diff options
author | Oleg Endo <olegendo@gcc.gnu.org> | 2014-03-01 13:16:37 +0000 |
---|---|---|
committer | Oleg Endo <olegendo@gcc.gnu.org> | 2014-03-01 13:16:37 +0000 |
commit | 19305875c254f3eb3089f2f49737a0138ca7f1a5 (patch) | |
tree | f894ad1c521394b83e649b88b3eb4fca7c8934ec /gcc/config | |
parent | 570215f99d7ea33be820a1c5512ff885d7ca9f36 (diff) | |
download | gcc-19305875c254f3eb3089f2f49737a0138ca7f1a5.zip gcc-19305875c254f3eb3089f2f49737a0138ca7f1a5.tar.gz gcc-19305875c254f3eb3089f2f49737a0138ca7f1a5.tar.bz2 |
re PR target/60071 ([SH] internal compiler error: in final_scan_insn, at final.c:2963)
PR target/60071
* config/sh/sh.md (*mov_t_msb_neg): Split into ...
(*mov_t_msb_neg_negc): ... this new insn.
PR target/60071
* gcc.c-torture/compile/pr60071.c: New.
From-SVN: r208242
Diffstat (limited to 'gcc/config')
-rw-r--r-- | gcc/config/sh/sh.md | 19 |
1 files changed, 17 insertions, 2 deletions
diff --git a/gcc/config/sh/sh.md b/gcc/config/sh/sh.md index 410e968..76af3a2 100644 --- a/gcc/config/sh/sh.md +++ b/gcc/config/sh/sh.md @@ -11434,6 +11434,10 @@ label: ;; T = 1: 0x80000000 -> reg ;; T = 0: 0x7FFFFFFF -> reg ;; This works because 0 - 0x80000000 = 0x80000000. +;; +;; This insn must not match again after it has been split into the constant +;; load and negc. This is accomplished by the special negc insn that +;; has a use on the operand. (define_insn_and_split "*mov_t_msb_neg" [(set (match_operand:SI 0 "arith_reg_dest") (minus:SI (const_int -2147483648) ;; 0x80000000 @@ -11444,12 +11448,23 @@ label: "&& can_create_pseudo_p ()" [(set (match_dup 2) (const_int -2147483648)) (parallel [(set (match_dup 0) (minus:SI (neg:SI (match_dup 2)) - (reg:SI T_REG))) - (clobber (reg:SI T_REG))])] + (reg:SI T_REG))) + (clobber (reg:SI T_REG)) + (use (match_dup 2))])] { operands[2] = gen_reg_rtx (SImode); }) +(define_insn "*mov_t_msb_neg_negc" + [(set (match_operand:SI 0 "arith_reg_dest" "=r") + (minus:SI (neg:SI (match_operand:SI 1 "arith_reg_operand" "r")) + (match_operand:SI 2 "t_reg_operand"))) + (clobber (reg:SI T_REG)) + (use (match_dup 1))] + "TARGET_SH1" + "negc %1,%0" + [(set_attr "type" "arith")]) + ;; These are essentially the same as above, but with the inverted T bit. ;; Combine recognizes the split patterns, but does not take them sometimes ;; if the T_REG clobber is specified. Instead it tries to split out the |