From: Joseph Myers Date: Mon, 11 Jun 2001 13:26:19 +0000 (+0100) Subject: re PR c/3116 (Bug with using oldstyle prototype declarations) X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=1552f8745719c1b62efc50579e200c7e851924c5;p=gcc.git re PR c/3116 (Bug with using oldstyle prototype declarations) * c-decl.c (store_parm_decls): When comparing types in an old-style function declaration with those from a previous prototype, compare the unqualified versions of parameter types. Fixes PR c/3116. testsuite: * gcc.c-torture/compile/20010611-1.c: New test. From-SVN: r43186 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 20948adc228..c39562b2ca4 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,10 @@ +2001-06-11 Joseph S. Myers + + * c-decl.c (store_parm_decls): When comparing types in an + old-style function declaration with those from a previous + prototype, compare the unqualified versions of parameter types. + Fixes PR c/3116. + 2001-06-11 Joseph S. Myers * doc/objc.texi: Use more logical markup. Use TeX dashes. diff --git a/gcc/c-decl.c b/gcc/c-decl.c index b68f7721a58..5d50394d551 100644 --- a/gcc/c-decl.c +++ b/gcc/c-decl.c @@ -6436,9 +6436,11 @@ store_parm_decls () "prototype declaration"); break; } - /* Type for passing arg must be consistent - with that declared for the arg. */ - if (! comptypes (DECL_ARG_TYPE (parm), TREE_VALUE (type))) + /* Type for passing arg must be consistent with that + declared for the arg. ISO C says we take the unqualified + type for parameters declared with qualified type. */ + if (! comptypes (TYPE_MAIN_VARIANT (DECL_ARG_TYPE (parm)), + TYPE_MAIN_VARIANT (TREE_VALUE (type)))) { if (TYPE_MAIN_VARIANT (TREE_TYPE (parm)) == TYPE_MAIN_VARIANT (TREE_VALUE (type))) diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index d1255208049..fd0720c740b 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,7 @@ +2001-06-11 Joseph S. Myers + + * gcc.c-torture/compile/20010611-1.c: New test. + 2001-06-11 Joseph S. Myers * gcc.dg/c99-tag-1.c: Add more tests. diff --git a/gcc/testsuite/gcc.c-torture/compile/20010611-1.c b/gcc/testsuite/gcc.c-torture/compile/20010611-1.c new file mode 100644 index 00000000000..87723bd497a --- /dev/null +++ b/gcc/testsuite/gcc.c-torture/compile/20010611-1.c @@ -0,0 +1,24 @@ +/* Origin: PR c/3116 from Andreas Jaeger . */ +/* When determining type compatibility of function types, we must remove + qualifiers from argument types. We used to fail to do this properly + in store_parm_decls when comparing prototype and non-prototype + declarations. */ +struct _IO_FILE { + int _flags; +}; + +typedef struct _IO_FILE __FILE; +typedef struct _IO_FILE _IO_FILE; +typedef long int wchar_t; + +extern wchar_t *fgetws (wchar_t *__restrict __ws, int __n, + __FILE *__restrict __stream); + +wchar_t * +fgetws (buf, n, fp) + wchar_t *buf; + int n; + _IO_FILE *fp; +{ + return (wchar_t *)0; +}