]> git.ipfire.org Git - thirdparty/glibc.git/commitdiff
Fix x86_64 fma4 pow inappropriate contraction (bug 19003).
authorJoseph Myers <joseph@codesourcery.com>
Thu, 24 Sep 2015 16:48:32 +0000 (16:48 +0000)
committerMike Frysinger <vapier@gentoo.org>
Wed, 30 Mar 2016 18:41:17 +0000 (14:41 -0400)
The x86_64 fma4 version of pow fails to disable contraction of
operations other than those explicitly intended to use fma
instructions, so resulting in large ulps errors on processors with
fma4 instructions, as in bug 18104 (165ulp for the test added for that
bug; error originally reported by "blaaa" on #glibc).  This patch adds
$(config-cflags-nofma) for e_pow-fma4.c, corresponding to the use for
e_pow.c in sysdeps/ieee754/dbl-64/Makefile.

Tested for x86_64 on a processor with fma4.

[BZ #19003]
* sysdeps/x86_64/fpu/multiarch/Makefile (CFLAGS-e_pow-fma4.c): Add
$(config-cflags-nofma).

(cherry picked from commit 51df2605064a2bfd44fa0655ef9815812347de80)
(cherry picked from commit c95a56e2a8b16eeb911eed5c1bdc8fd26f337f4d)

sysdeps/x86_64/fpu/multiarch/Makefile

index 86ea473b4ff9f1fef0bd5a85689ded79dc67a9f3..631534a5ce0d9eecf42a9d5c93d53b5b5c0cfe3d 100644 (file)
@@ -16,7 +16,7 @@ CFLAGS-e_asin-fma4.c = -mfma4
 CFLAGS-e_atan2-fma4.c = -mfma4
 CFLAGS-e_exp-fma4.c = -mfma4
 CFLAGS-e_log-fma4.c = -mfma4
-CFLAGS-e_pow-fma4.c = -mfma4
+CFLAGS-e_pow-fma4.c = -mfma4 $(config-cflags-nofma)
 CFLAGS-halfulp-fma4.c = -mfma4
 CFLAGS-mpa-fma4.c = -mfma4
 CFLAGS-mpatan-fma4.c = -mfma4