diff options
author | Martin Liska <mliska@suse.cz> | 2014-08-01 10:20:57 +0200 |
---|---|---|
committer | Martin Liska <marxin@gcc.gnu.org> | 2014-08-01 08:20:57 +0000 |
commit | fd29c0247aa4af7492782e6c933c713c6732b4b0 (patch) | |
tree | 34ecf6784681ee0ad5b65f264b03ec52f19e5524 /gcc/gimple-iterator.h | |
parent | 0ef40c649bd668717cb99a0dfc90a7218bdfbc29 (diff) | |
download | gcc-fd29c0247aa4af7492782e6c933c713c6732b4b0.zip gcc-fd29c0247aa4af7492782e6c933c713c6732b4b0.tar.gz gcc-fd29c0247aa4af7492782e6c933c713c6732b4b0.tar.bz2 |
IPA ICF pass 1/N
* gimple-iterator.h (gsi_next_nonvirtual_phi): New function.
* ipa-prop.h (count_formal_params): Global function created from static.
* ipa-prop.c (count_formal_params): Likewise.
* ipa-utils.c (ipa_merge_profiles): Be more tolerant if we merge
profiles for semantically equivalent functions.
* passes.c (do_per_function): If we load body of a function
during WPA, this condition should behave same.
* varpool.c (ctor_for_folding): More tolerant assert for variable
aliases created during WPA.
From-SVN: r213417
Diffstat (limited to 'gcc/gimple-iterator.h')
-rw-r--r-- | gcc/gimple-iterator.h | 24 |
1 files changed, 24 insertions, 0 deletions
diff --git a/gcc/gimple-iterator.h b/gcc/gimple-iterator.h index 909d58b..47168b9 100644 --- a/gcc/gimple-iterator.h +++ b/gcc/gimple-iterator.h @@ -281,6 +281,30 @@ gsi_last_nondebug_bb (basic_block bb) return i; } +/* Iterates I statement iterator to the next non-virtual statement. */ + +static inline void +gsi_next_nonvirtual_phi (gimple_stmt_iterator *i) +{ + gimple phi; + + if (gsi_end_p (*i)) + return; + + phi = gsi_stmt (*i); + gcc_assert (phi != NULL); + + while (virtual_operand_p (gimple_phi_result (phi))) + { + gsi_next (i); + + if (gsi_end_p (*i)) + return; + + phi = gsi_stmt (*i); + } +} + /* Return the basic block associated with this iterator. */ static inline basic_block |