]> git.ipfire.org Git - thirdparty/glibc.git/commit
ldbl-96: Set -1 to "int sign_exponent:16"
authorH.J. Lu <hjl.tools@gmail.com>
Mon, 16 Dec 2024 21:50:47 +0000 (05:50 +0800)
committerH.J. Lu <hjl.tools@gmail.com>
Tue, 17 Dec 2024 17:54:26 +0000 (01:54 +0800)
commit54fe008ba66b2575fb1815f3d5e0811a0107a00c
tree10ee5f75873be9e9350489f1526ef610b04aa241
parentd4ee46b0cd43012d311e07f11ee960efec3f1a94
ldbl-96: Set -1 to "int sign_exponent:16"

ieee_long_double_shape_type has

typedef union
{
  long double value;
  struct
  {
    ...
    int sign_exponent:16;
    ...
  } parts;
} ieee_long_double_shape_type;

Clang issues an error:

../sysdeps/ieee754/ldbl-96/test-totalorderl-ldbl-96.c:49:2: error: implicit truncation from 'int' to bit-field changes value from 65535 to -1 [-Werror,-Wbitfield-constant-conversion]
   49 |         SET_LDOUBLE_WORDS (ldnx, 0xffff,
      |         ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
   50 |                            tests[i] >> 32, tests[i] & 0xffffffffULL);
      |

Use -1, instead of 0xffff, to silence Clang.

Signed-off-by: H.J. Lu <hjl.tools@gmail.com>
Reviewed-by: Sam James <sam@gentoo.org>
sysdeps/ieee754/ldbl-96/test-totalorderl-ldbl-96.c