[Bug tree-optimization/103194] [12 Regression] ice in optimize_atomic_bit_test_and with __sync_fetch_and_and since r12-5102-gfb161782545224f5

jakub at gcc dot gnu.org gcc-bugzilla@gcc.gnu.org
Wed Dec 15 12:47:28 GMT 2021


https://gcc.gnu.org/bugzilla/show_bug.cgi?id=103194

--- Comment #22 from Jakub Jelinek <jakub at gcc dot gnu.org> ---
(In reply to Hongtao.liu from comment #15)
> > Is the behavior well defined for n >= 64? I got
> > 
> > foo.c:11:19: warning: left shift count >= width of type
> > [-Wshift-count-overflow]
> >    11 |   long mask = 1ll << 65;
> >       |                   ^~
> According to C99
> The result of E1 << E2 is E1 left-shifted E2 bit positions; vacated bits are
> filled with zeros. If E1 has an unsigned type, the value of the result is E1
> × 2E2, reduced modulo one more than the maximum value representable in the
> result type. If E1 has a signed type and nonnegative value, and E1 × 2E2 is
> representable in the result type, then that is the resulting value;
> otherwise, the behavior is undefined.
> 
> So yes, it's well defined, and the result is zero.

No, that isn't well defined in any C or C++ versions.
E.g. in C++:
https://eel.is/c++draft/expr.shift#1
The behavior is undefined if the right operand is negative, or greater than or
equal to the width of the promoted left operand.
C99 6.5.7:
If the value of the right operand is negative or is
greater than or equal to the width of the promoted left operand, the behavior
is undefined.
What varies is whether shifting negative values left is well defined or not, or
whether shifting bits into the sign bit of signed type is well defined or not.


More information about the Gcc-bugs mailing list