math: fix x86_64 and x32 asm not to use sahf instruction
authorSzabolcs Nagy <nsz@port70.net>
Wed, 5 Nov 2014 20:40:29 +0000 (21:40 +0100)
committerRich Felker <dalias@aerifal.cx>
Mon, 30 Mar 2015 05:41:32 +0000 (01:41 -0400)
commit8c245bf2725f3171ee8f58dab7169e5d682de026
treeae92d5d0536aa3b15adb96d62b4487488998e5a8
parente48fff8d338d85616dc650cc8b4dd5ae00083da1
math: fix x86_64 and x32 asm not to use sahf instruction

Some early x86_64 cpus (released before 2006) did not support sahf/lahf
instructions so they should be avoided (intel manual says they are only
supported if CPUID.80000001H:ECX.LAHF-SAHF[bit 0] = 1).

The workaround simplifies exp2l and expm1l because fucomip can be
used instead of the fucomp;fnstsw;sahf sequence copied from i386.

In fmodl and remainderl sahf is replaced by a simple bit test.

(cherry picked from commit a732e80d33b4fd6f510f7cec4f5573ef5d89bc4e)
src/math/x32/exp2l.s
src/math/x32/fmodl.s
src/math/x32/remainderl.s
src/math/x86_64/exp2l.s
src/math/x86_64/fmodl.s
src/math/x86_64/remainderl.s