From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: by sourceware.org (Postfix, from userid 1791) id 6099D3858436; Fri, 28 Oct 2022 17:47:05 +0000 (GMT) DKIM-Filter: OpenDKIM Filter v2.11.0 sourceware.org 6099D3858436 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=sourceware.org; s=default; t=1666979225; bh=l6sncjaI9t8ft5EZ5nt/wihh2Togh3f/g86jXWlmSD8=; h=From:To:Subject:Date:From; b=WUGdEkVIuEJ2dTeaCS5pzW1LLVievPtYc6pE+2L6aJvKljz5IxRDT8d5q9cnA+FML w6aFRzGeEAVpIl1LLAArmqrb5ii4d8AX92VugxuA2Bv1JbJ7o0CbLLXLHaqUzUmS4p c90Wwv7yZ9wCnNvNVBeVhVQ9qI1SzOFlwV8B/YV8= 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] math: Do not use __builtin_isinf on clang X-Act-Checkin: glibc X-Git-Author: Adhemerval Zanella X-Git-Refname: refs/heads/azanella/clang X-Git-Oldrev: 97c98382984f9faebb29e958431663cb5dcc9550 X-Git-Newrev: 6fdea0a59646ab4f4eaba28685e46307ca59f843 Message-Id: <20221028174705.6099D3858436@sourceware.org> Date: Fri, 28 Oct 2022 17:47:05 +0000 (GMT) List-Id: https://sourceware.org/git/gitweb.cgi?p=glibc.git;h=6fdea0a59646ab4f4eaba28685e46307ca59f843 commit 6fdea0a59646ab4f4eaba28685e46307ca59f843 Author: Adhemerval Zanella Date: Fri Apr 1 17:03:34 2022 -0300 math: Do not use __builtin_isinf on clang It does not handle pseudo normal numbers. Diff: --- math/math.h | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/math/math.h b/math/math.h index 82e484b777..7afb6d32b9 100644 --- a/math/math.h +++ b/math/math.h @@ -1012,7 +1012,8 @@ enum /* Return nonzero value if X is positive or negative infinity. */ # if __HAVE_DISTINCT_FLOAT128 && !__GNUC_PREREQ (7,0) \ - && !defined __SUPPORT_SNAN__ && !defined __cplusplus + && !defined __SUPPORT_SNAN__ && !defined __cplusplus \ + && !defined __clang__ /* Since __builtin_isinf_sign is broken for float128 before GCC 7.0, use the helper function, __isinff128, with older compilers. This is only provided for C mode, because in C++ mode, GCC has no support @@ -1021,8 +1022,7 @@ enum # define isinf(x) \ (__builtin_types_compatible_p (__typeof (x), _Float128) \ ? __isinff128 (x) : __builtin_isinf_sign (x)) -# elif (__GNUC_PREREQ (4,4) && !defined __SUPPORT_SNAN__) \ - || __glibc_clang_prereq (3,7) +# elif (__GNUC_PREREQ (4,4) && !defined __SUPPORT_SNAN__) # define isinf(x) __builtin_isinf_sign (x) # else # define isinf(x) __MATH_TG ((x), __isinf, (x))