e_exp.S 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. /*
  2. * Copyright (c) 1993,94 Winning Strategies, Inc.
  3. * All rights reserved.
  4. *
  5. * Redistribution and use in source and binary forms, with or without
  6. * modification, are permitted provided that the following conditions
  7. * are met:
  8. * 1. Redistributions of source code must retain the above copyright
  9. * notice, this list of conditions and the following disclaimer.
  10. * 2. Redistributions in binary form must reproduce the above copyright
  11. * notice, this list of conditions and the following disclaimer in the
  12. * documentation and/or other materials provided with the distribution.
  13. * 3. All advertising materials mentioning features or use of this software
  14. * must display the following acknowledgement:
  15. * This product includes software developed by Winning Strategies, Inc.
  16. * 4. The name of the author may not be used to endorse or promote products
  17. * derived from this software without specific prior written permission.
  18. *
  19. * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
  20. * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
  21. * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
  22. * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
  23. * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
  24. * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
  25. * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
  26. * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
  27. * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
  28. * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  29. */
  30. /*
  31. * Written by:
  32. * J.T. Conklin (jtc@wimsey.com), Winning Strategies, Inc.
  33. */
  34. #include <machine/asm.h>
  35. //__FBSDID("$FreeBSD: src/lib/msun/i387/e_exp.S,v 1.14 2011/01/07 16:13:12 kib Exp $")
  36. /* e^x = 2^(x * log2(e)) */
  37. ENTRY(exp)
  38. /*
  39. * If x is +-Inf, then the subtraction would give Inf-Inf = NaN.
  40. * Avoid this. Also avoid it if x is NaN for convenience.
  41. */
  42. movl 8(%esp),%eax
  43. andl $0x7fffffff,%eax
  44. cmpl $0x7ff00000,%eax
  45. jae x_Inf_or_NaN
  46. fldl 4(%esp)
  47. /*
  48. * Extended precision is needed to reduce the maximum error from
  49. * hundreds of ulps to less than 1 ulp. Switch to it if necessary.
  50. * We may as well set the rounding mode to to-nearest and mask traps
  51. * if we switch.
  52. */
  53. fstcw 4(%esp)
  54. movl 4(%esp),%eax
  55. andl $0x0300,%eax
  56. cmpl $0x0300,%eax /* RC == 0 && PC == 3? */
  57. je 1f /* jump if mode is good */
  58. movl $0x137f,8(%esp)
  59. fldcw 8(%esp)
  60. 1:
  61. fldl2e
  62. fmulp /* x * log2(e) */
  63. fst %st(1)
  64. frndint /* int(x * log2(e)) */
  65. fst %st(2)
  66. fsubrp /* fract(x * log2(e)) */
  67. f2xm1 /* 2^(fract(x * log2(e))) - 1 */
  68. fld1
  69. faddp /* 2^(fract(x * log2(e))) */
  70. fscale /* e^x */
  71. fstp %st(1)
  72. je 1f
  73. fldcw 4(%esp)
  74. 1:
  75. ret
  76. x_Inf_or_NaN:
  77. /*
  78. * Return 0 if x is -Inf. Otherwise just return x; when x is Inf
  79. * this gives Inf, and when x is a NaN this gives the same result
  80. * as (x + x) (x quieted).
  81. */
  82. cmpl $0xfff00000,8(%esp)
  83. jne x_not_minus_Inf
  84. cmpl $0,4(%esp)
  85. jne x_not_minus_Inf
  86. fldz
  87. ret
  88. x_not_minus_Inf:
  89. fldl 4(%esp)
  90. ret
  91. END(exp)
  92. .section .note.GNU-stack,"",%progbits