]> git.ipfire.org Git - thirdparty/glibc.git/commitdiff
x86_64: Fix asm constraints in feraiseexcept (bug 30305)
authorFlorian Weimer <fweimer@redhat.com>
Mon, 3 Apr 2023 15:23:11 +0000 (17:23 +0200)
committerFlorian Weimer <fweimer@redhat.com>
Mon, 3 Apr 2023 16:40:52 +0000 (18:40 +0200)
The divss instruction clobbers its first argument, and the constraints
need to reflect that.  Fortunately, with GCC 12, generated code does
not actually change, so there is no externally visible bug.

Suggested-by: Jakub Jelinek <jakub@redhat.com>
Reviewed-by: Noah Goldstein <goldstein.w.n@gmail.com>
sysdeps/x86_64/fpu/fraiseexcpt.c

index 924eed96a90de26f6cddb415a83c9ce29ffc7dd6..e7430a4158fb1b9302a8fb6cf503017034a61f8c 100644 (file)
@@ -33,7 +33,7 @@ __feraiseexcept (int excepts)
       /* One example of an invalid operation is 0.0 / 0.0.  */
       float f = 0.0;
 
-      __asm__ __volatile__ ("divss %0, %0 " : : "x" (f));
+      __asm__ __volatile__ ("divss %0, %0 " : "+x" (f));
       (void) &f;
     }
 
@@ -43,7 +43,7 @@ __feraiseexcept (int excepts)
       float f = 1.0;
       float g = 0.0;
 
-      __asm__ __volatile__ ("divss %1, %0" : : "x" (f), "x" (g));
+      __asm__ __volatile__ ("divss %1, %0" : "+x" (f) : "x" (g));
       (void) &f;
     }