From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: by sourceware.org (Postfix, from userid 1791) id 6CCDD3858436; Thu, 21 Dec 2023 18:54:31 +0000 (GMT) DKIM-Filter: OpenDKIM Filter v2.11.0 sourceware.org 6CCDD3858436 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=sourceware.org; s=default; t=1703184871; bh=YYznLe2+sKg6MCVME/05ozeWqQnPLRR2skAlH6ygn34=; h=From:To:Subject:Date:From; b=CZlSlh4aSQNhsDsWu/3vYKwYotmVHczIe54Qtgeuoff27OmmQh3dhMzJcGXhtCwcx TUJ0bLiLpNJFUkdb9kc/15D6Wqi08KVoKYpOAGK/Fe8zqEcAU4Fci/p/2EaQbDejyb LTqINlTXNHq++ZSriLwqYytzb18urBTWCH0bBBss= Content-Type: text/plain; charset="us-ascii" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit From: Adhemerval Zanella To: glibc-cvs@sourceware.org Subject: [glibc/azanella/clang] i386: sfp-machine.h: Do no use asm input cast for clang X-Act-Checkin: glibc X-Git-Author: Adhemerval Zanella X-Git-Refname: refs/heads/azanella/clang X-Git-Oldrev: 9470105aade86301226bba9d7c0f8d6064b7d49d X-Git-Newrev: f2d30112b1fbbec1bc3743aace27c27e530ee3e7 Message-Id: <20231221185431.6CCDD3858436@sourceware.org> Date: Thu, 21 Dec 2023 18:54:31 +0000 (GMT) List-Id: https://sourceware.org/git/gitweb.cgi?p=glibc.git;h=f2d30112b1fbbec1bc3743aace27c27e530ee3e7 commit f2d30112b1fbbec1bc3743aace27c27e530ee3e7 Author: Adhemerval Zanella Date: Tue Jul 26 08:45:41 2022 -0300 i386: sfp-machine.h: Do no use asm input cast for clang clang by default rejects the input casts with: error: invalid use of a cast in a inline asm context requiring an lvalue: remove the cast or build with -fheinous-gnu-extensions And even with -fheinous-gnu-extensions clang still throws an warning and also states that this option might be removed in the future. For gcc the cast are still useful [1] as type-checking. [1] https://gcc.gnu.org/pipermail/gcc-patches/2021-October/581722.html Diff: --- sysdeps/x86/fpu/sfp-machine.h | 44 +++++++++++++++++++++++++------------------ 1 file changed, 26 insertions(+), 18 deletions(-) diff --git a/sysdeps/x86/fpu/sfp-machine.h b/sysdeps/x86/fpu/sfp-machine.h index 89a73642b1..dd23c797bd 100644 --- a/sysdeps/x86/fpu/sfp-machine.h +++ b/sysdeps/x86/fpu/sfp-machine.h @@ -64,15 +64,23 @@ typedef unsigned int UTItype __attribute__ ((mode (TI))); # define _FP_WS_TYPE signed int # define _FP_I_TYPE int +/* clang does not support output constraint as lvalue, while gcc uses it as a + simple type check. */ +# ifdef __clang__ +# define __asm_output_check_type(__type, __arg) (__arg) +# else +# define __asm_output_check_type(__type, __arg) ((__type)(__arg)) +# endif + # define __FP_FRAC_ADD_4(r3,r2,r1,r0,x3,x2,x1,x0,y3,y2,y1,y0) \ __asm__ ("add{l} {%11,%3|%3,%11}\n\t" \ "adc{l} {%9,%2|%2,%9}\n\t" \ "adc{l} {%7,%1|%1,%7}\n\t" \ "adc{l} {%5,%0|%0,%5}" \ - : "=r" ((USItype) (r3)), \ - "=&r" ((USItype) (r2)), \ - "=&r" ((USItype) (r1)), \ - "=&r" ((USItype) (r0)) \ + : "=r" __asm_output_check_type (USItype, r3), \ + "=&r" __asm_output_check_type (USItype, r2), \ + "=&r" __asm_output_check_type (USItype, r1), \ + "=&r" __asm_output_check_type (USItype, r0) \ : "%0" ((USItype) (x3)), \ "g" ((USItype) (y3)), \ "%1" ((USItype) (x2)), \ @@ -85,9 +93,9 @@ typedef unsigned int UTItype __attribute__ ((mode (TI))); __asm__ ("add{l} {%8,%2|%2,%8}\n\t" \ "adc{l} {%6,%1|%1,%6}\n\t" \ "adc{l} {%4,%0|%0,%4}" \ - : "=r" ((USItype) (r2)), \ - "=&r" ((USItype) (r1)), \ - "=&r" ((USItype) (r0)) \ + : "=r" __asm_output_check_type (USItype, r2), \ + "=&r" __asm_output_check_type (USItype, r1), \ + "=&r" __asm_output_check_type (USItype, r0) \ : "%0" ((USItype) (x2)), \ "g" ((USItype) (y2)), \ "%1" ((USItype) (x1)), \ @@ -99,10 +107,10 @@ typedef unsigned int UTItype __attribute__ ((mode (TI))); "sbb{l} {%9,%2|%2,%9}\n\t" \ "sbb{l} {%7,%1|%1,%7}\n\t" \ "sbb{l} {%5,%0|%0,%5}" \ - : "=r" ((USItype) (r3)), \ - "=&r" ((USItype) (r2)), \ - "=&r" ((USItype) (r1)), \ - "=&r" ((USItype) (r0)) \ + : "=r" __asm_output_check_type (USItype, r3), \ + "=&r" __asm_output_check_type (USItype, r2), \ + "=&r" __asm_output_check_type (USItype, r1), \ + "=&r" __asm_output_check_type (USItype, r0) \ : "0" ((USItype) (x3)), \ "g" ((USItype) (y3)), \ "1" ((USItype) (x2)), \ @@ -115,9 +123,9 @@ typedef unsigned int UTItype __attribute__ ((mode (TI))); __asm__ ("sub{l} {%8,%2|%2,%8}\n\t" \ "sbb{l} {%6,%1|%1,%6}\n\t" \ "sbb{l} {%4,%0|%0,%4}" \ - : "=r" ((USItype) (r2)), \ - "=&r" ((USItype) (r1)), \ - "=&r" ((USItype) (r0)) \ + : "=r" __asm_output_check_type (USItype, r2), \ + "=&r" __asm_output_check_type (USItype, r1), \ + "=&r" __asm_output_check_type (USItype, r0) \ : "0" ((USItype) (x2)), \ "g" ((USItype) (y2)), \ "1" ((USItype) (x1)), \ @@ -129,10 +137,10 @@ typedef unsigned int UTItype __attribute__ ((mode (TI))); "adc{l} {$0,%2|%2,0}\n\t" \ "adc{l} {$0,%1|%1,0}\n\t" \ "adc{l} {$0,%0|%0,0}" \ - : "+r" ((USItype) (x3)), \ - "+&r" ((USItype) (x2)), \ - "+&r" ((USItype) (x1)), \ - "+&r" ((USItype) (x0)) \ + : "+r" __asm_output_check_type (USItype, x3), \ + "+&r" __asm_output_check_type (USItype, x2), \ + "+&r" __asm_output_check_type (USItype, x1), \ + "+&r" __asm_output_check_type (USItype, x0) \ : "g" ((USItype) (i)))