From: Dominik Vogt Date: Fri, 19 Feb 2016 10:15:43 +0000 (+0000) Subject: S/390: PR 69625: Add test case X-Git-Tag: basepoints/gcc-7~873 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=ca2bfbc2caf3c7d1b1bb64108730cc2b77401137;p=thirdparty%2Fgcc.git S/390: PR 69625: Add test case gcc/testsuite/ChangeLog PR target/69625 * gcc.target/s390/pr69625.c: Add test case. From-SVN: r233546 --- diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index b11b838ae926..dd2ea7067802 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2016-02-19 Dominik Vogt + + PR target/69625 + * gcc.target/s390/pr69625.c: Add test case. + 2016-02-18 Bernd Edlinger PR testsuite/68580 diff --git a/gcc/testsuite/gcc.target/s390/pr69625.c b/gcc/testsuite/gcc.target/s390/pr69625.c new file mode 100644 index 000000000000..f717183d3965 --- /dev/null +++ b/gcc/testsuite/gcc.target/s390/pr69625.c @@ -0,0 +1,37 @@ +/* Test for PR 69625; make sure that a leaf vararg function does not overwrite + the caller's r6. */ +/* { dg-do run } */ +/* { dg-options "-O2" } */ + +extern void abort (void); + +__attribute__ ((noinline)) +int +foo (int x, ...) +{ + __builtin_va_list vl; + int i; + + __asm__ __volatile__ ("lhi %%r6,1" : : : "r6"); + __builtin_va_start(vl, x); + for (i = 2; i <= 6; i++) + x += __builtin_va_arg(vl, int); + __builtin_va_end (vl); + + return x; +} + +__attribute__ ((noinline)) +void +bar (int r2, int r3, int r4, int r5, int r6) +{ + foo (r2, r3, r4, r5, r6); + if (r6 != 6) + abort (); +} + +int +main (void) +{ + bar (2, 3, 4, 5, 6); +}