From: Martin Sebor Date: Fri, 14 Jan 2022 16:59:53 +0000 (-0700) Subject: Test to verify -Wformat-overflow uses context-sensitive ranges. X-Git-Tag: upstream/12.2.0~2106 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=1e6294bb15d2169147c7838f89a9168980b94b47;p=platform%2Fupstream%2Fgcc.git Test to verify -Wformat-overflow uses context-sensitive ranges. gcc/testsuite/ChangeLog: * gcc.dg/tree-ssa/builtin-sprintf-warn-28.c: New test. --- diff --git a/gcc/testsuite/gcc.dg/tree-ssa/builtin-sprintf-warn-28.c b/gcc/testsuite/gcc.dg/tree-ssa/builtin-sprintf-warn-28.c new file mode 100644 index 0000000..d58d980 --- /dev/null +++ b/gcc/testsuite/gcc.dg/tree-ssa/builtin-sprintf-warn-28.c @@ -0,0 +1,21 @@ +/* Verify that -Wformat-overflow uses context-sensitive ranges even + at -O0 to avoid both false positives and negatives. + { dg-do compile } + { dg-options "-O0 -Wall" } */ + +extern int sprintf (char*, const char*, ...); + +extern char a[4]; + +void test_context_range (int c) +{ + int i = 998; + + /* Prior to the switch to Ranger in GCC 12 -Wformat-overflow triggers + for both calls because EVRP doesn't expose the accurate range of + the argument. */ + if (c) + sprintf (a, "%i", i + 2); // { dg-warning "writing a terminating nul past the end of the destination" } + else + sprintf (a, "%i", i + 1); // { dg-bogus "-Wformat-overflow" } +}