aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJakub Jelinek <jakub@redhat.com>2022-06-27 15:35:25 +0200
committerJakub Jelinek <jakub@redhat.com>2022-06-27 15:36:14 +0200
commit00063459f683adcd92ada8325984e6b10e9f7a95 (patch)
treebd8da27e71ade78ec78f5df0bba68084e44d8fc1
parent01e094f82d8d91e08f62465a2e4f7a4c4897f9cd (diff)
downloadgcc-00063459f683adcd92ada8325984e6b10e9f7a95.zip
gcc-00063459f683adcd92ada8325984e6b10e9f7a95.tar.gz
gcc-00063459f683adcd92ada8325984e6b10e9f7a95.tar.bz2
testsuite: Fix up pr106070.c test [PR106070]
The test FAILs on 32-bit targets, because when unsigned long is 32-bit, (unsigned long) -1 isn't 0xffffffffffffffff. The options to fix this would be either using -1UL, or switch to unsigned long long and using -1ULL, I chose the latter because the test then FAILs in r13-1242 even on 32-bit targets. And while at it, some deobfuscation and formatting tweaks. 2022-06-27 Jakub Jelinek <jakub@redhat.com> PR tree-optimization/106070 * gcc.dg/torture/pr106070.c: Use unsigned long long instead of unsigned long and -1ULL instead of 0xffffffffffffffff, deobcuscate and improve formatting.
-rw-r--r--gcc/testsuite/gcc.dg/torture/pr106070.c28
1 files changed, 15 insertions, 13 deletions
diff --git a/gcc/testsuite/gcc.dg/torture/pr106070.c b/gcc/testsuite/gcc.dg/torture/pr106070.c
index c36534f..f031516 100644
--- a/gcc/testsuite/gcc.dg/torture/pr106070.c
+++ b/gcc/testsuite/gcc.dg/torture/pr106070.c
@@ -1,20 +1,22 @@
/* { dg-do run } */
-unsigned int var_2 = 1;
-int var_4 = -1;
-int var_10 = 4;
-unsigned long arr_252;
-void __attribute__((noipa)) test() {
- for (int a = 0; a < var_10; a += 2)
- arr_252 = var_2 != (int)var_4 ? (unsigned long)var_4 : (unsigned long)var_2;
-}
+unsigned int a = 1;
+int b = -1;
+int c = 4;
+unsigned long long d;
-void test();
+void __attribute__((noipa))
+test (void)
+{
+ for (int i = 0; i < c; i += 2)
+ d = a != (int) b ? (unsigned long long) b : (unsigned long long) a;
+}
-int main()
+int
+main ()
{
- test();
- if (arr_252 != 0xffffffffffffffff)
- __builtin_abort();
+ test ();
+ if (d != -1ULL)
+ __builtin_abort ();
return 0;
}