From: Richard Biener Date: Thu, 5 Nov 2015 08:43:46 +0000 (+0000) Subject: loadpre2.c: Avoid undefined behavior due to uninitialized variables. X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=175a31e4914dc8814c08f8961daf0d419e2f0cb7;p=gcc.git loadpre2.c: Avoid undefined behavior due to uninitialized variables. 2015-11-05 Richard Biener * gcc.dg/tree-ssa/loadpre2.c: Avoid undefined behavior due to uninitialized variables. * gcc.dg/tree-ssa/loadpre21.c: Likewise. * gcc.dg/tree-ssa/loadpre22.c: Likewise. * gcc.dg/tree-ssa/loadpre23.c: Likewise. * gcc.dg/tree-ssa/loadpre24.c: Likewise. * gcc.dg/tree-ssa/loadpre25.c: Likewise. * gcc.dg/tree-ssa/loadpre4.c: Likewise. * gcc.dg/ipa/inlinehint-2.c: Likewise. * gcc.dg/ipa/pure-const-2.c: Likewise. * gcc.dg/tree-ssa/loop-1.c: Likewise. * gcc.dg/tree-ssa/loop-23.c: Likewise. * gcc.dg/tree-ssa/pr22051-2.c: Likewise. * gcc.dg/tree-ssa/ssa-pre-3.c: Likewise. * gcc.dg/tree-ssa/ssa-sccvn-3.c: Likewise. * gcc.dg/vect/pr30858.c: Likewise. * gcc.dg/vect/pr33866.c: Likewise. * gcc.dg/vect/pr37027.c: Likewise. * c-c++-common/ubsan/null-10.c: Likewise. * gcc.target/i386/incoming-8.c: Likewise. From-SVN: r229793 --- diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 1733e60e691..98d481e77a5 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,26 @@ +2015-11-05 Richard Biener + + * gcc.dg/tree-ssa/loadpre2.c: Avoid undefined behavior due to + uninitialized variables. + * gcc.dg/tree-ssa/loadpre21.c: Likewise. + * gcc.dg/tree-ssa/loadpre22.c: Likewise. + * gcc.dg/tree-ssa/loadpre23.c: Likewise. + * gcc.dg/tree-ssa/loadpre24.c: Likewise. + * gcc.dg/tree-ssa/loadpre25.c: Likewise. + * gcc.dg/tree-ssa/loadpre4.c: Likewise. + * gcc.dg/ipa/inlinehint-2.c: Likewise. + * gcc.dg/ipa/pure-const-2.c: Likewise. + * gcc.dg/tree-ssa/loop-1.c: Likewise. + * gcc.dg/tree-ssa/loop-23.c: Likewise. + * gcc.dg/tree-ssa/pr22051-2.c: Likewise. + * gcc.dg/tree-ssa/ssa-pre-3.c: Likewise. + * gcc.dg/tree-ssa/ssa-sccvn-3.c: Likewise. + * gcc.dg/vect/pr30858.c: Likewise. + * gcc.dg/vect/pr33866.c: Likewise. + * gcc.dg/vect/pr37027.c: Likewise. + * c-c++-common/ubsan/null-10.c: Likewise. + * gcc.target/i386/incoming-8.c: Likewise. + 2015-11-04 Eric Botcazou * gnat.dg/slice9.adb: New test. diff --git a/gcc/testsuite/c-c++-common/ubsan/null-10.c b/gcc/testsuite/c-c++-common/ubsan/null-10.c index 2ff948565d5..705e00d327d 100644 --- a/gcc/testsuite/c-c++-common/ubsan/null-10.c +++ b/gcc/testsuite/c-c++-common/ubsan/null-10.c @@ -2,10 +2,12 @@ /* { dg-options "-fsanitize=null -w" } */ /* { dg-shouldfail "ubsan" } */ +short x; + int main (void) { - short *p = 0, *u; + short *p = 0, *u = &x; *(u + *p) = 23; return 0; } diff --git a/gcc/testsuite/gcc.dg/ipa/inlinehint-2.c b/gcc/testsuite/gcc.dg/ipa/inlinehint-2.c index cfdcb24bcd5..500100d3899 100644 --- a/gcc/testsuite/gcc.dg/ipa/inlinehint-2.c +++ b/gcc/testsuite/gcc.dg/ipa/inlinehint-2.c @@ -5,7 +5,7 @@ int t(int s, void **p) { int i; - for (i;i<10000;i+=s) + for (i=0;i<10000;i+=s) p[i]=0; } int diff --git a/gcc/testsuite/gcc.dg/ipa/pure-const-2.c b/gcc/testsuite/gcc.dg/ipa/pure-const-2.c index 51d779776bc..564a59c20cb 100644 --- a/gcc/testsuite/gcc.dg/ipa/pure-const-2.c +++ b/gcc/testsuite/gcc.dg/ipa/pure-const-2.c @@ -5,7 +5,7 @@ int i_am_pure(char *c, int n) { char *d=__builtin_alloca (n); int i; - int sum; + int sum = 0; for (i=0;ii; a->i = 9; } - return d + e; + return e; } /* { dg-final { scan-tree-dump-times "Eliminated: 1" 1 "pre" } } */ diff --git a/gcc/testsuite/gcc.dg/tree-ssa/loadpre4.c b/gcc/testsuite/gcc.dg/tree-ssa/loadpre4.c index 48630c8abbf..2ca7e393cdf 100644 --- a/gcc/testsuite/gcc.dg/tree-ssa/loadpre4.c +++ b/gcc/testsuite/gcc.dg/tree-ssa/loadpre4.c @@ -2,17 +2,15 @@ /* { dg-options "-O2 -fdump-tree-pre-stats" } */ int main(int *a, int argc) { - int b; - int c; int i; - int d, e; + int e; for (i = 0; i < argc; i++) { e = *a; *a = 9; } - return d + e; + return e; } /* { dg-final { scan-tree-dump-times "Eliminated: 1" 1 "pre" } } */ diff --git a/gcc/testsuite/gcc.dg/tree-ssa/loop-1.c b/gcc/testsuite/gcc.dg/tree-ssa/loop-1.c index 9d18dd7efdc..0193c6e52fc 100644 --- a/gcc/testsuite/gcc.dg/tree-ssa/loop-1.c +++ b/gcc/testsuite/gcc.dg/tree-ssa/loop-1.c @@ -24,7 +24,7 @@ int foo (int x); int xxx(void) { int x = 45; - int sum; + int sum = 0; while (x >>= 1) sum += foo (x) * 2; diff --git a/gcc/testsuite/gcc.dg/tree-ssa/loop-23.c b/gcc/testsuite/gcc.dg/tree-ssa/loop-23.c index 3c884849c5f..50ae1a8c1cf 100644 --- a/gcc/testsuite/gcc.dg/tree-ssa/loop-23.c +++ b/gcc/testsuite/gcc.dg/tree-ssa/loop-23.c @@ -7,7 +7,7 @@ int bla(int); int foo(void) { int i; - int sum; + int sum = 0; /* This loop used to appear to be too large for unrolling. */ for (i = 0; i < 4; i++) diff --git a/gcc/testsuite/gcc.dg/tree-ssa/pr22051-2.c b/gcc/testsuite/gcc.dg/tree-ssa/pr22051-2.c index cae9a06323a..98114f3d422 100644 --- a/gcc/testsuite/gcc.dg/tree-ssa/pr22051-2.c +++ b/gcc/testsuite/gcc.dg/tree-ssa/pr22051-2.c @@ -1,14 +1,10 @@ /* { dg-do compile } */ /* { dg-options "-O2 -fdump-tree-optimized -w" } */ - - - void *arf (); int -foo() +foo(void (*q)(void)) { - void (*q)(void); int r = q; if (r != 0) diff --git a/gcc/testsuite/gcc.dg/tree-ssa/ssa-pre-3.c b/gcc/testsuite/gcc.dg/tree-ssa/ssa-pre-3.c index 0af5342a566..ba2c8eaaa8d 100644 --- a/gcc/testsuite/gcc.dg/tree-ssa/ssa-pre-3.c +++ b/gcc/testsuite/gcc.dg/tree-ssa/ssa-pre-3.c @@ -1,8 +1,8 @@ /* { dg-do compile } */ /* { dg-options "-O2 -fdump-tree-pre-stats" } */ -unsigned foo1 (unsigned a, unsigned b) +unsigned foo1 (unsigned a, unsigned b, unsigned j, unsigned k) { - unsigned i, j, k; + unsigned i; for (i = 0; i != a; i++) { j += 4*b; diff --git a/gcc/testsuite/gcc.dg/tree-ssa/ssa-sccvn-3.c b/gcc/testsuite/gcc.dg/tree-ssa/ssa-sccvn-3.c index 4284d890520..9040ff856bc 100644 --- a/gcc/testsuite/gcc.dg/tree-ssa/ssa-sccvn-3.c +++ b/gcc/testsuite/gcc.dg/tree-ssa/ssa-sccvn-3.c @@ -1,8 +1,8 @@ /* { dg-do compile } */ -/* { dg-options "-O2 -fdump-tree-fre1-stats" } */ +/* { dg-options "-O2 -fdump-tree-fre1" } */ +int *p; int main(int argc, char **argv) { - int *p; int result; *p = 2; if (argc) @@ -11,4 +11,4 @@ int main(int argc, char **argv) return result; } /* We should eliminate result = *p by saying it has the value 2. */ -/* { dg-final { scan-tree-dump-times "Eliminated: 1" 1 "fre1"} } */ +/* { dg-final { scan-tree-dump "return 2;" "fre1"} } */ diff --git a/gcc/testsuite/gcc.dg/vect/pr30858.c b/gcc/testsuite/gcc.dg/vect/pr30858.c index 35a6a8dab36..cc92318d7df 100644 --- a/gcc/testsuite/gcc.dg/vect/pr30858.c +++ b/gcc/testsuite/gcc.dg/vect/pr30858.c @@ -4,7 +4,7 @@ int foo (int ko) { - int j,i; + int j,i = 0; for (j = 0; j < ko; j++) i += (i > 10) ? -5 : 7; return i; diff --git a/gcc/testsuite/gcc.dg/vect/pr33866.c b/gcc/testsuite/gcc.dg/vect/pr33866.c index ddb1287660c..737b2e8db2e 100644 --- a/gcc/testsuite/gcc.dg/vect/pr33866.c +++ b/gcc/testsuite/gcc.dg/vect/pr33866.c @@ -18,7 +18,7 @@ void test_select_fill_hyper_simple (long *offset) fill_iter_info iter_info; int i, j; iter_info.coords = (long *) points; - for (i = 0, num_points = 0; j < (int) start[1]; j++, num_points++) + for (j = i = 0, num_points = 0; j < (int) start[1]; j++, num_points++) { points[num_points][0] = i + start[0]; points[num_points][1] = j + start[1]; diff --git a/gcc/testsuite/gcc.dg/vect/pr37027.c b/gcc/testsuite/gcc.dg/vect/pr37027.c index 8c83f01bceb..ef6760ec924 100644 --- a/gcc/testsuite/gcc.dg/vect/pr37027.c +++ b/gcc/testsuite/gcc.dg/vect/pr37027.c @@ -18,8 +18,8 @@ void foo (void) { int i; - int sum1; - int sum2; + int sum1 = 0; + int sum2 = 0; for (i = 0; i < 16; i++) { diff --git a/gcc/testsuite/gcc.target/i386/incoming-8.c b/gcc/testsuite/gcc.target/i386/incoming-8.c index 61d9cb37d72..a9912d1b122 100644 --- a/gcc/testsuite/gcc.target/i386/incoming-8.c +++ b/gcc/testsuite/gcc.target/i386/incoming-8.c @@ -6,7 +6,7 @@ float foo (float f) { float array[128]; - float x; + float x = 0.; int i; for (i = 0; i < sizeof(array) / sizeof(*array); i++) array[i] = f;