From: Mark Mitchell Date: Sat, 1 Mar 2003 01:22:43 +0000 (+0000) Subject: re PR c++/9892 (g++.old-deja/g++.pt/static9.C regression) X-Git-Tag: releases/gcc-3.4.0~8336 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=1d62c33ebd5cf50c19a015401ee02c6949f0b9df;p=thirdparty%2Fgcc.git re PR c++/9892 (g++.old-deja/g++.pt/static9.C regression) PR c++/9892 * pt.c (instantiate_decl): Clear DECL_RTL for a VAR_DECL when instantiating it. From-SVN: r63601 --- diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index 78d4f262e655..e4ccfb2a2fd7 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,3 +1,9 @@ +2003-02-28 + + PR c++/9892 + * pt.c (instantiate_decl): Clear DECL_RTL for a VAR_DECL when + instantiating it. + 2003-02-28 Aldy Hernandez * parser.c (cp_parser_init_declarator): Revert opaque diff --git a/gcc/cp/pt.c b/gcc/cp/pt.c index c0ec51dc73e9..ac5e4e1c8ef3 100644 --- a/gcc/cp/pt.c +++ b/gcc/cp/pt.c @@ -10825,7 +10825,7 @@ instantiate_decl (d, defer_ok) /* Regenerate the declaration in case the template has been modified by a subsequent redeclaration. */ regenerate_decl_from_template (d, td); - + /* We already set the file and line above. Reset them now in case they changed as a result of calling regenerate_decl_from_template. */ lineno = DECL_SOURCE_LINE (d); @@ -10833,6 +10833,10 @@ instantiate_decl (d, defer_ok) if (TREE_CODE (d) == VAR_DECL) { + /* Clear out DECL_RTL; whatever was there before may not be right + since we've reset the type of the declaration. */ + SET_DECL_RTL (d, NULL_RTX); + DECL_IN_AGGR_P (d) = 0; if (DECL_INTERFACE_KNOWN (d)) DECL_EXTERNAL (d) = ! DECL_NOT_REALLY_EXTERN (d);