aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRichard Kenner <kenner@vlsi1.ultra.nyu.edu>2001-11-15 14:58:19 +0000
committerRichard Kenner <kenner@gcc.gnu.org>2001-11-15 09:58:19 -0500
commitfea54805d1cfdd197167865a35b198ac95df0eca (patch)
treebdb6c2f2be6cff5083eb5660c269ed15c1cd3306
parent768caa286d153f6366c98154db2ecb5557af8c4a (diff)
downloadgcc-fea54805d1cfdd197167865a35b198ac95df0eca.zip
gcc-fea54805d1cfdd197167865a35b198ac95df0eca.tar.gz
gcc-fea54805d1cfdd197167865a35b198ac95df0eca.tar.bz2
final.c (alter_subreg): If simplify_subreg can't do anything, handle REG ourselves and abort for others.
* final.c (alter_subreg): If simplify_subreg can't do anything, handle REG ourselves and abort for others. From-SVN: r47058
-rw-r--r--gcc/ChangeLog5
-rw-r--r--gcc/final.c21
2 files changed, 25 insertions, 1 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 0cec809..aac12db 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,8 @@
+Thu Nov 15 08:36:39 2001 Richard Kenner <kenner@vlsi1.ultra.nyu.edu>
+
+ * final.c (alter_subreg): If simplify_subreg can't do anything,
+ handle REG ourselves and abort for others.
+
2001-11-15 Richard Hodson <hodsonr@dionecorp.com>
* config/h8300/h8300.c (dosize): Avoid corrupting R3 in interrupt
diff --git a/gcc/final.c b/gcc/final.c
index 733503e..9302fea 100644
--- a/gcc/final.c
+++ b/gcc/final.c
@@ -3038,7 +3038,26 @@ alter_subreg (xp)
if (GET_CODE (y) == MEM)
*xp = adjust_address (y, GET_MODE (x), SUBREG_BYTE (x));
else
- *xp = simplify_subreg (GET_MODE (x), y, GET_MODE (y), SUBREG_BYTE (x));
+ {
+ rtx new = simplify_subreg (GET_MODE (x), y, GET_MODE (y),
+ SUBREG_BYTE (x));
+
+ if (new != 0)
+ *xp = new;
+ /* Simplify_subreg can't handle some REG cases, but we have to. */
+ else if (GET_CODE (y) == REG)
+ {
+ REGNO (x) = subreg_hard_regno (x, 1);
+ PUT_CODE (x, REG);
+ ORIGINAL_REGNO (x) = ORIGINAL_REGNO (y);
+ /* This field has a different meaning for REGs and SUBREGs. Make
+ sure to clear it! */
+ x->used = 0;
+ }
+ else
+ abort ();
+ }
+
return *xp;
}