diff options
author | Jakub Jelinek <jakub@redhat.com> | 2007-12-18 06:05:43 +0100 |
---|---|---|
committer | John David Anglin <danglin@gcc.gnu.org> | 2007-12-18 05:05:43 +0000 |
commit | ac2dbfde07272bdd2021c76e27132c7a47dc5641 (patch) | |
tree | 17f0ccffb3d292eeea11b7045b1b4d418ce736ab /gcc | |
parent | 8b13ce7ee21e5a8fdd3437b956d8a0ddd91ea5f8 (diff) | |
download | gcc-ac2dbfde07272bdd2021c76e27132c7a47dc5641.tar.gz |
re PR bootstrap/34003 (gcc trunk unable to bootstrap itself; Unsatisfied symbols: ggc_free)
PR bootstrap/34003
* c-decl.c (merge_decls): Copy RTL from olddecl to newdecl.
* config/pa/pa.c (pa_encode_section_info): If !first, preserve
SYMBOL_FLAG_REFERENCED flag.
* gcc.dg/pr34003-1.c: New test.
* gcc.dg/pr34003-2.c: New.
From-SVN: r131032
Diffstat (limited to 'gcc')
-rw-r--r-- | gcc/ChangeLog | 7 | ||||
-rw-r--r-- | gcc/c-decl.c | 3 | ||||
-rw-r--r-- | gcc/config/pa/pa.c | 8 | ||||
-rw-r--r-- | gcc/testsuite/ChangeLog | 6 | ||||
-rw-r--r-- | gcc/testsuite/gcc.dg/pr34003-1.c | 8 | ||||
-rw-r--r-- | gcc/testsuite/gcc.dg/pr34003-2.c | 20 |
6 files changed, 52 insertions, 0 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog index bdcb44bc2b1..3ed2a6f9efd 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,10 @@ +2007-12-17 Jakub Jelinek <jakub@redhat.com> + + PR bootstrap/34003 + * c-decl.c (merge_decls): Copy RTL from olddecl to newdecl. + * config/pa/pa.c (pa_encode_section_info): If !first, preserve + SYMBOL_FLAG_REFERENCED flag. + 2007-12-13 Torbjorn Granlund <tege@swox.com> * config/i386/i386.c (ix86_rtx_costs) [MULT]: Check op0 for diff --git a/gcc/c-decl.c b/gcc/c-decl.c index 95ff9e115e4..7cd79206dad 100644 --- a/gcc/c-decl.c +++ b/gcc/c-decl.c @@ -1660,6 +1660,9 @@ merge_decls (tree newdecl, tree olddecl, tree newtype, tree oldtype) } } + /* Keep the old rtl since we can safely use it. */ + if (HAS_RTL_P (olddecl)) + COPY_DECL_RTL (olddecl, newdecl); /* Merge the type qualifiers. */ if (TREE_READONLY (newdecl)) diff --git a/gcc/config/pa/pa.c b/gcc/config/pa/pa.c index 368dcca767a..20fde92e24f 100644 --- a/gcc/config/pa/pa.c +++ b/gcc/config/pa/pa.c @@ -7779,6 +7779,12 @@ hppa_encode_label (rtx sym) static void pa_encode_section_info (tree decl, rtx rtl, int first) { + int old_referenced = 0; + + if (!first && MEM_P (rtl) && GET_CODE (XEXP (rtl, 0)) == SYMBOL_REF) + old_referenced + = SYMBOL_REF_FLAGS (XEXP (rtl, 0)) & SYMBOL_FLAG_REFERENCED; + default_encode_section_info (decl, rtl, first); if (first && TEXT_SPACE_P (decl)) @@ -7787,6 +7793,8 @@ pa_encode_section_info (tree decl, rtx rtl, int first) if (TREE_CODE (decl) == FUNCTION_DECL) hppa_encode_label (XEXP (rtl, 0)); } + else if (old_referenced) + SYMBOL_REF_FLAGS (XEXP (rtl, 0)) |= old_referenced; } /* This is sort of inverse to pa_encode_section_info. */ diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index f8a31aae8a9..01034d03288 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,9 @@ +2007-12-17 Jakub Jelinek <jakub@redhat.com> + + PR bootstrap/34003 + * gcc.dg/pr34003-1.c: New test. + * gcc.dg/pr34003-2.c: New. + 2007-12-10 Simon Martin <simartin@users.sourceforge.net> PR c++/34059 diff --git a/gcc/testsuite/gcc.dg/pr34003-1.c b/gcc/testsuite/gcc.dg/pr34003-1.c new file mode 100644 index 00000000000..ff97fe6d23e --- /dev/null +++ b/gcc/testsuite/gcc.dg/pr34003-1.c @@ -0,0 +1,8 @@ +/* PR bootstrap/34003 */ +/* { dg-do link } */ +/* { dg-options "-O0" } */ +/* { dg-additional-sources "pr34003-2.c" } */ + +extern void foo (void); +int bar (void) { foo (); return 1; } +extern void foo (void); diff --git a/gcc/testsuite/gcc.dg/pr34003-2.c b/gcc/testsuite/gcc.dg/pr34003-2.c new file mode 100644 index 00000000000..a5330567f50 --- /dev/null +++ b/gcc/testsuite/gcc.dg/pr34003-2.c @@ -0,0 +1,20 @@ +/* PR bootstrap/34003 */ +/* { dg-do compile } */ +/* { dg-options "-O0" } */ + +extern void abort (void); + +int seen = 0; + +void foo (void) +{ + ++seen; +} + +int main (void) +{ + extern int bar (void); + if (bar () != 1 || seen != 1) + abort (); + return 0; +} |