From: Steve Ellcey Date: Thu, 24 Mar 2011 16:29:18 +0000 (+0000) Subject: re PR target/48209 (FAIL: gcc.c-torture/execute/pr47917.c execution) X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=bf3b3396ef74a4993fdcdb325503f982541885d9;p=gcc.git re PR target/48209 (FAIL: gcc.c-torture/execute/pr47917.c execution) 2011-03-24 Steve Ellcey PR target/48209 * gcc.c-torture/execute/pr47917.c: Move this... * gcc.dg/torture/pr47917.c: to here and add xfails. From-SVN: r171404 --- diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index dab36a8c684..b7cad7f297b 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,9 @@ +2011-03-24 Steve Ellcey + + PR target/48209 + * gcc.c-torture/execute/pr47917.c: Move this... + * gcc.dg/torture/pr47917.c: to here and add xfails. + 2011-03-24 Eric Botcazou * gnat.dg/array16.ad[sb]: New test. diff --git a/gcc/testsuite/gcc.c-torture/execute/pr47917.c b/gcc/testsuite/gcc.c-torture/execute/pr47917.c deleted file mode 100644 index 3d8a9bc6af7..00000000000 --- a/gcc/testsuite/gcc.c-torture/execute/pr47917.c +++ /dev/null @@ -1,32 +0,0 @@ -/* PR middle-end/47917 */ - -extern int snprintf (char *, __SIZE_TYPE__, const char *, ...); -extern int memcmp (const void *, const void *, __SIZE_TYPE__); -extern void abort (void); - -char buf1[6], buf2[6], buf3[4], buf4[4]; -int i; - -int -foo (void) -{ - int ret = snprintf (buf1, sizeof buf1, "abcde"); - ret += snprintf (buf2, sizeof buf2, "abcdef") * 16; - ret += snprintf (buf3, sizeof buf3, "%s", i++ < 6 ? "abc" : "def") * 256; - ret += snprintf (buf4, sizeof buf4, "%s", i++ > 10 ? "abcde" : "defgh") * 4096; - return ret; -} - -int -main (void) -{ - if (foo () != 5 + 6 * 16 + 3 * 256 + 5 * 4096) - abort (); - if (memcmp (buf1, "abcde", 6) != 0 - || memcmp (buf2, "abcde", 6) != 0 - || memcmp (buf3, "abc", 4) != 0 - || memcmp (buf4, "def", 4) != 0 - || i != 2) - abort (); - return 0; -} diff --git a/gcc/testsuite/gcc.dg/torture/pr47917.c b/gcc/testsuite/gcc.dg/torture/pr47917.c new file mode 100644 index 00000000000..4b56c04e80a --- /dev/null +++ b/gcc/testsuite/gcc.dg/torture/pr47917.c @@ -0,0 +1,37 @@ +/* { dg-do run } */ +/* { dg-options "-std=c99" } */ +/* { dg-xfail-if "no C99 snprintf function" { *-*-hpux10* } } */ +/* { dg-xfail-run-if "non-conforming C99 snprintf" { *-*-hpux11.[012]* } } */ + +/* PR middle-end/47917 */ + +extern int snprintf (char *, __SIZE_TYPE__, const char *, ...); +extern int memcmp (const void *, const void *, __SIZE_TYPE__); +extern void abort (void); + +char buf1[6], buf2[6], buf3[4], buf4[4]; +int i; + +int +foo (void) +{ + int ret = snprintf (buf1, sizeof buf1, "abcde"); + ret += snprintf (buf2, sizeof buf2, "abcdef") * 16; + ret += snprintf (buf3, sizeof buf3, "%s", i++ < 6 ? "abc" : "def") * 256; + ret += snprintf (buf4, sizeof buf4, "%s", i++ > 10 ? "abcde" : "defgh") * 4096; + return ret; +} + +int +main (void) +{ + if (foo () != 5 + 6 * 16 + 3 * 256 + 5 * 4096) + abort (); + if (memcmp (buf1, "abcde", 6) != 0 + || memcmp (buf2, "abcde", 6) != 0 + || memcmp (buf3, "abc", 4) != 0 + || memcmp (buf4, "def", 4) != 0 + || i != 2) + abort (); + return 0; +}