summaryrefslogtreecommitdiffstats
path: root/meta/recipes-core/eglibc/eglibc-2.15/x86_fenv.patch
blob: 40c1c4d67e1ded6583565aa532919e38af8acbb2 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
--- a/sysdeps/x86_64/fpu/bits/fenv.h
+++ b/sysdeps/x86_64/fpu/bits/fenv.h
@@ -112,16 +112,24 @@ __NTH (feraiseexcept (int __excepts))
 	{
 	  /* One example of a invalid operation is 0.0 / 0.0.  */
 	  float __f = 0.0;
-
+# if defined __SSE_MATH__ || __WORDSIZE == 64
 	  __asm__ __volatile__ ("divss %0, %0 " : : "x" (__f));
+# else
+	 __asm__ __volatile__ ("fdiv %%st, %%st(0); fwait"
+			       : "=t" (__f) : "0" (__f));
+# endif
 	  (void) &__f;
 	}
       if ((FE_DIVBYZERO & __excepts) != 0)
 	{
 	  float __f = 1.0;
 	  float __g = 0.0;
-
+# if defined __SSE_MATH__ || __WORDSIZE == 64
 	  __asm__ __volatile__ ("divss %1, %0" : : "x" (__f), "x" (__g));
+# else
+	  __asm__ __volatile__ ("fdivp %%st(1), %%st; fwait"
+				: "=t" (__f) : "0" (__f), "u" (__g) : "st(1)");
+# endif
 	  (void) &__f;
 	}