/uspace/lib/softfloat/neg.c

https://gitlab.com/vhelen/vhelen · C · 87 lines · 33 code · 19 blank · 35 comment · 0 complexity · 5a9ea8a53f29ec9febb8b3ac94c0a861 MD5 · raw file

  1. /*
  2. * Copyright (c) 2005 Josef Cejka
  3. * Copyright (c) 2011 Petr Koupy
  4. * All rights reserved.
  5. *
  6. * Redistribution and use in source and binary forms, with or without
  7. * modification, are permitted provided that the following conditions
  8. * are met:
  9. *
  10. * - Redistributions of source code must retain the above copyright
  11. * notice, this list of conditions and the following disclaimer.
  12. * - Redistributions in binary form must reproduce the above copyright
  13. * notice, this list of conditions and the following disclaimer in the
  14. * documentation and/or other materials provided with the distribution.
  15. * - The name of the author may not be used to endorse or promote products
  16. * derived from this software without specific prior written permission.
  17. *
  18. * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
  19. * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
  20. * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
  21. * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
  22. * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
  23. * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
  24. * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
  25. * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
  26. * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
  27. * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  28. */
  29. /** @addtogroup softfloat
  30. * @{
  31. */
  32. /** @file Negation functions.
  33. */
  34. #include "neg.h"
  35. #include "common.h"
  36. #ifdef float32_t
  37. float32_t __negsf2(float32_t a)
  38. {
  39. float32_u ua;
  40. ua.val = a;
  41. ua.data.parts.sign = !ua.data.parts.sign;
  42. return ua.val;
  43. }
  44. #endif
  45. #ifdef float64_t
  46. float64_t __negdf2(float64_t a)
  47. {
  48. float64_u ua;
  49. ua.val = a;
  50. ua.data.parts.sign = !ua.data.parts.sign;
  51. return ua.val;
  52. }
  53. #endif
  54. #ifdef float128_t
  55. float128_t __negtf2(float128_t a)
  56. {
  57. float128_u ua;
  58. ua.val = a;
  59. ua.data.parts.sign = !ua.data.parts.sign;
  60. return ua.val;
  61. }
  62. void _Qp_neg(float128_t *c, float128_t *a)
  63. {
  64. *c = __negtf2(*a);
  65. }
  66. #endif
  67. /** @}
  68. */