From: Joseph Myers Date: Fri, 23 Jul 2004 19:22:13 +0000 (+0100) Subject: c-decl.c (start_function): Form composite type of function types rather than copying... X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=7eb01bd8296eda52b215c3047ce4bc6a2040c875;p=gcc.git c-decl.c (start_function): Form composite type of function types rather than copying type from previous... * c-decl.c (start_function): Form composite type of function types rather than copying type from previous prototype declaration. testsuite: * gcc.dg/comp-return-1.c: New test From-SVN: r85093 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index f5867e40c95..ce98498f3e9 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,8 @@ +2004-07-23 Joseph S. Myers + + * c-decl.c (start_function): Form composite type of function types + rather than copying type from previous prototype declaration. + 2004-07-23 Janis Johnson * config/rs6000/altivec.h (vec_lvewx, vec_lvehx, vec_lvwbx): Remove diff --git a/gcc/c-decl.c b/gcc/c-decl.c index ac812e3dea7..93469d9885f 100644 --- a/gcc/c-decl.c +++ b/gcc/c-decl.c @@ -5712,7 +5712,8 @@ start_function (tree declspecs, tree declarator, tree attributes) TREE_TYPE (TREE_TYPE (old_decl))) && TYPE_ARG_TYPES (TREE_TYPE (decl1)) == 0) { - TREE_TYPE (decl1) = TREE_TYPE (old_decl); + TREE_TYPE (decl1) = composite_type (TREE_TYPE (old_decl), + TREE_TYPE (decl1)); current_function_prototype_locus = DECL_SOURCE_LOCATION (old_decl); } diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 512ac8ec239..ad8aacf17a9 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,7 @@ +2004-07-23 Joseph S. Myers + + * gcc.dg/comp-return-1.c: New test + 2004-07-23 Janis Johnson * gcc.dg/vmx/8-02a.c: Fix typo. diff --git a/gcc/testsuite/gcc.dg/comp-return-1.c b/gcc/testsuite/gcc.dg/comp-return-1.c new file mode 100644 index 00000000000..82c398355d0 --- /dev/null +++ b/gcc/testsuite/gcc.dg/comp-return-1.c @@ -0,0 +1,31 @@ +/* When merging a nonprototype definition of a function with a prior + prototype declaration, the composite type of the return types must + be formed rather than just copying the function type. */ +/* Origin: Joseph Myers */ +/* { dg-do compile } */ + +typedef int a[]; +typedef int a5[5]; +typedef int a10[10]; + +a *f1 (); +a5 *f1 () { return 0; } + +a *f2 (void); +a5 *f2 () { return 0; } + +a *f3 (); +a5 *f3 (void) { return 0; } + +a *f4 (void); +a5 *f4 (void) { return 0; } + +void +g (void) +{ + a10 *x; + x = f1 (); /* { dg-error "incompatible" "f1" } */ + x = f2 (); /* { dg-error "incompatible" "f2" } */ + x = f3 (); /* { dg-error "incompatible" "f3" } */ + x = f4 (); /* { dg-error "incompatible" "f4" } */ +}