summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--gcc/ChangeLog14
-rw-r--r--gcc/df-scan.c2
-rw-r--r--gcc/emit-rtl.c5
-rw-r--r--gcc/read-rtl.c2
-rw-r--r--gcc/regs.h4
-rw-r--r--gcc/rtl.h19
6 files changed, 35 insertions, 11 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index c18b7368da0..92e2bd402f5 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,5 +1,19 @@
2015-05-19 Richard Sandiford <richard.sandiford@arm.com>
+ * rtl.h (reg_info): Add an nregs field.
+ (REG_NREGS): Use it.
+ (SET_REGNO_RAW): Delete.
+ (set_regno_raw): New function.
+ * regs.h (END_HARD_REGNO): Make equivalent to END_REGNO.
+ (END_REGNO): Redefine in terms of REG_NREGS.
+ * read-rtl.c (read_rtx_code): Call set_regno_raw instead of
+ SET_REGNO_RAW.
+ * emit-rtl.c (set_mode_and_regno): Likewise.
+ * df-scan.c (df_ref_change_reg_with_loc): Use set_mode_and_regno
+ instead of SET_REGNO_RAW.
+
+2015-05-19 Richard Sandiford <richard.sandiford@arm.com>
+
* rtl.h (PUT_MODE_RAW): New macro.
(PUT_REG_NOTE_KIND): Use it.
(set_mode_and_regno): Declare.
diff --git a/gcc/df-scan.c b/gcc/df-scan.c
index 6175fd9f56b..3aec13cdb6a 100644
--- a/gcc/df-scan.c
+++ b/gcc/df-scan.c
@@ -1930,7 +1930,7 @@ df_ref_change_reg_with_loc (rtx loc, unsigned int new_regno)
DF_REG_EQ_USE_GET (new_regno),
new_regno, loc);
}
- SET_REGNO_RAW (loc, new_regno);
+ set_mode_and_regno (loc, GET_MODE (loc), new_regno);
}
diff --git a/gcc/emit-rtl.c b/gcc/emit-rtl.c
index 03bd76a206b..9766336fdc8 100644
--- a/gcc/emit-rtl.c
+++ b/gcc/emit-rtl.c
@@ -435,8 +435,11 @@ gen_blockage (void)
void
set_mode_and_regno (rtx x, machine_mode mode, unsigned int regno)
{
+ unsigned int nregs = (HARD_REGISTER_NUM_P (regno)
+ ? hard_regno_nregs[regno][mode]
+ : 1);
PUT_MODE_RAW (x, mode);
- SET_REGNO_RAW (x, regno);
+ set_regno_raw (x, regno, nregs);
}
/* Generate a new REG rtx. Make sure ORIGINAL_REGNO is set properly, and
diff --git a/gcc/read-rtl.c b/gcc/read-rtl.c
index a1ff48d0667..749efaff8af 100644
--- a/gcc/read-rtl.c
+++ b/gcc/read-rtl.c
@@ -1349,7 +1349,7 @@ read_rtx_code (const char *code_name)
case 'r':
read_name (&name);
validate_const_int (name.string);
- SET_REGNO_RAW (return_rtx, atoi (name.string));
+ set_regno_raw (return_rtx, atoi (name.string), 1);
REG_ATTRS (return_rtx) = NULL;
break;
diff --git a/gcc/regs.h b/gcc/regs.h
index 1f8f5a788de..a1374d10941 100644
--- a/gcc/regs.h
+++ b/gcc/regs.h
@@ -288,11 +288,11 @@ end_hard_regno (machine_mode mode, unsigned int regno)
/* Likewise for hard register X. */
-#define END_HARD_REGNO(X) end_hard_regno (GET_MODE (X), REGNO (X))
+#define END_HARD_REGNO(X) END_REGNO (X)
/* Likewise for hard or pseudo register X. */
-#define END_REGNO(X) (HARD_REGISTER_P (X) ? END_HARD_REGNO (X) : REGNO (X) + 1)
+#define END_REGNO(X) (REGNO (X) + REG_NREGS (X))
/* Add to REGS all the registers required to store a value of mode MODE
in register REGNO. */
diff --git a/gcc/rtl.h b/gcc/rtl.h
index 955ce7d027d..e7d06c2ecdd 100644
--- a/gcc/rtl.h
+++ b/gcc/rtl.h
@@ -210,7 +210,9 @@ struct GTY(()) reg_info {
/* The value of REGNO. */
unsigned int regno;
- unsigned int unused : 32;
+ /* The value of REG_NREGS. */
+ unsigned int nregs : 8;
+ unsigned int unused : 24;
/* The value of REG_ATTRS. */
reg_attrs *attrs;
@@ -1712,15 +1714,11 @@ inline rtx_insn *JUMP_LABEL_AS_INSN (const rtx_insn *insn)
be used on RHS. Use SET_REGNO to change the value. */
#define REGNO(RTX) (rhs_regno(RTX))
#define SET_REGNO(RTX, N) (df_ref_change_reg_with_loc (RTX, N))
-#define SET_REGNO_RAW(RTX, N) (REG_CHECK (RTX)->regno = N)
/* Return the number of consecutive registers in a REG. This is always
1 for pseudo registers and is determined by HARD_REGNO_NREGS for
hard registers. */
-#define REG_NREGS(RTX) \
- (REGNO (RTX) < FIRST_PSEUDO_REGISTER \
- ? (unsigned int) hard_regno_nregs[REGNO (RTX)][GET_MODE (RTX)] \
- : 1)
+#define REG_NREGS(RTX) (REG_CHECK (RTX)->nregs)
/* ORIGINAL_REGNO holds the number the register originally had; for a
pseudo register turned into a hard reg this will hold the old pseudo
@@ -1735,6 +1733,15 @@ rhs_regno (const_rtx x)
return REG_CHECK (x)->regno;
}
+/* Change the REGNO and REG_NREGS of REG X to the specified values,
+ bypassing the df machinery. */
+static inline void
+set_regno_raw (rtx x, unsigned int regno, unsigned int nregs)
+{
+ reg_info *reg = REG_CHECK (x);
+ reg->regno = regno;
+ reg->nregs = nregs;
+}
/* 1 if RTX is a reg or parallel that is the current function's return
value. */