From 48ee6fa02c596bebd833aa2abd17e25d6dc8db25 Mon Sep 17 00:00:00 2001 From: Eric Botcazou Date: Fri, 28 Nov 2003 17:35:52 +0100 Subject: [PATCH] builtin-apply2.c: Set size of stack argument data to 64. * gcc.dg/builtin-apply2.c: Set size of stack argument data to 64. * gcc.dg/builtin-apply3.c: New test. From-SVN: r74022 --- gcc/testsuite/ChangeLog | 5 +++++ gcc/testsuite/gcc.dg/builtin-apply2.c | 11 +--------- gcc/testsuite/gcc.dg/builtin-apply3.c | 31 +++++++++++++++++++++++++++ 3 files changed, 37 insertions(+), 10 deletions(-) create mode 100644 gcc/testsuite/gcc.dg/builtin-apply3.c diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index cd7670f26c2..cbac84803d4 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2003-11-28 Eric Botcazou + + * gcc.dg/builtin-apply2.c: Set size of stack argument data to 64. + * gcc.dg/builtin-apply3.c: New test. + 2003-11-27 Eric Botcazou * lib/compat.exp (compat-obj): New xfaildata parameter. diff --git a/gcc/testsuite/gcc.dg/builtin-apply2.c b/gcc/testsuite/gcc.dg/builtin-apply2.c index 56b27a1dd17..a1ba20fce53 100644 --- a/gcc/testsuite/gcc.dg/builtin-apply2.c +++ b/gcc/testsuite/gcc.dg/builtin-apply2.c @@ -9,8 +9,6 @@ #define INTEGER_ARG 5 -typedef __SIZE_TYPE__ size_t; - extern void abort(void); void foo(char *name, double d, double e, double f, int g) @@ -21,14 +19,7 @@ void foo(char *name, double d, double e, double f, int g) void bar(char *name, ...) { - size_t size; - void *arguments; - - size = sizeof(char *) + 3 * sizeof(double) + sizeof(int); - - arguments = __builtin_apply_args(); - - __builtin_apply(foo, arguments, size); + __builtin_apply(foo, __builtin_apply_args(), 64); } int main(void) diff --git a/gcc/testsuite/gcc.dg/builtin-apply3.c b/gcc/testsuite/gcc.dg/builtin-apply3.c new file mode 100644 index 00000000000..1335d09022a --- /dev/null +++ b/gcc/testsuite/gcc.dg/builtin-apply3.c @@ -0,0 +1,31 @@ +/* PR middle-end/12210 */ +/* Origin: Ossadchy Yury A. */ + +/* This used to fail on i686 because the argument was not copied + to the right location by __builtin_apply after the direct call. */ + +/* { dg-do run } */ + + +#define INTEGER_ARG 5 + +extern void abort(void); + +void foo(int arg) +{ + if (arg != INTEGER_ARG) + abort(); +} + +void bar(int arg) +{ + foo(arg); + __builtin_apply(foo, __builtin_apply_args(), 16); +} + +int main(void) +{ + bar(INTEGER_ARG); + + return 0; +} -- 2.30.2