diff --git a/gcc/ChangeLog b/gcc/ChangeLog index f2021d2c51ad..58735a14cdb4 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +2008-01-30 Jan Hubicka + + PR target/34982 + * i386.c (init_cumulative_args): Use real function declaration when + calling locally. + 2008-01-30 Richard Sandiford PR rtl-optimization/34998 diff --git a/gcc/config/i386/i386.c b/gcc/config/i386/i386.c index 6e9ae2a2ebd8..4e5cb22d203f 100644 --- a/gcc/config/i386/i386.c +++ b/gcc/config/i386/i386.c @@ -3432,6 +3432,7 @@ init_cumulative_args (CUMULATIVE_ARGS *cum, /* Argument info to initialize */ rtx libname, /* SYMBOL_REF of library name or 0 */ tree fndecl) { + struct cgraph_local_info *i = fndecl ? cgraph_local_info (fndecl) : NULL; memset (cum, 0, sizeof (*cum)); /* Set up the number of registers to use for passing arguments. */ @@ -3442,6 +3443,15 @@ init_cumulative_args (CUMULATIVE_ARGS *cum, /* Argument info to initialize */ cum->mmx_nregs = MMX_REGPARM_MAX; cum->warn_sse = true; cum->warn_mmx = true; + + /* Because type might mismatch in between caller and callee, we need to + use actual type of function for local calls. + FIXME: cgraph_analyze can be told to actually record if function uses + va_start so for local functions maybe_vaarg can be made aggressive + helping K&R code. + FIXME: once typesytem is fixed, we won't need this code anymore. */ + if (i && i->local) + fntype = TREE_TYPE (fndecl); cum->maybe_vaarg = (fntype ? (!prototype_p (fntype) || stdarg_p (fntype)) : !libname); diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 3cee20a403cc..24c89231375c 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2008-01-30 Jan Hubicka + + PR target/34982 + * gcc.c-torture/execute/pr34982.c: New testcase + 2008-01-30 Andreas Krebbel * gcc.target/s390/tf_to_di-1.c: New testcase. diff --git a/gcc/testsuite/gcc.c-torture/execute/pr34982.c b/gcc/testsuite/gcc.c-torture/execute/pr34982.c new file mode 100644 index 000000000000..f7ad67cbc5a0 --- /dev/null +++ b/gcc/testsuite/gcc.c-torture/execute/pr34982.c @@ -0,0 +1,14 @@ +extern void abort (void); + +static void something(); + +int main() +{ + something(-1); +} + +static void something(int i) +{ + if (i != -1) + abort (); +}