From: Matthew Fortune Date: Mon, 20 Feb 2017 12:06:56 +0000 (+0000) Subject: Handle WORD_REGISTER_OPERATIONS when reloading (subreg (reg)) X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=222aafd7b63a3d79a80c55efefae7b52953be5b4;p=gcc.git Handle WORD_REGISTER_OPERATIONS when reloading (subreg (reg)) gcc/ PR target/78660 * lra-constraints.c (curr_insn_transform): Handle WORD_REGISTER_OPERATIONS requirements when reloading SUBREGs. From-SVN: r245598 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index f72bb1c0cfe..9dc6b58a0ad 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +2017-02-20 Matthew Fortune + + PR target/78660 + * lra-constraints.c (curr_insn_transform): Handle + WORD_REGISTER_OPERATIONS requirements when reloading SUBREGs. + 2017-02-19 Uros Bizjak Revert: diff --git a/gcc/lra-constraints.c b/gcc/lra-constraints.c index 0098a7585e8..62947e36c97 100644 --- a/gcc/lra-constraints.c +++ b/gcc/lra-constraints.c @@ -4130,7 +4130,15 @@ curr_insn_transform (bool check_only_p) && (goal_alt[i] == NO_REGS || (simplify_subreg_regno (ira_class_hard_regs[goal_alt[i]][0], - GET_MODE (reg), byte, mode) >= 0))))) + GET_MODE (reg), byte, mode) >= 0))) + /* WORD_REGISTER_OPERATIONS targets require the register + to be reloaded when the outer mode is strictly + narrower than the inner mode. Note: It may be + necessary to always reload the inner mode here but it + requires further investigation. */ + || (GET_MODE_PRECISION (mode) + < GET_MODE_PRECISION (GET_MODE (reg)) + && WORD_REGISTER_OPERATIONS))) { if (type == OP_OUT) type = OP_INOUT;