summaryrefslogtreecommitdiff
path: root/gcc/config/m68k
diff options
context:
space:
mode:
Diffstat (limited to 'gcc/config/m68k')
-rw-r--r--gcc/config/m68k/m68k-protos.h10
-rw-r--r--gcc/config/m68k/m68k.c12
-rw-r--r--gcc/config/m68k/m68k.h3
-rw-r--r--gcc/config/m68k/m68k.md114
4 files changed, 54 insertions, 85 deletions
diff --git a/gcc/config/m68k/m68k-protos.h b/gcc/config/m68k/m68k-protos.h
index 73810d72f82..8538b8e0d28 100644
--- a/gcc/config/m68k/m68k-protos.h
+++ b/gcc/config/m68k/m68k-protos.h
@@ -41,24 +41,14 @@ extern const char *output_iorsi3 (rtx *);
extern const char *output_xorsi3 (rtx *);
extern void m68k_output_pic_call (rtx dest);
extern void output_dbcc_and_branch (rtx *);
-extern int const_uint32_operand (rtx, enum machine_mode);
-extern int const_sint32_operand (rtx, enum machine_mode);
extern int floating_exact_log2 (rtx);
-extern int not_sp_operand (rtx, enum machine_mode);
-extern int valid_dbcc_comparison_p (rtx, enum machine_mode);
-extern int extend_operator (rtx, enum machine_mode);
extern bool strict_low_part_peephole_ok (enum machine_mode mode, rtx first_insn, rtx target);
/* Functions from m68k.c used in macros. */
-extern bool symbolic_operand (rtx, enum machine_mode);
extern int standard_68881_constant_p (rtx);
extern void print_operand_address (FILE *, rtx);
extern void print_operand (FILE *, rtx, int);
extern void notice_update_cc (rtx, rtx);
-extern int general_src_operand (rtx, enum machine_mode);
-extern int nonimmediate_src_operand (rtx, enum machine_mode);
-extern int memory_src_operand (rtx, enum machine_mode);
-extern int pcrel_address (rtx, enum machine_mode);
extern rtx legitimize_pic_address (rtx, enum machine_mode, rtx);
#endif /* RTX_CODE */
diff --git a/gcc/config/m68k/m68k.c b/gcc/config/m68k/m68k.c
index 174c3a6a335..4f2b71e06f9 100644
--- a/gcc/config/m68k/m68k.c
+++ b/gcc/config/m68k/m68k.c
@@ -1118,7 +1118,7 @@ output_scc_di(rtx op, rtx operand1, rtx operand2, rtx dest)
else
loperands[3] = adjust_address (operand2, SImode, 4);
}
- loperands[4] = gen_label_rtx();
+ loperands[4] = gen_label_rtx ();
if (operand2 != const0_rtx)
{
output_asm_insn (MOTOROLA ?
@@ -1160,7 +1160,7 @@ output_scc_di(rtx op, rtx operand1, rtx operand2, rtx dest)
break;
case GT:
- loperands[6] = gen_label_rtx();
+ loperands[6] = gen_label_rtx ();
output_asm_insn (MOTOROLA ?
"shi %5\n\tjbra %l6" :
"shi %5\n\tjra %l6",
@@ -1179,7 +1179,7 @@ output_scc_di(rtx op, rtx operand1, rtx operand2, rtx dest)
break;
case LT:
- loperands[6] = gen_label_rtx();
+ loperands[6] = gen_label_rtx ();
output_asm_insn (MOTOROLA ?
"scs %5\n\tjbra %l6" :
"scs %5\n\tjra %l6",
@@ -1198,7 +1198,7 @@ output_scc_di(rtx op, rtx operand1, rtx operand2, rtx dest)
break;
case GE:
- loperands[6] = gen_label_rtx();
+ loperands[6] = gen_label_rtx ();
output_asm_insn (MOTOROLA ?
"scc %5\n\tjbra %l6" :
"scc %5\n\tjra %l6",
@@ -1217,7 +1217,7 @@ output_scc_di(rtx op, rtx operand1, rtx operand2, rtx dest)
break;
case LE:
- loperands[6] = gen_label_rtx();
+ loperands[6] = gen_label_rtx ();
output_asm_insn (MOTOROLA ?
"sls %5\n\tjbra %l6" :
"sls %5\n\tjra %l6",
@@ -1283,7 +1283,7 @@ output_btst (rtx *operands, rtx countop, rtx dataop, rtx insn, int signpos)
/* Returns true if OP is either a symbol reference or a sum of a symbol
reference and a constant. */
-bool
+int
symbolic_operand (rtx op, enum machine_mode mode ATTRIBUTE_UNUSED)
{
switch (GET_CODE (op))
diff --git a/gcc/config/m68k/m68k.h b/gcc/config/m68k/m68k.h
index bcfa68ebd8e..62f839af566 100644
--- a/gcc/config/m68k/m68k.h
+++ b/gcc/config/m68k/m68k.h
@@ -1270,4 +1270,5 @@ extern int m68k_last_compare_had_fp_operands;
{"const_sint32_operand", {CONST_INT}}, \
{"valid_dbcc_comparison_p", {EQ, NE, GTU, LTU, GEU, LEU, \
GT, LT, GE, LE}}, \
- {"extend_operator", {SIGN_EXTEND, ZERO_EXTEND}},
+ {"extend_operator", {SIGN_EXTEND, ZERO_EXTEND}}, \
+ {"symbolic_operand", {SYMBOL_REF, LABEL_REF, CONST}},
diff --git a/gcc/config/m68k/m68k.md b/gcc/config/m68k/m68k.md
index fa3a39524c1..cc69553683c 100644
--- a/gcc/config/m68k/m68k.md
+++ b/gcc/config/m68k/m68k.md
@@ -122,6 +122,12 @@
(define_constants
[(UNSPECV_BLOCKAGE 0)
])
+
+;; Registers by name.
+(define_constants
+ [(A0_REG 8)
+ (SP_REG 15)
+ ])
(define_insn ""
[(set (match_operand:DF 0 "push_operand" "=m")
@@ -233,10 +239,9 @@
[(set (cc0)
(match_operand:SF 0 "general_operand" ""))]
"TARGET_68881"
- "
{
m68k_last_compare_had_fp_operands = 1;
-}")
+})
(define_insn ""
[(set (cc0)
@@ -253,10 +258,9 @@
[(set (cc0)
(match_operand:DF 0 "general_operand" ""))]
"TARGET_68881"
- "
{
m68k_last_compare_had_fp_operands = 1;
-}")
+})
(define_insn ""
[(set (cc0)
@@ -303,7 +307,6 @@
(compare (match_operand:SI 0 "nonimmediate_operand" "")
(match_operand:SI 1 "general_operand" "")))]
""
- "
{
m68k_last_compare_had_fp_operands = 0;
if (flag_pic && !TARGET_PCREL && symbolic_operand (operands[1], SImode))
@@ -315,7 +318,7 @@
rtx temp = reload_in_progress ? operands[0] : gen_reg_rtx (Pmode);
operands[1] = legitimize_pic_address (operands[1], SImode, temp);
}
-}")
+})
;; A composite of the cmp, cmpa, cmpi & cmpm m68000 op codes.
(define_insn ""
@@ -408,10 +411,9 @@
(compare (match_operand:DF 0 "general_operand" "")
(match_operand:DF 1 "general_operand" "")))]
"TARGET_68881"
- "
{
m68k_last_compare_had_fp_operands = 1;
-}")
+})
(define_insn ""
[(set (cc0)
@@ -436,10 +438,9 @@
(compare (match_operand:SF 0 "general_operand" "")
(match_operand:SF 1 "general_operand" "")))]
"TARGET_68881"
- "
{
m68k_last_compare_had_fp_operands = 1;
-}")
+})
(define_insn ""
[(set (cc0)
@@ -639,7 +640,6 @@
[(set (match_operand:SI 0 "nonimmediate_operand" "")
(match_operand:SI 1 "general_operand" ""))]
""
- "
{
if (flag_pic && !TARGET_PCREL && symbolic_operand (operands[1], SImode))
{
@@ -661,7 +661,7 @@
operands[0] = gen_rtx_MEM (SImode,
force_reg (SImode, XEXP (operands[0], 0)));
}
-}")
+})
;; General case of fullword move. The register constraints
;; force integer constants in range for a moveq to be reloaded
@@ -774,8 +774,8 @@
"* return output_move_strictqi (operands);")
(define_expand "pushqi1"
- [(set (reg:SI 15) (plus:SI (reg:SI 15) (const_int -2)))
- (set (mem:QI (plus:SI (reg:SI 15) (const_int 1)))
+ [(set (reg:SI SP_REG) (plus:SI (reg:SI SP_REG) (const_int -2)))
+ (set (mem:QI (plus:SI (reg:SI SP_REG) (const_int 1)))
(match_operand:QI 0 "general_operand" ""))]
"!TARGET_COLDFIRE"
"")
@@ -899,7 +899,6 @@
[(set (match_operand:XF 0 "nonimmediate_operand" "")
(match_operand:XF 1 "general_operand" ""))]
""
- "
{
/* We can't rewrite operands during reload. */
if (! reload_in_progress)
@@ -920,7 +919,7 @@
force_reg (SImode, XEXP (operands[0], 0)));
}
}
-}")
+})
(define_insn ""
[(set (match_operand:XF 0 "nonimmediate_operand" "=f,m,f,!r,!f,!r")
@@ -1485,7 +1484,7 @@
"")
(define_insn "*cfv4_extendqisi2"
- [(set (match_operand:SI 0 "general_operand" "=d")
+ [(set (match_operand:SI 0 "nonimmediate_operand" "=d")
(sign_extend:SI (match_operand:QI 1 "nonimmediate_operand" "rms")))]
"TARGET_CFV4"
"mvs%.b %1,%0")
@@ -2645,7 +2644,6 @@
(const_int 32))))
(clobber (match_dup 3))])]
"TARGET_68020 && !TARGET_68060 && !TARGET_COLDFIRE"
- "
{
operands[3] = gen_reg_rtx (SImode);
@@ -2659,7 +2657,7 @@
operands[1], operands[2]));
DONE;
}
-}")
+})
(define_insn ""
[(set (match_operand:SI 0 "register_operand" "=d")
@@ -2693,7 +2691,6 @@
(const_int 32))))
(clobber (match_dup 3))])]
"TARGET_68020 && !TARGET_68060 && !TARGET_COLDFIRE"
- "
{
operands[3] = gen_reg_rtx (SImode);
if (GET_CODE (operands[2]) == CONST_INT)
@@ -2703,7 +2700,7 @@
operands[1], operands[2]));
DONE;
}
-}")
+})
(define_insn ""
[(set (match_operand:SI 0 "register_operand" "=d")
@@ -3153,9 +3150,9 @@
&& GET_CODE (operands[2]) == CONST_INT)
{
if (INTVAL (operands[2]) == 0x000000ff)
- return \"mvz%.b %0,%0\";
+ return "mvz%.b %0,%0";
else if (INTVAL (operands[2]) == 0x0000ffff)
- return \"mvz%.w %0,%0\";
+ return "mvz%.w %0,%0";
}
return output_andsi3 (operands);
})
@@ -3553,14 +3550,13 @@
[(set (match_operand:DI 0 "nonimmediate_operand" "")
(neg:DI (match_operand:DI 1 "general_operand" "")))]
""
- "
{
if (TARGET_COLDFIRE)
emit_insn (gen_negdi2_5200 (operands[0], operands[1]));
else
emit_insn (gen_negdi2_internal (operands[0], operands[1]));
DONE;
-}")
+})
(define_insn "negdi2_internal"
[(set (match_operand:DI 0 "nonimmediate_operand" "=<,do,!*a")
@@ -3592,14 +3588,13 @@
[(set (match_operand:SI 0 "nonimmediate_operand" "")
(neg:SI (match_operand:SI 1 "general_operand" "")))]
""
- "
{
if (TARGET_COLDFIRE)
emit_insn (gen_negsi2_5200 (operands[0], operands[1]));
else
emit_insn (gen_negsi2_internal (operands[0], operands[1]));
DONE;
-}")
+})
(define_insn "negsi2_internal"
[(set (match_operand:SI 0 "nonimmediate_operand" "=dm")
@@ -3643,7 +3638,6 @@
[(set (match_operand:SF 0 "nonimmediate_operand" "")
(neg:SF (match_operand:SF 1 "general_operand" "")))]
""
- "
{
if (!TARGET_68881)
{
@@ -3664,7 +3658,7 @@
emit_move_insn (operands[0], operands[0]);
DONE;
}
-}")
+})
(define_insn ""
[(set (match_operand:SF 0 "nonimmediate_operand" "=f,d")
@@ -3685,7 +3679,6 @@
[(set (match_operand:DF 0 "nonimmediate_operand" "")
(neg:DF (match_operand:DF 1 "general_operand" "")))]
""
- "
{
if (!TARGET_68881)
{
@@ -3713,7 +3706,7 @@
emit_no_conflict_block (insns, operands[0], operands[1], 0, 0);
DONE;
}
-}")
+})
(define_insn ""
[(set (match_operand:DF 0 "nonimmediate_operand" "=f,d")
@@ -3761,7 +3754,6 @@
[(set (match_operand:SF 0 "nonimmediate_operand" "")
(abs:SF (match_operand:SF 1 "general_operand" "")))]
""
- "
{
if (!TARGET_68881)
{
@@ -3782,7 +3774,7 @@
emit_move_insn (operands[0], operands[0]);
DONE;
}
-}")
+})
(define_insn ""
[(set (match_operand:SF 0 "nonimmediate_operand" "=f")
@@ -3798,7 +3790,6 @@
[(set (match_operand:DF 0 "nonimmediate_operand" "")
(abs:DF (match_operand:DF 1 "general_operand" "")))]
""
- "
{
if (!TARGET_68881)
{
@@ -3826,7 +3817,7 @@
emit_no_conflict_block (insns, operands[0], operands[1], 0, 0);
DONE;
}
-}")
+})
(define_insn ""
[(set (match_operand:DF 0 "nonimmediate_operand" "=f")
@@ -3861,14 +3852,13 @@
[(set (match_operand:SI 0 "nonimmediate_operand" "")
(not:SI (match_operand:SI 1 "general_operand" "")))]
""
- "
{
if (TARGET_COLDFIRE)
emit_insn (gen_one_cmplsi2_5200 (operands[0], operands[1]));
else
emit_insn (gen_one_cmplsi2_internal (operands[0], operands[1]));
DONE;
-}")
+})
(define_insn "one_cmplsi2_internal"
[(set (match_operand:SI 0 "nonimmediate_operand" "=dm")
@@ -5059,14 +5049,13 @@
[(set (match_operand:QI 0 "register_operand" "")
(eq:QI (cc0) (const_int 0)))]
""
- "
{
if (TARGET_68060 && m68k_last_compare_had_fp_operands)
{
m68k_last_compare_had_fp_operands = 0;
FAIL;
}
-}")
+})
(define_insn ""
[(set (match_operand:QI 0 "register_operand" "=d")
@@ -5081,14 +5070,13 @@
[(set (match_operand:QI 0 "register_operand" "")
(ne:QI (cc0) (const_int 0)))]
""
- "
{
if (TARGET_68060 && m68k_last_compare_had_fp_operands)
{
m68k_last_compare_had_fp_operands = 0;
FAIL;
}
-}")
+})
(define_insn ""
[(set (match_operand:QI 0 "register_operand" "=d")
@@ -5103,14 +5091,13 @@
[(set (match_operand:QI 0 "register_operand" "")
(gt:QI (cc0) (const_int 0)))]
""
- "
{
if (TARGET_68060 && m68k_last_compare_had_fp_operands)
{
m68k_last_compare_had_fp_operands = 0;
FAIL;
}
-}")
+})
(define_insn ""
[(set (match_operand:QI 0 "register_operand" "=d")
@@ -5140,14 +5127,13 @@
[(set (match_operand:QI 0 "register_operand" "")
(lt:QI (cc0) (const_int 0)))]
""
- "
{
if (TARGET_68060 && m68k_last_compare_had_fp_operands)
{
m68k_last_compare_had_fp_operands = 0;
FAIL;
}
-}")
+})
(define_insn ""
[(set (match_operand:QI 0 "register_operand" "=d")
@@ -5177,14 +5163,13 @@
[(set (match_operand:QI 0 "register_operand" "")
(ge:QI (cc0) (const_int 0)))]
""
- "
{
if (TARGET_68060 && m68k_last_compare_had_fp_operands)
{
m68k_last_compare_had_fp_operands = 0;
FAIL;
}
-}")
+})
(define_insn ""
[(set (match_operand:QI 0 "register_operand" "=d")
@@ -5214,14 +5199,13 @@
[(set (match_operand:QI 0 "register_operand" "")
(le:QI (cc0) (const_int 0)))]
""
- "
{
if (TARGET_68060 && m68k_last_compare_had_fp_operands)
{
m68k_last_compare_had_fp_operands = 0;
FAIL;
}
-}")
+})
(define_insn ""
[(set (match_operand:QI 0 "register_operand" "=d")
@@ -6092,13 +6076,12 @@
[(parallel [(set (pc) (match_operand 0 "" ""))
(use (label_ref (match_operand 1 "" "")))])]
""
- "
{
#ifdef CASE_VECTOR_PC_RELATIVE
operands[0] = gen_rtx_PLUS (SImode, pc_rtx,
gen_rtx_SIGN_EXTEND (SImode, operands[0]));
#endif
-}")
+})
;; Jump to variable address from dispatch table of absolute addresses.
(define_insn ""
@@ -6298,11 +6281,10 @@
;; Operand 1 not really used on the m68000.
""
- "
{
if (flag_pic && GET_CODE (XEXP (operands[0], 0)) == SYMBOL_REF)
SYMBOL_REF_FLAG (XEXP (operands[0], 0)) = 1;
-}")
+})
;; This is a normal call sequence.
(define_insn ""
@@ -6340,11 +6322,10 @@
(match_operand:SI 2 "general_operand" "")))]
;; Operand 2 not really used on the m68000.
""
- "
{
if (flag_pic && GET_CODE (XEXP (operands[1], 0)) == SYMBOL_REF)
SYMBOL_REF_FLAG (XEXP (operands[1], 0)) = 1;
-}")
+})
;; This is a normal call_value
(define_insn ""
@@ -6381,7 +6362,6 @@
(match_operand 1 "" "")
(match_operand 2 "" "")])]
"NEEDS_UNTYPED_CALL"
- "
{
int i;
@@ -6400,7 +6380,7 @@
emit_insn (gen_blockage ());
DONE;
-}")
+})
;; UNSPEC_VOLATILE is considered to use and clobber all hard registers and
;; all of memory. This blocks insns from being moved across this point.
@@ -6464,7 +6444,7 @@
;; But it is mainly intended to test the support for these optimizations.
(define_peephole
- [(set (reg:SI 15) (plus:SI (reg:SI 15) (const_int 4)))
+ [(set (reg:SI SP_REG) (plus:SI (reg:SI SP_REG) (const_int 4)))
(set (match_operand:DF 0 "register_operand" "=f")
(match_operand:DF 1 "register_operand" "ad"))]
"FP_REG_P (operands[0]) && ! FP_REG_P (operands[1])"
@@ -6481,8 +6461,8 @@
;; when there are consecutive library calls.
(define_peephole
- [(set (reg:SI 15) (plus:SI (reg:SI 15)
- (match_operand:SI 0 "const_int_operand" "n")))
+ [(set (reg:SI SP_REG) (plus:SI (reg:SI SP_REG)
+ (match_operand:SI 0 "const_int_operand" "n")))
(set (match_operand:SF 1 "push_operand" "=m")
(match_operand:SF 2 "general_operand" "rmfF"))]
"INTVAL (operands[0]) >= 4
@@ -6525,8 +6505,8 @@
;; Speed up stack adjust followed by a fullword fixedpoint push.
(define_peephole
- [(set (reg:SI 15) (plus:SI (reg:SI 15)
- (match_operand:SI 0 "const_int_operand" "n")))
+ [(set (reg:SI SP_REG) (plus:SI (reg:SI SP_REG)
+ (match_operand:SI 0 "const_int_operand" "n")))
(set (match_operand:SI 1 "push_operand" "=m")
(match_operand:SI 2 "general_operand" "g"))]
"INTVAL (operands[0]) >= 4
@@ -6569,9 +6549,9 @@
;; Speed up pushing a single byte but leaving four bytes of space.
(define_peephole
- [(set (mem:QI (pre_dec:SI (reg:SI 15)))
+ [(set (mem:QI (pre_dec:SI (reg:SI SP_REG)))
(match_operand:QI 1 "general_operand" "dami"))
- (set (reg:SI 15) (minus:SI (reg:SI 15) (const_int 2)))]
+ (set (reg:SI SP_REG) (minus:SI (reg:SI SP_REG) (const_int 2)))]
"! reg_mentioned_p (stack_pointer_rtx, operands[1])"
{
rtx xoperands[4];
@@ -7026,7 +7006,6 @@
[(set (match_operand:XF 0 "nonimmediate_operand" "")
(neg:XF (match_operand:XF 1 "nonimmediate_operand" "")))]
""
- "
{
if (!TARGET_68881)
{
@@ -7056,7 +7035,7 @@
emit_no_conflict_block (insns, operands[0], operands[1], 0, 0);
DONE;
}
-}")
+})
(define_insn "negxf2_68881"
[(set (match_operand:XF 0 "nonimmediate_operand" "=f")
@@ -7072,7 +7051,6 @@
[(set (match_operand:XF 0 "nonimmediate_operand" "")
(abs:XF (match_operand:XF 1 "nonimmediate_operand" "")))]
""
- "
{
if (!TARGET_68881)
{
@@ -7102,7 +7080,7 @@
emit_no_conflict_block (insns, operands[0], operands[1], 0, 0);
DONE;
}
-}")
+})
(define_insn "absxf2_68881"
[(set (match_operand:XF 0 "nonimmediate_operand" "=f")