diff options
author | hubicka <hubicka@138bc75d-0d04-0410-961f-82ee72b054a4> | 2002-03-06 10:17:23 +0000 |
---|---|---|
committer | hubicka <hubicka@138bc75d-0d04-0410-961f-82ee72b054a4> | 2002-03-06 10:17:23 +0000 |
commit | fb20d6fadb6929a41e0f2645ba8da6d68c9feff4 (patch) | |
tree | 1a7be85532d6be381af338d07dbdca5f8fd08db0 /gcc/rtlanal.c | |
parent | e74146c323db69d660738c3fe6276e25c30c708a (diff) | |
download | gcc-fb20d6fadb6929a41e0f2645ba8da6d68c9feff4.tar.gz |
* cfgrtl.c (delete_insn_and_edges, delete_insn_chain_and_edges): New.
* rtl.h (delete_insn_and_edges, delete_insn_chain_and_edges): Declare
* basic-block.h (update_life_info, update_life_info_in_dirty_blocks,
delete_noop_moves): Return indeger.
* flow.c (ndead): New variable.
(propagate_block_delete_insn): Use delete_insn_and_edges; remove
BB argument; update callers.
(propagate_block_delete_libcall): Use delete_insn_chain_and_edges.
(life_analysis): Do not call purge_all_dead_edges.
(update_life_info): Return number of deleted insns; print statistics.
(update_life_info_in_dirty_blocks): likewise.
(delete_noop_moves): Use delete_insn_and_edges; print statistics;
return number of insns deleted.
* cse.c: Include timevar.h
(delete_trivially_dead_insns): Kill preserve_basic_blocks argument;
iterate until stabilizes; print statistics; return number of killed
insns.
* Makefile.in: (cse.o): Add timevar.h dependency
* rtl.h (delete_trivially_dead_insns): New.
* timever.def: Add TV_DELETE_TRIVIALLY_DEAD timer.
* toplev.c (rest_of_compilation): Update callers.
* cfgcleanup.c (try_optimize_cfg): Kill blocks.
(try_optimize_cfg): Do not update liveness.
(cleanup-cfg): Loop until try_optimize_cfg and dead code
removal stabilizes; use delete_trivially_dead_insns.
* cfgrtl.c (verify_flow_info): Sanity check outgoing edges.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@50355 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/rtlanal.c')
-rw-r--r-- | gcc/rtlanal.c | 35 |
1 files changed, 35 insertions, 0 deletions
diff --git a/gcc/rtlanal.c b/gcc/rtlanal.c index 5f338e86e2f..997bb525a2b 100644 --- a/gcc/rtlanal.c +++ b/gcc/rtlanal.c @@ -3119,3 +3119,38 @@ find_first_parameter_load (call_insn, boundary) } return before; } + +/* Return true if we should avoid inserting code between INSN and preceeding + call instruction. */ + +bool +keep_with_call_p (insn) + rtx insn; +{ + rtx set; + + if (INSN_P (insn) && (set = single_set (insn)) != NULL) + { + if (GET_CODE (SET_DEST (set)) == REG + && fixed_regs[REGNO (SET_DEST (set))] + && general_operand (SET_SRC (set), VOIDmode)) + return true; + if (GET_CODE (SET_SRC (set)) == REG + && FUNCTION_VALUE_REGNO_P (REGNO (SET_SRC (set))) + && GET_CODE (SET_DEST (set)) == REG + && REGNO (SET_DEST (set)) >= FIRST_PSEUDO_REGISTER) + return true; + /* There may be stack pop just after the call and + before actual store of return register. Search + for the actual store when deciding if we can break + or not. */ + if (SET_DEST (set) == stack_pointer_rtx) + { + rtx i2 = next_nonnote_insn (insn); + if (i2 && keep_with_call_p (insn)) + return true; + } + } + return false; +} + |