diff options
| author | amylaar <amylaar@138bc75d-0d04-0410-961f-82ee72b054a4> | 1999-06-16 13:32:14 +0000 |
|---|---|---|
| committer | amylaar <amylaar@138bc75d-0d04-0410-961f-82ee72b054a4> | 1999-06-16 13:32:14 +0000 |
| commit | 27fbe4ece9664f6c53e3b5570a1419d899ba2128 (patch) | |
| tree | d2645ebb431a9227e5c9155d83dae59270a5bd36 | |
| parent | 612358060eebc439f602c1e75e8ae3ac2fc3ebeb (diff) | |
| download | ppe42-gcc-27fbe4ece9664f6c53e3b5570a1419d899ba2128.tar.gz ppe42-gcc-27fbe4ece9664f6c53e3b5570a1419d899ba2128.zip | |
* cse.c (cse_insn): Don't put hard register source into tables for
last insn of a libcall.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@27550 138bc75d-0d04-0410-961f-82ee72b054a4
| -rw-r--r-- | gcc/ChangeLog | 5 | ||||
| -rw-r--r-- | gcc/cse.c | 7 |
2 files changed, 11 insertions, 1 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 6f050bcedcd..7a97024a2f4 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,8 @@ +Wed Jun 16 20:29:00 1999 J"orn Rennecke <amylaar@cygnus.co.uk> + + * cse.c (cse_insn): Don't put hard register source into tables for + last insn of a libcall. + Wed Jun 16 19:44:33 1999 J"orn Rennecke <amylaar@cygnus.co.uk> * loop.c (strength_reduce): Insert sets of derived givs at every diff --git a/gcc/cse.c b/gcc/cse.c index 5fc6c7889a2..605d1850753 100644 --- a/gcc/cse.c +++ b/gcc/cse.c @@ -7607,7 +7607,12 @@ cse_insn (insn, libcall_insn) enum machine_mode mode = GET_MODE (src) == VOIDmode ? GET_MODE (dest) : GET_MODE (src); - if (sets[i].src_elt == 0) + /* Don't put a hard register source into the table if this is + the last insn of a libcall. */ + if (sets[i].src_elt == 0 + && (GET_CODE (src) != REG + || REGNO (src) >= FIRST_PSEUDO_REGISTER + || ! find_reg_note (insn, REG_RETVAL, NULL_RTX))) { register struct table_elt *elt; |

