From: Matthias Kretz Date: Fri, 13 Jan 2023 15:20:36 +0000 (+0100) Subject: libstdc++: Ensure __builtin_constant_p isn't lost on the way X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=e4ddaf9dd48763227ab93c8fe93f7d04080c07a1;p=people%2Fms%2Fgcc.git libstdc++: Ensure __builtin_constant_p isn't lost on the way The more expensive code path should only be taken if it can be optimized away. Signed-off-by: Matthias Kretz libstdc++-v3/ChangeLog: * include/experimental/bits/simd.h (_SimdWrapper::_M_is_constprop_none_of) (_SimdWrapper::_M_is_constprop_all_of): Return false unless the computed result still satisfies __builtin_constant_p. (cherry picked from commit fea34ee491104f325682cc5fb75683b7d74a0a3b) --- diff --git a/libstdc++-v3/include/experimental/bits/simd.h b/libstdc++-v3/include/experimental/bits/simd.h index 0e58ae01b17..e9a07018cf0 100644 --- a/libstdc++-v3/include/experimental/bits/simd.h +++ b/libstdc++-v3/include/experimental/bits/simd.h @@ -2546,7 +2546,8 @@ template else __execute_n_times<_Width>( [&](auto __i) { __r &= _M_data[__i.value] == _Tp(); }); - return __r; + if (__builtin_constant_p(__r)) + return __r; } return false; } @@ -2566,7 +2567,8 @@ template else __execute_n_times<_Width>( [&](auto __i) { __r &= _M_data[__i.value] == ~_Tp(); }); - return __r; + if (__builtin_constant_p(__r)) + return __r; } return false; }