summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJeffrey A Law <law@cygnus.com>1999-07-13 17:03:22 +0000
committerJeff Law <law@gcc.gnu.org>1999-07-13 11:03:22 -0600
commitd440ca8d597141afa64c02748d6172e7fa7483e6 (patch)
tree16d20e5b67bd746f464ace33fd5b1266acd6d169
parentac691bc6ea80abb66c1c4f7191ae95be6642adec (diff)
downloadgcc-d440ca8d597141afa64c02748d6172e7fa7483e6.tar.gz
cse.c (cse_insn): Don't put hard register source into tables for the last insn of a libcall.
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 the last insn of a libcall. Bring over from mainline sources. Fixes various sparc lapack problems. From-SVN: r28088
-rw-r--r--gcc/ChangeLog4
-rw-r--r--gcc/cse.c7
2 files changed, 10 insertions, 1 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 3d6f6f19a0f..1b2618ef827 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,5 +1,9 @@
Tue Jul 13 10:44:14 1999 Jeffrey A Law (law@cygnus.com)
+ 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
+ the last insn of a libcall.
+
* rs6000.c (find_addr_reg): Do not select r0 as an address
register.
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;