Commit d84760c9 by Richard Henderson Committed by Richard Henderson

mn10300: Emit clr.

From-SVN: r168722
parent ec815d65
2011-01-12 Richard Henderson <rth@redhat.com>
* config/mn10300/mn10300.md (INT): New mode iterator.
(*mov<INT>_clr): New pattern, and peep2 to generate it.
* config/mn10300/mn10300.c (mn10300_option_override): Force enable
flag_split_wide_types.
......
......@@ -68,8 +68,13 @@
]
(const_int 0))
)
(define_mode_iterator INT [QI HI SI])
;; ----------------------------------------------------------------------
;; Pipeline description.
;; ----------------------------------------------------------------------
;; The AM33 only has a single pipeline. It has five stages (fetch,
;; decode, execute, memory access, writeback) each of which normally
......@@ -1172,6 +1177,30 @@
[(set_attr "timings" "11,11,11,11,11,11,22")]
)
;; If the flags register is not live, generate CLR instead of MOV 0.
;; For MN103, this is only legal for DATA_REGS; for AM33 this is legal
;; but not a win for ADDRESS_REGS.
(define_peephole2
[(set (match_operand:INT 0 "register_operand" "") (const_int 0))]
"peep2_regno_dead_p (0, CC_REG)
&& (REGNO_DATA_P (REGNO (operands[0]), 1)
|| REGNO_EXTENDED_P (REGNO (operands[0]), 1))"
[(parallel [(set (match_dup 0) (const_int 0))
(clobber (reg:CC CC_REG))])]
)
(define_insn "*mov<mode>_clr"
[(set (match_operand:INT 0 "register_operand" "=D")
(const_int 0))
(clobber (reg:CC CC_REG))]
""
"clr %0"
)
;; ----------------------------------------------------------------------
;; ADD INSTRUCTIONS
;; ----------------------------------------------------------------------
(define_insn "*mn10300_addsi3"
[(set (match_operand:SI 0 "register_operand" "=dx,a,a,dax,!*y,!dax")
(plus:SI (match_operand:SI 1 "register_operand" "%0,0,0,0,0,dax")
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment