From: Richard Guenther Date: Tue, 22 May 2012 09:33:01 +0000 (+0000) Subject: tree-flow.h (add_referenced_var_1): Declare. X-Git-Tag: misc/gccgo-go1_1_2~2763 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=3efa0725f4e780eb523e10c0b27a3e69fd7b5081;p=thirdparty%2Fgcc.git tree-flow.h (add_referenced_var_1): Declare. 2012-05-22 Richard Guenther * tree-flow.h (add_referenced_var_1): Declare. (add_referenced_var): Define. * tree-dfa.c (referenced_var_check_and_insert): Avoid one hash lookup. (add_referenced_var): Rename to ... (add_referenced_var_1): ... this. Take struct function argument. From-SVN: r187766 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 496bb5fdc280..fc082836fbc3 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,12 @@ +2012-05-22 Richard Guenther + + * tree-flow.h (add_referenced_var_1): Declare. + (add_referenced_var): Define. + * tree-dfa.c (referenced_var_check_and_insert): Avoid one hash + lookup. + (add_referenced_var): Rename to ... + (add_referenced_var_1): ... this. Take struct function argument. + 2012-05-22 Ramana Radhakrishnan PR target/53334 diff --git a/gcc/tree-dfa.c b/gcc/tree-dfa.c index 46fcfc1ef1df..785ae1b3d4b6 100644 --- a/gcc/tree-dfa.c +++ b/gcc/tree-dfa.c @@ -503,24 +503,23 @@ referenced_var_lookup (struct function *fn, unsigned int uid) Return true if it required insertion. */ static bool -referenced_var_check_and_insert (tree to) +referenced_var_check_and_insert (tree to, struct function *fn) { - tree h, *loc; + tree *loc; struct tree_decl_minimal in; unsigned int uid = DECL_UID (to); in.uid = uid; - h = (tree) htab_find_with_hash (gimple_referenced_vars (cfun), &in, uid); - if (h) + loc = (tree *) htab_find_slot_with_hash (gimple_referenced_vars (fn), + &in, uid, INSERT); + if (*loc) { /* DECL_UID has already been entered in the table. Verify that it is the same entry as TO. See PR 27793. */ - gcc_assert (h == to); + gcc_assert (*loc == to); return false; } - loc = (tree *) htab_find_slot_with_hash (gimple_referenced_vars (cfun), - &in, uid, INSERT); *loc = to; return true; } @@ -575,7 +574,7 @@ set_default_def (tree var, tree def) /* Add VAR to the list of referenced variables if it isn't already there. */ bool -add_referenced_var (tree var) +add_referenced_var_1 (tree var, struct function *fn) { gcc_checking_assert (TREE_CODE (var) == VAR_DECL || TREE_CODE (var) == PARM_DECL @@ -585,7 +584,7 @@ add_referenced_var (tree var) create_var_ann (var); /* Insert VAR into the referenced_vars hash table if it isn't present. */ - if (referenced_var_check_and_insert (var)) + if (referenced_var_check_and_insert (var, fn)) return true; return false; diff --git a/gcc/tree-flow.h b/gcc/tree-flow.h index faa06ae130db..78bd9f863536 100644 --- a/gcc/tree-flow.h +++ b/gcc/tree-flow.h @@ -491,7 +491,8 @@ extern void debug_referenced_vars (void); extern void dump_referenced_vars (FILE *); extern void dump_variable (FILE *, tree); extern void debug_variable (tree); -extern bool add_referenced_var (tree); +extern bool add_referenced_var_1 (tree, struct function *); +#define add_referenced_var(v) add_referenced_var_1 ((v), cfun) extern void remove_referenced_var (tree); extern tree make_rename_temp (tree, const char *); extern void set_default_def (tree, tree);