1 /* 2 * Written by J.T. Conklin <jtc (at) netbsd.org>. 3 * Public domain. 4 */ 5 6 #include <machine/asm.h> 7 8 RCSID("$NetBSD: e_expf.S,v 1.3 2000/09/26 07:28:24 kleink Exp $") 9 10 /* e^x = 2^(x * log2(e)) */ 11 ENTRY(__ieee754_expf) 12 flds 4(%esp) 13 fldl2e 14 fmulp /* x * log2(e) */ 15 fldl %st(0) 16 frndint /* int(x * log2(e)) */ 17 fsubr %st(0),%st(1) /* fract(x * log2(e)) */ 18 fxch 19 f2xm1 /* 2^(fract(x * log2(e))) - 1 */ 20 fld1 21 faddp /* 2^(fract(x * log2(e))) */ 22 fscale /* e^x */ 23 fstpl %st(1) 24 ret 25