diff options
author | Richard Guenther <rguenther@suse.de> | 2011-12-13 14:43:44 +0000 |
---|---|---|
committer | Richard Biener <rguenth@gcc.gnu.org> | 2011-12-13 14:43:44 +0000 |
commit | ea973bad53d63fa66e3a6b0446ae95e7e130f30a (patch) | |
tree | ef1bbe465db7790613b6d18f148baf8d06fab828 /gcc/tree-streamer-in.c | |
parent | 88d599dcf67fd7be5c2a6bdd279bbd7e1ac7f7aa (diff) | |
download | gcc-ea973bad53d63fa66e3a6b0446ae95e7e130f30a.zip gcc-ea973bad53d63fa66e3a6b0446ae95e7e130f30a.tar.gz gcc-ea973bad53d63fa66e3a6b0446ae95e7e130f30a.tar.bz2 |
re PR debug/48354 (internal compiler error: in splice_child_die, at dwarf2out.c:8064)
2011-12-13 Richard Guenther <rguenther@suse.de>
PR lto/48354
* tree.c (find_decls_types_r): Also walk DECL_ORIGINAL_TYPE.
* tree-streamer-in.c (lto_input_ts_decl_non_common_tree_pointers):
Stream DECL_ORIGINAL_TYPE.
* tree-streamer-out.c (write_ts_decl_non_common_tree_pointers):
Likewise.
lto/
* lto.c (lto_ft_decl_non_common): When we merged DECL_ORIGINAL_TYPE
with the type of the TYPE_DECL clear DECL_ORIGINAL_TYPE.
* g++.dg/lto/pr48354-1_0.C: New testcase.
From-SVN: r182286
Diffstat (limited to 'gcc/tree-streamer-in.c')
-rw-r--r-- | gcc/tree-streamer-in.c | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/gcc/tree-streamer-in.c b/gcc/tree-streamer-in.c index 86eb9ce..919a5be 100644 --- a/gcc/tree-streamer-in.c +++ b/gcc/tree-streamer-in.c @@ -602,6 +602,8 @@ lto_input_ts_decl_non_common_tree_pointers (struct lto_input_block *ib, DECL_ARGUMENTS (expr) = stream_read_tree (ib, data_in); DECL_RESULT (expr) = stream_read_tree (ib, data_in); } + else if (TREE_CODE (expr) == TYPE_DECL) + DECL_ORIGINAL_TYPE (expr) = stream_read_tree (ib, data_in); DECL_VINDEX (expr) = stream_read_tree (ib, data_in); } |