The PR is about inconsistent behavior wrt inline predicate analysis
and later folding of __builtin_constant_p which ultimatively results
from fold_builtin_constant_p stripping nops off its argument but
this not being done on GIMPLE. The following adds a match.pd pattern
for this.
PR ipa/111036
* match.pd (__builtin_constant_p ((T)x)): Strip nop-conversions
from __builtin_constant_p arguments.
* gcc.dg/torture/pr111036.c: New testcase.
long as the requested element is within range. */
(simplify (IFN_VEC_EXTRACT (vec_duplicate @0) INTEGER_CST@1)
@0)
+
+/* Strip nop-conversions __builtin_constant_p arguments. */
+(simplify
+ (BUILT_IN_CONSTANT_P (nop_convert@1 @0))
+ (BUILT_IN_CONSTANT_P @0))
--- /dev/null
+/* { dg-do run } */
+
+#include <stdlib.h>
+
+__attribute__((aligned(32))) static struct
+{
+ unsigned long long available_cmd_ids_per_core[2];
+} _rl2c_cmd_id_data;
+
+static inline void __attribute__((always_inline))
+foo (void *base, size_t length)
+{
+ unsigned long int p = (unsigned long int) base;
+ if (__builtin_constant_p(p) && (p & 31) == 0) { exit (0); }
+ else if (__builtin_constant_p(length)) { exit (0); }
+ else { exit (0); }
+}
+
+int main(int argc, char **argv)
+{
+ foo(&_rl2c_cmd_id_data, sizeof(*(&_rl2c_cmd_id_data)));
+ return 0;
+}
+