diff options
author | Jan Hubicka <jh@suse.cz> | 2006-12-23 01:27:44 +0100 |
---|---|---|
committer | Jan Hubicka <hubicka@gcc.gnu.org> | 2006-12-23 00:27:44 +0000 |
commit | 6ac5a24645e9f7793abc1f850d2a24a369a2e12b (patch) | |
tree | 6a329a1462ce5410f79cc96e19ef32901b223c94 /gcc/tree-dfa.c | |
parent | 007948dfcfa6b47b1c0e507d6050f0e386a97839 (diff) | |
download | gcc-6ac5a24645e9f7793abc1f850d2a24a369a2e12b.zip gcc-6ac5a24645e9f7793abc1f850d2a24a369a2e12b.tar.gz gcc-6ac5a24645e9f7793abc1f850d2a24a369a2e12b.tar.bz2 |
tree-flow-inline.h (var_ann): External variable annotations are unshared too.
* tree-flow-inline.h (var_ann): External variable annotations are
unshared too.
(tree_common_ann): Handle correctly unshared variables annotations.
* tree-dfa.c (create_var_ann): External variable annotations are
unshared too.
From-SVN: r120164
Diffstat (limited to 'gcc/tree-dfa.c')
-rw-r--r-- | gcc/tree-dfa.c | 6 |
1 files changed, 3 insertions, 3 deletions
diff --git a/gcc/tree-dfa.c b/gcc/tree-dfa.c index 9c30eb5..59899f1 100644 --- a/gcc/tree-dfa.c +++ b/gcc/tree-dfa.c @@ -130,7 +130,7 @@ create_var_ann (tree t) gcc_assert (DECL_P (t)); gcc_assert (!t->base.ann || t->base.ann->common.type == VAR_ANN); - if (TREE_STATIC (t)) + if (!MTAG_P (t) && (TREE_STATIC (t) || DECL_EXTERNAL (t))) { sann = GGC_CNEW (struct static_var_ann_d); ann = &sann->ann; @@ -140,7 +140,7 @@ create_var_ann (tree t) ann->common.type = VAR_ANN; - if (TREE_STATIC (t)) + if (!MTAG_P (t) && (TREE_STATIC (t) || DECL_EXTERNAL (t))) { void **slot; sann->uid = DECL_UID (t); @@ -696,7 +696,7 @@ set_default_def (tree var, tree def) htab_remove_elt (DEFAULT_DEFS (cfun), *loc); return; } - gcc_assert (TREE_CODE (def) == SSA_NAME); + gcc_assert (!def || TREE_CODE (def) == SSA_NAME); loc = htab_find_slot_with_hash (DEFAULT_DEFS (cfun), &in, DECL_UID (var), INSERT); |