summaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
Diffstat (limited to 'gcc')
-rw-r--r--gcc/ChangeLog.subreg48
1 files changed, 48 insertions, 0 deletions
diff --git a/gcc/ChangeLog.subreg b/gcc/ChangeLog.subreg
new file mode 100644
index 00000000000..e7f74ecca07
--- /dev/null
+++ b/gcc/ChangeLog.subreg
@@ -0,0 +1,48 @@
+2013-12-11 H.J. Lu <hongjiu.lu@intel.com>
+
+ * combine.c (subst): Pass subreg byte to REG_CANNOT_CHANGE_MODE_P.
+ (simplify_set): Likewise.
+ * emit-rtl.c (validate_subreg): Likewise.
+ * recog.c (register_operand): Likewise.
+ * rtlanal.c (simplify_subreg_regno): Likewise.
+ * hard-reg-set.h (REG_CANNOT_CHANGE_MODE_P): Add SUBREG_BYTE
+ and pass it to CANNOT_CHANGE_MODE_CLASS.
+ * regcprop.c (mode_change_ok): Pass unknown subreg byte to
+ REG_CANNOT_CHANGE_MODE_P.
+ * reginfo.c (record_subregs_of_mode): Pass unknown subreg byte
+ to CANNOT_CHANGE_MODE_CLASS.
+ * postreload.c (reload_cse_simplify_set): Pass subreg byte to
+ CANNOT_CHANGE_MODE_CLASS.
+ (reload_cse_simplify_operands): Likewise.
+ * reload.c (push_reload): Likewise.
+ * reload1.c (choose_reload_regs): Pass subreg byte to
+ REG_CANNOT_CHANGE_MODE_P.
+ (inherit_piecemeal_p): Pass unknown subreg byte to
+ REG_CANNOT_CHANGE_MODE_P.
+ * config/aarch64/aarch64.h (CANNOT_CHANGE_MODE_CLASS): Add
+ and ignore subreg byte.
+ * config/alpha/alpha.h (CANNOT_CHANGE_MODE_CLASS): Likewise.
+ * config/arm/arm.h (CANNOT_CHANGE_MODE_CLASS): Likewise.
+ * config/ia64/ia64.h (CANNOT_CHANGE_MODE_CLASS): Likewise.
+ * config/m32c/m32c.h (CANNOT_CHANGE_MODE_CLASS): Likewise.
+ * config/mep/mep.h (CANNOT_CHANGE_MODE_CLASS): Likewise.
+ * config/mips/mips.h (CANNOT_CHANGE_MODE_CLASS): Likewise.
+ * config/msp430/msp430.h (CANNOT_CHANGE_MODE_CLASS): Likewise.
+ * config/pa/pa32-regs.h (CANNOT_CHANGE_MODE_CLASS): Likewise.
+ * config/pa/pa64-regs.h (CANNOT_CHANGE_MODE_CLASS): Likewise.
+ * config/pdp11/pdp11.h (CANNOT_CHANGE_MODE_CLASS): Likewise.
+ * config/rs6000/rs6000.h (CANNOT_CHANGE_MODE_CLASS): Likewise.
+ * config/s390/s390.h (CANNOT_CHANGE_MODE_CLASS): Likewise.
+ * config/score/score.h (CANNOT_CHANGE_MODE_CLASS): Likewise.
+ * config/sh/sh.h (CANNOT_CHANGE_MODE_CLASS): Likewise.
+ * config/sparc/sparc.h (CANNOT_CHANGE_MODE_CLASS): Likewise.
+ * config/spu/spu.h (CANNOT_CHANGE_MODE_CLASS): Likewise.
+ * config/i386/i386-protos.h (ix86_cannot_change_mode_class): Add
+ an unsigned int argument.
+ * config/i386/i386.c (ix86_cannot_change_mode_class): Take subreg
+ byte. Return true only if subreg byte is non-zero.
+ * config/i386/i386.h (CANNOT_CHANGE_MODE_CLASS): Add SUBREG_BYTE
+ and pass it to ix86_cannot_change_mode_class.
+ * doc/rtl.texi: Add subreg_byte to CANNOT_CHANGE_MODE_CLASS.
+ * doc/tm.texi.in: Likewise.
+ * doc/tm.texi: Regenerated.