diff options
Diffstat (limited to 'gcc/tree-ssa.c')
| -rw-r--r-- | gcc/tree-ssa.c | 22 |
1 files changed, 20 insertions, 2 deletions
diff --git a/gcc/tree-ssa.c b/gcc/tree-ssa.c index e325953..c6386be 100644 --- a/gcc/tree-ssa.c +++ b/gcc/tree-ssa.c @@ -810,6 +810,24 @@ var_ann_hash (const void *item) return ((const struct static_var_ann_d *)item)->uid; } +/* Return true if the DECL_UID in both trees are equal. */ + +static int +uid_ssaname_map_eq (const void *va, const void *vb) +{ + const_tree a = (const_tree) va; + const_tree b = (const_tree) vb; + return (a->ssa_name.var->decl_minimal.uid == b->ssa_name.var->decl_minimal.uid); +} + +/* Hash a tree in a uid_decl_map. */ + +static unsigned int +uid_ssaname_map_hash (const void *item) +{ + return ((const_tree)item)->ssa_name.var->decl_minimal.uid; +} + /* Initialize global DFA and SSA structures. */ @@ -819,8 +837,8 @@ init_tree_ssa (void) cfun->gimple_df = GGC_CNEW (struct gimple_df); cfun->gimple_df->referenced_vars = htab_create_ggc (20, uid_decl_map_hash, uid_decl_map_eq, NULL); - cfun->gimple_df->default_defs = htab_create_ggc (20, int_tree_map_hash, - int_tree_map_eq, NULL); + cfun->gimple_df->default_defs = htab_create_ggc (20, uid_ssaname_map_hash, + uid_ssaname_map_eq, NULL); cfun->gimple_df->var_anns = htab_create_ggc (20, var_ann_hash, var_ann_eq, NULL); cfun->gimple_df->call_clobbered_vars = BITMAP_GGC_ALLOC (); |
