blob: b9bce62d98209321b76ae33103ae26d4b9cf09ef [file] [log] [blame]
/* { dg-do compile } */
/* { dg-options "-O2 -Wformat-overflow" } */
extern __inline __attribute__ ((__always_inline__)) __attribute__ ((__gnu_inline__)) __attribute__ ((__artificial__)) int
__attribute__ ((__nothrow__ , __leaf__)) sprintf (char *__restrict __s, const char *__restrict __fmt, ...)
{
return __builtin___sprintf_chk (__s, 2 - 1,
__builtin_object_size (__s, 2 > 1), __fmt, __builtin_va_arg_pack ());
}
char number[sizeof "999999"];
int somerandom (void);
void
Foo (void)
{
int i = somerandom ();
if (! (0 <= i))
__builtin_unreachable ();
if (! (0 <= i && i <= 999999))
__builtin_unreachable ();
/* Legacy evrp sets the range of i to [0, MAX] *before* the first conditional,
and to [0,999999] *before* the second conditional. This is because both
evrp and VRP use trickery to set global ranges when this particular use of
a __builtin_unreachable is in play (see uses of
assert_unreachable_fallthru_edge_p).
Setting these ranges at the definition site, causes VRP to remove the
unreachable code altogether, leaving the following sprintf unguarded. This
causes the bogus warning below. */
sprintf (number, "%d", i); /* { dg-bogus "writing" "" } */
}