/* * Written by J.T. Conklin . * Public domain. */ #include RCSID("$NetBSD: e_exp.S,v 1.4.6.1 1996/07/03 19:27:36 jtc Exp $") /* e^x = 2^(x * log2(e)) */ ENTRY(__ieee754_exp) subl $8,%esp fstcw 4(%esp) /* store fpu control word */ movw 4(%esp),%dx orw $0x0180,%dx movw %dx,(%esp) fldcw (%esp) /* load modfied control word */ fldl 12(%esp) fldl2e fmulp /* x * log2(e) */ fstl %st(1) frndint /* int(x * log2(e)) */ fxch %st(1) fsub %st(1),%st /* fract(x * log2(e)) */ f2xm1 /* 2^(fract(x * log2(e))) - 1 */ fld1 faddp /* 2^(fract(x * log2(e))) */ fscale /* e^x */ fstpl %st(1) fldcw 4(%esp) /* restore original control word */ addl $8,%esp ret