From 1bc5aee63eb72b341f506ad058502cd0361f0d10 Mon Sep 17 00:00:00 2001 From: Ben Cheng Date: Tue, 25 Mar 2014 22:37:19 -0700 Subject: Initial checkin of GCC 4.9.0 from trunk (r208799). Change-Id: I48a3c08bb98542aa215912a75f03c0890e497dba --- .../gcc/testsuite/gcc.c-torture/execute/va-arg-4.c | 33 ++++++++++++++++++++++ 1 file changed, 33 insertions(+) create mode 100644 gcc-4.9/gcc/testsuite/gcc.c-torture/execute/va-arg-4.c (limited to 'gcc-4.9/gcc/testsuite/gcc.c-torture/execute/va-arg-4.c') diff --git a/gcc-4.9/gcc/testsuite/gcc.c-torture/execute/va-arg-4.c b/gcc-4.9/gcc/testsuite/gcc.c-torture/execute/va-arg-4.c new file mode 100644 index 000000000..a824f64ff --- /dev/null +++ b/gcc-4.9/gcc/testsuite/gcc.c-torture/execute/va-arg-4.c @@ -0,0 +1,33 @@ +/* On the i960 any arg bigger than 16 bytes causes all subsequent args + to be passed on the stack. We test this. */ + +#include + +typedef struct { + char a[32]; +} big; + +void +f (big x, char *s, ...) +{ + va_list ap; + + if (x.a[0] != 'a' || x.a[1] != 'b' || x.a[2] != 'c') + abort (); + va_start (ap, s); + if (va_arg (ap, int) != 42) + abort (); + if (va_arg (ap, int) != 'x') + abort (); + if (va_arg (ap, int) != 0) + abort (); + va_end (ap); +} + +main () +{ + static big x = { "abc" }; + + f (x, "", 42, 'x', 0); + exit (0); +} -- cgit v1.2.3