summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--gcc/ChangeLog4
-rw-r--r--gcc/config/sh/sh.md1335
2 files changed, 593 insertions, 746 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 258bda905ac..019b0f8e67a 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,7 @@
+2012-03-20 Oleg Endo <olegendo@gcc.gnu.org>
+
+ * config/sh/sh.md: Use braced string notation where applicable.
+
2012-03-19 Uros Bizjak <ubizjak@gmail.com>
* config/i386/i386.md (allocate_stack): Simplify.
diff --git a/gcc/config/sh/sh.md b/gcc/config/sh/sh.md
index 31160b0d1d4..302480eafaf 100644
--- a/gcc/config/sh/sh.md
+++ b/gcc/config/sh/sh.md
@@ -682,11 +682,10 @@
&& CONST_OK_FOR_K08 (INTVAL (operands[3]))"
[(set (reg:SI T_REG) (eq:SI (and:SI (match_dup 0) (match_dup 3))
(const_int 0)))]
- "
{
if (GET_MODE (operands[0]) == QImode)
operands[0] = simplify_gen_subreg (SImode, operands[0], QImode, 0);
-}")
+})
;; Extract single bit, negate and store it in the T bit.
;; Not used for SH4A.
@@ -793,14 +792,16 @@
(pc)))
(clobber (reg:SI T_REG))]
""
- "if (TARGET_SHMEDIA)
- emit_jump_insn (gen_cbranchint4_media (operands[0], operands[1],
- operands[2], operands[3]));
- else if (TARGET_CBRANCHDI4)
- expand_cbranchsi4 (operands, LAST_AND_UNUSED_RTX_CODE, -1);
- else
- sh_emit_compare_and_branch (operands, SImode);
- DONE;")
+{
+ if (TARGET_SHMEDIA)
+ emit_jump_insn (gen_cbranchint4_media (operands[0], operands[1],
+ operands[2], operands[3]));
+ else if (TARGET_CBRANCHDI4)
+ expand_cbranchsi4 (operands, LAST_AND_UNUSED_RTX_CODE, -1);
+ else
+ sh_emit_compare_and_branch (operands, SImode);
+ DONE;
+})
;; -------------------------------------------------------------------------
;; SImode unsigned integer comparisons
@@ -814,11 +815,10 @@
"cmp/hs %1,%0"
"&& operands[1] == CONST0_RTX (SImode)"
[(pc)]
- "
{
emit_insn (gen_sett ());
DONE;
-}"
+}
[(set_attr "type" "mt_group")])
(define_insn "cmpgtusi_t"
@@ -850,7 +850,6 @@
(clobber (match_dup 4))
(clobber (reg:SI T_REG))]
"TARGET_CBRANCHDI4 || TARGET_SH2 || TARGET_SHMEDIA"
- "
{
enum rtx_code comparison;
@@ -879,7 +878,7 @@
= gen_rtx_fmt_ee (comparison, VOIDmode, operands[1], operands[2]);
operands[4] = gen_rtx_SCRATCH (SImode);
}
-}")
+})
(define_insn_and_split "cbranchdi4_i"
[(set (pc)
@@ -894,12 +893,11 @@
"#"
"&& reload_completed"
[(pc)]
- "
{
if (!expand_cbranchdi4 (operands, GET_CODE (operands[0])))
FAIL;
DONE;
-}")
+})
;; -------------------------------------------------------------------------
;; DImode signed integer comparisons
@@ -941,7 +939,6 @@
(pc)))
(set (reg:SI T_REG) (eq:SI (match_dup 4) (match_dup 5)))
(match_dup 6)]
- "
{
operands[2]
= gen_rtx_REG (SImode,
@@ -955,7 +952,7 @@
operands[4] = gen_lowpart (SImode, operands[0]);
operands[5] = gen_lowpart (SImode, operands[1]);
operands[6] = gen_label_rtx ();
-}")
+})
(define_insn "cmpgtdi_t"
[(set (reg:SI T_REG)
@@ -1095,11 +1092,10 @@
"TARGET_SHMEDIA && peep2_reg_dead_p (2, operands[0])"
[(set (match_dup 2)
(if_then_else:DI (match_dup 3) (match_dup 0) (match_dup 2)))]
- "
{
operands[3] = gen_rtx_fmt_ee (reverse_condition (GET_CODE (operands[3])),
VOIDmode, operands[1], CONST0_RTX (DImode));
-}")
+})
(define_peephole2
[(set (match_operand:DI 0 "general_movdst_operand" "")
@@ -1121,7 +1117,6 @@
(match_operand:DI 2 "register_operand" "")
(match_operand:DI 3 "register_operand" "")))]
"TARGET_SHMEDIA"
- "
{
if ((GET_CODE (operands[1]) == EQ || GET_CODE (operands[1]) == NE)
&& GET_MODE (XEXP (operands[1], 0)) == DImode
@@ -1139,7 +1134,7 @@
if (!operands[1])
FAIL;
}
-}")
+})
;; Add SImode variants for cmveq / cmvne to compensate for not promoting
;; SImode to DImode.
@@ -1174,11 +1169,10 @@
"TARGET_SHMEDIA && peep2_reg_dead_p (2, operands[0])"
[(set (match_dup 2)
(if_then_else:SI (match_dup 3) (match_dup 0) (match_dup 2)))]
- "
{
operands[3] = gen_rtx_fmt_ee (reverse_condition (GET_CODE (operands[3])),
VOIDmode, operands[1], CONST0_RTX (SImode));
-}")
+})
(define_peephole2
[(set (match_operand:SI 0 "general_movdst_operand" "")
@@ -1193,10 +1187,9 @@
&& (!REG_P (operands[1]) || GENERAL_REGISTER_P (REGNO (operands[1])))"
[(set (match_dup 2)
(if_then_else:SI (match_dup 4) (match_dup 1) (match_dup 2)))]
- "
{
replace_rtx (operands[4], operands[0], operands[1]);
-}")
+})
(define_peephole2
[(set (match_operand 0 "any_register_operand" "")
@@ -1217,7 +1210,6 @@
== REGNO_REG_CLASS (REGNO (operands[0])))"
[(set (match_dup 0) (match_dup 3))
(set (match_dup 4) (match_dup 5))]
- "
{
rtx set1, set2, insn2;
rtx replacements[4];
@@ -1269,7 +1261,7 @@
FAIL;
}
DONE;
-}")
+})
;; The register allocator is rather clumsy in handling multi-way conditional
;; moves, so allow the combiner to make them, and we split them up after
@@ -1287,7 +1279,6 @@
"#"
"TARGET_SHMEDIA && reload_completed"
[(pc)]
- "
{
emit_insn (gen_movsicc_false (operands[0], operands[1], operands[2],
operands[3]));
@@ -1295,7 +1286,7 @@
emit_insn (gen_movsicc_false (operands[0], operands[5], operands[4],
operands[0]));
DONE;
-}")
+})
(define_insn "*movsicc_t_false"
[(set (match_operand:SI 0 "arith_reg_dest" "=r,r")
@@ -1329,7 +1320,6 @@
(match_operand:SI 2 "arith_reg_or_0_operand" "")
(match_operand:SI 3 "arith_reg_operand" "")))]
"TARGET_SHMEDIA || TARGET_PRETEND_CMOVE"
- "
{
if ((GET_CODE (operands[1]) == EQ || GET_CODE (operands[1]) == NE)
&& GET_MODE (XEXP (operands[1], 0)) == SImode
@@ -1377,7 +1367,7 @@
if (!operands[1])
FAIL;
}
-}")
+})
(define_expand "movqicc"
[(set (match_operand:QI 0 "register_operand" "")
@@ -1385,14 +1375,13 @@
(match_operand:QI 2 "register_operand" "")
(match_operand:QI 3 "register_operand" "")))]
"TARGET_SHMEDIA"
- "
{
operands[0] = simplify_gen_subreg (SImode, operands[0], QImode, 0);
operands[2] = simplify_gen_subreg (SImode, operands[2], QImode, 0);
operands[3] = simplify_gen_subreg (SImode, operands[3], QImode, 0);
emit (gen_movsicc (operands[0], operands[1], operands[2], operands[3]));
DONE;
-}")
+})
;; -------------------------------------------------------------------------
;; Addition instructions
@@ -1403,7 +1392,6 @@
(plus:DI (match_operand:DI 1 "arith_reg_operand" "")
(match_operand:DI 2 "arith_operand" "")))]
""
- "
{
if (TARGET_SH1)
{
@@ -1413,7 +1401,7 @@
emit_insn (gen_adddi3_compact (operands[0], operands[1], operands[2]));
DONE;
}
-}")
+})
(define_insn "*adddi3_media"
[(set (match_operand:DI 0 "arith_reg_dest" "=r,r")
@@ -1462,7 +1450,6 @@
(clobber (reg:SI T_REG))]
"TARGET_SH1 && reload_completed"
[(const_int 0)]
- "
{
rtx high0, high2, low0 = gen_lowpart (SImode, operands[0]);
high0 = gen_rtx_REG (SImode,
@@ -1475,7 +1462,7 @@
emit_insn (gen_addc (low0, low0, gen_lowpart (SImode, operands[2])));
emit_insn (gen_addc1 (high0, high0, high2));
DONE;
-}")
+})
(define_insn "addc"
[(set (match_operand:SI 0 "arith_reg_dest" "=r")
@@ -1503,11 +1490,10 @@
(plus:SI (match_operand:SI 1 "arith_operand" "")
(match_operand:SI 2 "arith_operand" "")))]
""
- "
{
if (TARGET_SHMEDIA)
operands[1] = force_reg (SImode, operands[1]);
-}")
+})
(define_insn "addsi3_media"
[(set (match_operand:SI 0 "arith_reg_dest" "=r,r")
@@ -1550,7 +1536,6 @@
(minus:DI (match_operand:DI 1 "arith_reg_or_0_operand" "")
(match_operand:DI 2 "arith_reg_operand" "")))]
""
- "
{
if (TARGET_SH1)
{
@@ -1558,7 +1543,7 @@
emit_insn (gen_subdi3_compact (operands[0], operands[1], operands[2]));
DONE;
}
-}")
+})
(define_insn "*subdi3_media"
[(set (match_operand:DI 0 "arith_reg_dest" "=r")
@@ -1593,7 +1578,6 @@
(clobber (reg:SI T_REG))]
"TARGET_SH1 && reload_completed"
[(const_int 0)]
- "
{
rtx high0, high2, low0 = gen_lowpart (SImode, operands[0]);
high0 = gen_rtx_REG (SImode,
@@ -1606,7 +1590,7 @@
emit_insn (gen_subc (low0, low0, gen_lowpart (SImode, operands[2])));
emit_insn (gen_subc1 (high0, high0, high2));
DONE;
-}")
+})
(define_insn "subc"
[(set (match_operand:SI 0 "arith_reg_dest" "=r")
@@ -1692,7 +1676,6 @@
(minus:SI (match_operand:SI 1 "arith_operand" "")
(match_operand:SI 2 "arith_reg_operand" "")))]
""
- "
{
if (TARGET_SH1 && CONST_INT_P (operands[1]))
{
@@ -1708,7 +1691,7 @@
if (operands[1] != const0_rtx && GET_CODE (operands[1]) != SUBREG)
operands[1] = force_reg (SImode, operands[1]);
}
-}")
+})
;; -------------------------------------------------------------------------
;; Division instructions
@@ -1793,7 +1776,6 @@
(set (match_operand:SI 0 "register_operand" "")
(truncate:SI (match_dup 8)))]
"TARGET_SHMEDIA_FPU"
- "
{
operands[3] = gen_reg_rtx (DImode);
operands[4] = gen_reg_rtx (DImode);
@@ -1801,7 +1783,7 @@
operands[6] = gen_reg_rtx (DFmode);
operands[7] = gen_reg_rtx (DFmode);
operands[8] = gen_reg_rtx (DImode);
-}")
+})
(define_insn "udivsi3_i4"
[(set (match_operand:SI 0 "register_operand" "=y")
@@ -1868,7 +1850,6 @@
(clobber (reg:SI R4_REG))
(use (match_dup 3))])]
""
- "
{
rtx last;
@@ -1892,12 +1873,12 @@
emit_move_insn (operands[0], operands[2]);
DONE;
}
- function_symbol (operands[3], \"__udivsi3_i4i\", SFUNC_GOT);
+ function_symbol (operands[3], "__udivsi3_i4i", SFUNC_GOT);
last = gen_udivsi3_i4_int (operands[0], operands[3]);
}
else if (TARGET_DIVIDE_CALL_FP)
{
- function_symbol (operands[3], \"__udivsi3_i4\", SFUNC_STATIC);
+ function_symbol (operands[3], "__udivsi3_i4", SFUNC_STATIC);
if (TARGET_FPU_SINGLE)
last = gen_udivsi3_i4_single (operands[0], operands[3]);
else
@@ -1920,7 +1901,7 @@
else if (TARGET_SH5)
{
function_symbol (operands[3],
- TARGET_FPU_ANY ? \"__udivsi3_i4\" : \"__udivsi3\",
+ TARGET_FPU_ANY ? "__udivsi3_i4" : "__udivsi3",
SFUNC_STATIC);
if (TARGET_SHMEDIA)
@@ -1932,14 +1913,14 @@
}
else
{
- function_symbol (operands[3], \"__udivsi3\", SFUNC_STATIC);
+ function_symbol (operands[3], "__udivsi3", SFUNC_STATIC);
last = gen_udivsi3_i1 (operands[0], operands[3]);
}
emit_move_insn (gen_rtx_REG (SImode, 4), operands[1]);
emit_move_insn (gen_rtx_REG (SImode, 5), operands[2]);
emit_insn (last);
DONE;
-}")
+})
(define_insn "divsi3_sh2a"
[(set (match_operand:SI 0 "arith_reg_dest" "=r")
@@ -2042,7 +2023,6 @@
"#"
"&& (high_life_started || reload_completed)"
[(pc)]
- "
{
const char *name = sh_divsi3_libfunc;
enum sh_function_kind kind = SFUNC_GOT;
@@ -2057,7 +2037,7 @@
if (GET_CODE (x) != UNSPEC || XINT (x, 1) != UNSPEC_DIV_INV_M1)
break;
x = XVECEXP (x, 0, 0);
- name = \"__sdivsi3_2\";
+ name = "__sdivsi3_2";
kind = SFUNC_STATIC;
emit_move_insn (gen_rtx_REG (DImode, R20_REG), x);
break;
@@ -2065,7 +2045,7 @@
sym = function_symbol (NULL, name, kind);
emit_insn (gen_divsi3_media_2 (operands[0], sym));
DONE;
-}"
+}
[(set_attr "highpart" "must_split")])
(define_expand "divsi3_i4_media"
@@ -2075,12 +2055,11 @@
(set (match_operand:SI 0 "register_operand" "=r")
(fix:SI (match_dup 5)))]
"TARGET_SHMEDIA_FPU"
- "
{
operands[3] = gen_reg_rtx (DFmode);
operands[4] = gen_reg_rtx (DFmode);
operands[5] = gen_reg_rtx (DFmode);
-}")
+})
(define_insn "divsi3_i4"
[(set (match_operand:SI 0 "register_operand" "=y")
@@ -2137,7 +2116,6 @@
(clobber (reg:SI R3_REG))
(use (match_dup 3))])]
""
- "
{
rtx last;
@@ -2197,13 +2175,13 @@
divisor = force_reg (SImode, divisor);
if (flag_pic && Pmode != DImode)
{
- tab_base = gen_rtx_SYMBOL_REF (Pmode, \"__div_table\");
+ tab_base = gen_rtx_SYMBOL_REF (Pmode, "__div_table");
tab_base = gen_datalabel_ref (tab_base);
tab_base = force_reg (DImode, gen_rtx_SIGN_EXTEND (DImode, tab_base));
}
else
{
- tab_base = gen_rtx_SYMBOL_REF (DImode, \"__div_table\");
+ tab_base = gen_rtx_SYMBOL_REF (DImode, "__div_table");
tab_base = gen_datalabel_ref (tab_base);
tab_base = force_reg (DImode, tab_base);
}
@@ -2254,14 +2232,14 @@
{
if (TARGET_DIVIDE_CALL2)
{
- rtx tab_base = gen_rtx_SYMBOL_REF (Pmode, \"__div_table\");
+ rtx tab_base = gen_rtx_SYMBOL_REF (Pmode, "__div_table");
tab_base = gen_datalabel_ref (tab_base);
emit_move_insn (gen_rtx_REG (Pmode, R20_REG), tab_base);
}
if (TARGET_FPU_ANY && TARGET_SH1)
function_symbol (operands[3], sh_divsi3_libfunc, SFUNC_STATIC);
else if (TARGET_DIVIDE_CALL2)
- function_symbol (operands[3], \"__sdivsi3_2\", SFUNC_STATIC);
+ function_symbol (operands[3], "__sdivsi3_2", SFUNC_STATIC);
else
function_symbol (operands[3], sh_divsi3_libfunc, SFUNC_GOT);
@@ -2282,7 +2260,7 @@
emit_move_insn (gen_rtx_REG (SImode, 5), operands[2]);
emit_insn (last);
DONE;
-}")
+})
;; operands: scratch, tab_base, tab_ix
;; These are unspecs because we could generate an indexed addressing mode
@@ -2323,7 +2301,6 @@
(clobber (match_operand:DI 4 "register_operand" "=r"))
(clobber (match_operand:DI 5 "register_operand" "=r"))]
"TARGET_SHMEDIA"
- "
{
/*
tab_base: r20
@@ -2352,7 +2329,7 @@ norm32: r25
emit_insn (gen_ashrdi3_media (scratch0, scratch0, GEN_INT (24)));
emit_insn (gen_subdisi3_media (inv0, scratch1, scratch0));
DONE;
-}")
+})
;; operands: inv1, tab_base, tab_ix, norm32
(define_insn_and_split "divsi_inv_m1"
@@ -2370,7 +2347,6 @@ norm32: r25
"#"
"&& !can_create_pseudo_p ()"
[(pc)]
- "
{
/* inv0: r19
muls.l r19, r19, r18 // u0.28
@@ -2400,7 +2376,7 @@ norm32: r25
emit_insn (gen_subdi3 (scratch1, scratch0, scratch1));
emit_insn (gen_ashrdisi3_media_opaque (inv1, scratch1, GEN_INT (28)));
DONE;
-}")
+})
;; operands: inv2, norm32, inv1, i92
(define_insn_and_split "divsi_inv_m2"
@@ -2414,7 +2390,6 @@ norm32: r25
"#"
"&& !can_create_pseudo_p ()"
[(pc)]
- "
{
/*
muls.l r18, r25, r0 // s2.60
@@ -2436,7 +2411,7 @@ norm32: r25
emit_insn (gen_mulsidi3_media (scratch0, scratch0_si, inv1));
emit_insn (gen_ashrdisi3_media_opaque (inv2, scratch0, GEN_INT (30)));
DONE;
-}")
+})
(define_insn_and_split "divsi_inv_m3"
[(set (match_operand:SI 0 "register_operand" "=r")
@@ -2458,7 +2433,6 @@ norm32: r25
"#"
"&& !can_create_pseudo_p ()"
[(pc)]
- "
{
/*
r0: result r1: shift r4: dividend r18: inv1 r19: inv2
@@ -2496,7 +2470,7 @@ norm32: r25
emit_insn (gen_ashrdi3_media (scratch0, scratch0, shift));
emit_insn (gen_subdisi3_media (result, scratch0, scratch2));
DONE;
-}")
+})
;; operands: quotient, dividend, inv1, inv2, shift, i2p27, i43
;; inv1: tab_base, tab_ix, norm32
@@ -2531,7 +2505,6 @@ norm32: r25
"#"
"&& !can_create_pseudo_p ()"
[(pc)]
- "
{
rtx result = operands[0];
rtx dividend = operands[1];
@@ -2605,7 +2578,7 @@ norm32: r25
emit_insn (gen_ashrdi3_media (scratch2, scratch2, shift));
emit_insn (gen_subdisi3_media (result, scratch2, scratch3));
DONE;
-}")
+})
(define_insn "divsi_inv20"
[(set (match_operand:DI 0 "register_operand" "=&r")
@@ -2624,7 +2597,6 @@ norm32: r25
(clobber (match_operand:SI 9 "register_operand" "=r"))]
"TARGET_SHMEDIA
&& (TARGET_DIVIDE_INV20U || TARGET_DIVIDE_INV20L)"
- "*
{
/* operands: %0 div_result, %1 norm32, %2 inv1, %3 dividend,
%4 dividend_nsb, %5 result_sign, %6 i43, %12 i2p27,
@@ -2646,18 +2618,18 @@ label:
int likely = TARGET_DIVIDE_INV20L;
- if (! likely) output_asm_insn (\"muls.l\t%2, %1 , %8\", operands);
- output_asm_insn (\"muls.l\t%2, %3, %0\;xor\t%12, %5, %7\", operands);
+ if (! likely) output_asm_insn ("muls.l\t%2, %1 , %8", operands);
+ output_asm_insn ("muls.l\t%2, %3, %0\;xor\t%12, %5, %7", operands);
output_asm_insn (likely
- ? \"bge/l\t%4, %6, %10\;muls.l\t%2, %1 , %8\"
- : \"bge/u\t%4, %6, %10\", operands);
- output_asm_insn (\"shari\t%8, 16, %8\;muls.l\t%8, %2, %8\", operands);
- if (! likely) output_asm_insn (\"sub\t%0, %7, %0\", operands);
- output_asm_insn (\"shari\t%3, 14, %9\;shari\t%8, 30, %8\", operands);
+ ? "bge/l\t%4, %6, %10\;muls.l\t%2, %1 , %8"
+ : "bge/u\t%4, %6, %10", operands);
+ output_asm_insn ("shari\t%8, 16, %8\;muls.l\t%8, %2, %8", operands);
+ if (! likely) output_asm_insn ("sub\t%0, %7, %0", operands);
+ output_asm_insn ("shari\t%3, 14, %9\;shari\t%8, 30, %8", operands);
return (likely
- ? \"muls.l\t%8, %9, %8\;sub\t%0, %8, %0\n%11:\tadd\t%0, %7, %0\"
- : \"muls.l\t%8, %9, %7\n%11:\tsub\t%0, %7, %0\");
-}")
+ ? "muls.l\t%8, %9, %8\;sub\t%0, %8, %0\n%11:\tadd\t%0, %7, %0"
+ : "muls.l\t%8, %9, %7\n%11:\tsub\t%0, %7, %0");
+})
(define_insn_and_split "divsi_inv_fp"
[(set (match_operand:SI 0 "general_movdst_operand" "=rf")
@@ -2705,7 +2677,6 @@ label:
(set (match_dup 8)
(fix:SI (match_dup 11)))
(set (match_dup 0) (match_dup 8))]
- "
{
if (! fp_arith_reg_operand (operands[1], SImode))
{
@@ -2717,7 +2688,7 @@ label:
emit_move_insn (operands[8], operands[2]);
operands[2] = operands[8];
}
-}"
+}
[(set_attr "highpart" "must_split")])
;; -------------------------------------------------------------------------
@@ -2753,7 +2724,6 @@ label:
(set (match_operand:SI 0 "arith_reg_operand" "")
(reg:SI MACL_REG))]
"TARGET_SH1"
- "
{
rtx insn, macl;
@@ -2772,7 +2742,7 @@ label:
emit_libcall_block (insn, operands[0], macl, SET_SRC (single_set (insn)));
DONE;
-}")
+})
(define_expand "umulhisi3"
[(set (reg:SI MACL_REG)
@@ -2783,7 +2753,6 @@ label:
(set (match_operand:SI 0 "arith_reg_operand" "")
(reg:SI MACL_REG))]
"TARGET_SH1"
- "
{
rtx insn, macl;
@@ -2802,7 +2771,7 @@ label:
emit_libcall_block (insn, operands[0], macl, SET_SRC (single_set (insn)));
DONE;
-}")
+})
;; mulsi3 on the SH2 can be done in one instruction, on the SH1 we generate
;; a call to a routine which clobbers known registers.
@@ -2861,13 +2830,12 @@ label:
(set (match_operand:SI 0 "arith_reg_operand" "")
(reg:SI MACL_REG))]
"TARGET_SH1"
- "
{
if (!TARGET_SH2)
{
/* The address must be set outside the libcall,
since it goes into a pseudo. */
- rtx sym = function_symbol (NULL, \"__mulsi3\", SFUNC_STATIC);
+ rtx sym = function_symbol (NULL, "__mulsi3", SFUNC_STATIC);
rtx addr = force_reg (SImode, sym);
rtx insns = gen_mulsi3_call (operands[0], operands[1],
operands[2], addr);
@@ -2884,7 +2852,7 @@ label:
emit_insn (gen_movsi_i ((operands[0]), macl));
}
DONE;
-}")
+})
(define_insn "mulsidi3_i"
[(set (reg:SI MACH_REG)
@@ -2906,15 +2874,13 @@ label:
(mult:DI (sign_extend:DI (match_operand:SI 1 "arith_reg_operand" "r"))
(sign_extend:DI (match_operand:SI 2 "arith_reg_operand" "r"))))]
"TARGET_SH2 || TARGET_SHMEDIA"
- "
{
if (TARGET_SH2)
{
- emit_insn (gen_mulsidi3_compact (operands[0], operands[1],
- operands[2]));
- DONE;
+ emit_insn (gen_mulsidi3_compact (operands[0], operands[1], operands[2]));
+ DONE;
}
-}")
+})
(define_insn "mulsidi3_media"
[(set (match_operand:DI 0 "arith_reg_dest" "=r")
@@ -2944,7 +2910,6 @@ label:
(clobber (reg:SI MACL_REG))]
"TARGET_SH2"
[(const_int 0)]
- "
{
rtx low_dst = gen_lowpart (SImode, operands[0]);
rtx high_dst = gen_highpart (SImode, operands[0]);
@@ -2956,7 +2921,7 @@ label:
/* We need something to tag the possible REG_EQUAL notes on to. */
emit_move_insn (operands[0], operands[0]);
DONE;
-}")
+})
(define_insn "umulsidi3_i"
[(set (reg:SI MACH_REG)
@@ -2978,15 +2943,13 @@ label:
(mult:DI (zero_extend:DI (match_operand:SI 1 "arith_reg_operand" "r"))
(zero_extend:DI (match_operand:SI 2 "arith_reg_operand" "r"))))]
"TARGET_SH2 || TARGET_SHMEDIA"
- "
{
if (TARGET_SH2)
{
- emit_insn (gen_umulsidi3_compact (operands[0], operands[1],
- operands[2]));
- DONE;
+ emit_insn (gen_umulsidi3_compact (operands[0], operands[1], operands[2]));
+ DONE;
}
-}")
+})
(define_insn "umulsidi3_media"
[(set (match_operand:DI 0 "arith_reg_dest" "=r")
@@ -3015,7 +2978,6 @@ label:
(clobber (reg:SI MACL_REG))]
"TARGET_SH2"
[(const_int 0)]
- "
{
rtx low_dst = gen_lowpart (SImode, operands[0]);
rtx high_dst = gen_highpart (SImode, operands[0]);
@@ -3027,7 +2989,7 @@ label:
/* We need something to tag the possible REG_EQUAL notes on to. */
emit_move_insn (operands[0], operands[0]);
DONE;
-}")
+})
(define_insn "smulsi3_highpart_i"
[(set (reg:SI MACH_REG)
@@ -3055,7 +3017,6 @@ label:
(set (match_operand:SI 0 "arith_reg_operand" "")
(reg:SI MACH_REG))]
"TARGET_SH2"
- "
{
rtx insn, mach;
@@ -3074,7 +3035,7 @@ label:
emit_libcall_block (insn, operands[0], mach, SET_SRC (single_set (insn)));
DONE;
-}")
+})
(define_insn "umulsi3_highpart_i"
[(set (reg:SI MACH_REG)
@@ -3102,7 +3063,6 @@ label:
(set (match_operand:SI 0 "arith_reg_operand" "")
(reg:SI MACH_REG))]
"TARGET_SH2"
- "
{
rtx insn, mach;
@@ -3116,7 +3076,7 @@ label:
emit_libcall_block (insn, operands[0], mach, SET_SRC (single_set (insn)));
DONE;
-}")
+})
(define_insn_and_split "muldi3"
[(set (match_operand:DI 0 "arith_reg_dest" "=r")
@@ -3128,7 +3088,6 @@ label:
"#"
"reload_completed"
[(const_int 0)]
- "
{
rtx op3_v2si, op2_v2si;
@@ -3156,7 +3115,7 @@ label:
emit_insn (gen_adddi3 (operands[0], operands[3], operands[0]));
emit_insn (gen_adddi3 (operands[0], operands[4], operands[0]));
DONE;
-}")
+})
;; -------------------------------------------------------------------------
@@ -3299,13 +3258,12 @@ label:
"#"
"&& reload_completed"
[(set (match_dup 0) (match_dup 3))]
- "
{
operands[3]
= gen_rtx_fmt_ee (GET_CODE (operands[3]), DImode,
simplify_gen_subreg (DImode, operands[1], SImode, 0),
simplify_gen_subreg (DImode, operands[2], SImode, 0));
-}")
+})
(define_insn_and_split "*logical_sidisi3"
[(set (match_operand:SI 0 "arith_reg_dest" "=r,r")
@@ -3374,7 +3332,6 @@ label:
"TARGET_SHMEDIA"
[(set (match_dup 5) (match_dup 4))
(set (match_dup 0) (sign_extend:DI (match_dup 5)))]
-"
{
enum machine_mode inmode = GET_MODE (operands[1]);
int offset = 0;
@@ -3388,7 +3345,7 @@ label:
if (! TARGET_LITTLE_ENDIAN)
offset += 8 - GET_MODE_SIZE (inmode);
operands[5] = gen_rtx_SUBREG (inmode, operands[0], offset);
-}")
+})
;; -------------------------------------------------------------------------
;; Shifts and rotates
@@ -3406,14 +3363,13 @@ label:
(rotate:DI (match_operand:DI 1 "arith_reg_operand" "r")
(match_operand:HI 2 "mextr_bit_offset" "i")))]
"TARGET_SHMEDIA"
- "*
{
static char templ[16];
- sprintf (templ, \"mextr%d\\t%%1,%%1,%%0\",
+ sprintf (templ, "mextr%d\\t%%1,%%1,%%0",
8 - (int) (INTVAL (operands[2]) >> 3));
return templ;
-}"
+}
[(set_attr "type" "arith_media")])
(define_expand "rotrdi3"
@@ -3421,20 +3377,22 @@ label:
(rotatert:DI (match_operand:DI 1 "arith_reg_operand" "r")
(match_operand:HI 2 "mextr_bit_offset" "i")))]
"TARGET_SHMEDIA"
- "if (! mextr_bit_offset (operands[2], HImode)) FAIL;")
+{
+ if (! mextr_bit_offset (operands[2], HImode))
+ FAIL;
+})
(define_insn "rotrdi3_mextr"
[(set (match_operand:DI 0 "arith_reg_dest" "=r")
(rotatert:DI (match_operand:DI 1 "arith_reg_operand" "r")
(match_operand:HI 2 "mextr_bit_offset" "i")))]
"TARGET_SHMEDIA"
- "*
{
static char templ[16];
- sprintf (templ, \"mextr%d\\t%%1,%%1,%%0\", (int) INTVAL (operands[2]) >> 3);
+ sprintf (templ, "mextr%d\\t%%1,%%1,%%0", (int) INTVAL (operands[2]) >> 3);
return templ;
-}"
+}
[(set_attr "type" "arith_media")])
(define_split
@@ -3446,13 +3404,12 @@ label:
(clobber (match_operand:DI 3 "register_operand" ""))]
"TARGET_SHMEDIA"
[(match_dup 4) (match_dup 5)]
- "
{
operands[4] = ((TARGET_LITTLE_ENDIAN ? gen_ldhi_q : gen_ldlo_q)
(operands[3], operands[1]));
operands[5] = gen_mextr_rl (operands[0], operands[3], operands[2],
GEN_INT (56), GEN_INT (8));
-}")
+})
(define_insn "rotlsi3_1"
[(set (match_operand:SI 0 "arith_reg_dest" "=r")
@@ -3486,7 +3443,6 @@ label:
(rotate:SI (match_operand:SI 1 "arith_reg_operand" "")
(match_operand:SI 2 "immediate_operand" "")))]
"TARGET_SH1"
- "
{
static const char rot_tab[] = {
000, 000, 000, 000, 000, 000, 010, 001,
@@ -3535,7 +3491,7 @@ label:
emit_insn (gen_rotlsi3_31 (operands[0], operands[0]));
DONE;
-}")
+})
(define_insn "*rotlhi3_8"
[(set (match_operand:HI 0 "arith_reg_dest" "=r")
@@ -3550,11 +3506,10 @@ label:
(rotate:HI (match_operand:HI 1 "arith_reg_operand" "")
(match_operand:HI 2 "immediate_operand" "")))]
"TARGET_SH1"
- "
{
if (!CONST_INT_P (operands[2]) || INTVAL (operands[2]) != 8)
FAIL;
-}")
+})
;;
;; shift left
@@ -3582,7 +3537,9 @@ label:
(parallel
[(set (match_dup 0) (ashift:SI (match_dup 1) (match_dup 3)))
(clobber (match_dup 4))])]
- "operands[4] = gen_rtx_SCRATCH (SImode);"
+{
+ operands[4] = gen_rtx_SCRATCH (SImode);
+}
[(set_attr "length" "*,*,*,4")
(set_attr "type" "dyn_shift,arith,arith,arith")])
@@ -3620,11 +3577,10 @@ label:
(clobber (reg:SI T_REG))]
"TARGET_SH1 && reload_completed"
[(use (reg:SI R0_REG))]
- "
{
gen_shifty_op (ASHIFT, operands);
DONE;
-}")
+})
(define_insn "ashlsi3_media"
[(set (match_operand:SI 0 "arith_reg_dest" "=r,r")
@@ -3643,7 +3599,6 @@ label:
(match_operand:SI 2 "nonmemory_operand" "")))
(clobber (reg:SI T_REG))])]
""
- "
{
if (TARGET_SHMEDIA)
{
@@ -3660,7 +3615,7 @@ label:
}
if (! immediate_operand (operands[2], GET_MODE (operands[2])))
FAIL;
-}")
+})
(define_insn "*ashlhi3_n"
[(set (match_operand:HI 0 "arith_reg_dest" "=r")
@@ -3683,7 +3638,6 @@ label:
(match_operand:SI 2 "nonmemory_operand" "")))
(clobber (reg:SI T_REG))])]
"TARGET_SH1"
- "
{
if (!CONST_INT_P (operands[2]))
FAIL;
@@ -3691,7 +3645,7 @@ label:
operands. Make sure operands[1] is a HImode register here. */
if (!arith_reg_operand (operands[1], HImode))
operands[1] = copy_to_mode_reg (HImode, operands[1]);
-}")
+})
(define_split
[(set (match_operand:HI 0 "arith_reg_dest" "")
@@ -3700,15 +3654,14 @@ label:
(clobber (reg:SI T_REG))]
"TARGET_SH1 && reload_completed"
[(use (reg:SI R0_REG))]
- "
{
gen_shifty_hi_op (ASHIFT, operands);
DONE;
-}")
+})
-;
-; arithmetic shift right
-;
+;;
+;; arithmetic shift right
+;;
(define_insn "ashrsi3_k"
[(set (match_operand:SI 0 "arith_reg_dest" "=r")
@@ -3742,7 +3695,9 @@ label:
"TARGET_SH1"
[(set (match_dup 0) (rotate:SI (match_dup 1) (const_int 16)))
(set (match_dup 0) (sign_extend:SI (match_dup 2)))]
- "operands[2] = gen_lowpart (HImode, operands[0]);")
+{
+ operands[2] = gen_lowpart (HImode, operands[0]);
+})
;; ??? This should be a define expand.
@@ -3762,12 +3717,11 @@ label:
(clobber (reg:SI T_REG))]
"TARGET_SH1"
[(const_int 0)]
- "
{
emit_insn (gen_ashlsi_c (operands[0], operands[1]));
emit_insn (gen_mov_neg_si_t (copy_rtx (operands[0])));
DONE;
-}")
+})
(define_peephole2
[(set (match_operand:SI 0 "arith_reg_dest" "") (const_int 0))
@@ -3777,11 +3731,10 @@ label:
&& peep2_reg_dead_p (2, operands[0])
&& peep2_reg_dead_p (2, operands[1])"
[(const_int 0)]
- "
{
emit_insn (gen_ashlsi_c (operands[1], operands[1]));
DONE;
-}")
+})
(define_insn "ashlsi_c"
[(set (match_operand:SI 0 "arith_reg_dest" "=r")
@@ -3837,7 +3790,6 @@ label:
(match_operand:SI 2 "nonmemory_operand" "")))
(clobber (reg:SI T_REG))])]
""
- "
{
if (TARGET_SHMEDIA)
{
@@ -3848,7 +3800,7 @@ label:
DONE;
else
FAIL;
-}")
+})
;; logical shift right
@@ -3904,11 +3856,10 @@ label:
(clobber (reg:SI T_REG))]
"TARGET_SH1 && reload_completed"
[(use (reg:SI R0_REG))]
- "
{
gen_shifty_op (LSHIFTRT, operands);
DONE;
-}")
+})
(define_insn "lshrsi3_media"
[(set (match_operand:SI 0 "arith_reg_dest" "=r,r")
@@ -3927,7 +3878,6 @@ label:
(match_operand:SI 2 "nonmemory_operand" "")))
(clobber (reg:SI T_REG))])]
""
- "
{
if (TARGET_SHMEDIA)
{
@@ -3947,7 +3897,7 @@ label:
}
if (! immediate_operand (operands[2], GET_MODE (operands[2])))
FAIL;
-}")
+})
;; ??? This should be a define expand.
@@ -3968,7 +3918,6 @@ label:
(ashift:DI (match_operand:DI 1 "arith_reg_operand" "r")
(match_operand:DI 2 "const_int_operand" "n")))]
"TARGET_SH1 && INTVAL (operands[2]) < 32"
- "
{
int low_word = (TARGET_LITTLE_ENDIAN ? 0 : 1);
int high_word = (TARGET_LITTLE_ENDIAN ? 1 : 0);
@@ -3987,7 +3936,7 @@ label:
emit_insn (gen_iorsi3 (high_dst, tmp0, tmp1));
emit_move_insn (operands[0], dst);
DONE;
-}")
+})
(define_insn "ashldi3_media"
[(set (match_operand:DI 0 "arith_reg_dest" "=r,r")
@@ -4014,28 +3963,25 @@ label:
(match_operand:DI 2 "immediate_operand" "")))
(clobber (reg:SI T_REG))])]
""
- "
{
if (TARGET_SHMEDIA)
{
emit_insn (gen_ashldi3_media (operands[0], operands[1], operands[2]));
DONE;
}
- if (CONST_INT_P (operands[2])
- && INTVAL (operands[2]) == 1)
+ if (CONST_INT_P (operands[2]) && INTVAL (operands[2]) == 1)
{
emit_insn (gen_ashldi3_k (operands[0], operands[1]));
DONE;
}
- else if (CONST_INT_P (operands[2])
- && INTVAL (operands[2]) < 32)
+ else if (CONST_INT_P (operands[2]) && INTVAL (operands[2]) < 32)
{
emit_insn (gen_ashldi3_std (operands[0], operands[1], operands[2]));
DONE;
}
else
FAIL;
-}")
+})
;; ??? This should be a define expand.
@@ -4076,17 +4022,15 @@ label:
(match_operand:DI 2 "immediate_operand" "")))
(clobber (reg:SI T_REG))])]
""
- "
{
if (TARGET_SHMEDIA)
{
emit_insn (gen_lshrdi3_media (operands[0], operands[1], operands[2]));
DONE;
}
- if (!CONST_INT_P (operands[2])
- || INTVAL (operands[2]) != 1)
+ if (!CONST_INT_P (operands[2]) || INTVAL (operands[2]) != 1)
FAIL;
-}")
+})
;; ??? This should be a define expand.
@@ -4145,17 +4089,15 @@ label:
(match_operand:DI 2 "immediate_operand" "")))
(clobber (reg:SI T_REG))])]
""
- "
{
if (TARGET_SHMEDIA)
{
emit_insn (gen_ashrdi3_media (operands[0], operands[1], operands[2]));
DONE;
}
- if (!CONST_INT_P (operands[2])
- || INTVAL (operands[2]) != 1)
+ if (!CONST_INT_P (operands[2]) || INTVAL (operands[2]) != 1)
FAIL;
-}")
+})
;; combined left/right shift
@@ -4166,8 +4108,11 @@ label:
(match_operand:SI 3 "const_int_operand" "")))]
"TARGET_SH1 && reload_completed && (unsigned)INTVAL (operands[2]) < 32"
[(use (reg:SI R0_REG))]
- "if (gen_shl_and (operands[0], operands[2], operands[3], operands[1])) FAIL;
- DONE;")
+{
+ if (gen_shl_and (operands[0], operands[2], operands[3], operands[1]))
+ FAIL;
+ DONE;
+})
(define_split
[(set (match_operand:SI 0 "register_operand" "")
@@ -4177,8 +4122,11 @@ label:
(clobber (reg:SI T_REG))]
"TARGET_SH1 && reload_completed && (unsigned)INTVAL (operands[2]) < 32"
[(use (reg:SI R0_REG))]
- "if (gen_shl_and (operands[0], operands[2], operands[3], operands[1])) FAIL;
- DONE;")
+{
+ if (gen_shl_and (operands[0], operands[2], operands[3], operands[1]))
+ FAIL;
+ DONE;
+})
(define_insn ""
[(set (match_operand:SI 0 "register_operand" "=r")
@@ -4187,7 +4135,7 @@ label:
(match_operand:SI 3 "const_int_operand" "n")))
(clobber (reg:SI T_REG))]
"TARGET_SH1 && shl_and_kind (operands[2], operands[3], 0) == 1"
- "#"
+ "#"
[(set (attr "length")
(cond [(eq (symbol_ref "shl_and_length (insn)") (const_int 2))
(const_string "4")
@@ -4213,7 +4161,7 @@ label:
(match_operand:SI 3 "const_int_operand" "n")))
(clobber (reg:SI T_REG))]
"TARGET_SH1 && shl_and_kind (operands[2], operands[3], 0) == 2"
- "#"
+ "#"
[(set (attr "length")
(cond [(eq (symbol_ref "shl_and_length (insn)") (const_int 2))
(const_string "4")
@@ -4266,7 +4214,6 @@ label:
(clobber (reg:SI T_REG))]
"TARGET_SH1"
[(use (reg:SI R0_REG))]
- "
{
rtx and_source = operands[rtx_equal_p (operands[0], operands[1]) ? 3 : 1];
@@ -4283,7 +4230,7 @@ label:
gen_shifty_op (LSHIFTRT, operands);
}
DONE;
-}")
+})
;; signed left/right shift combination.
(define_split
@@ -4296,8 +4243,11 @@ label:
(clobber (reg:SI T_REG))]
"TARGET_SH1"
[(use (reg:SI R0_REG))]
- "if (gen_shl_sext (operands[0], operands[2], operands[3], operands[1])) FAIL;
- DONE;")
+{
+ if (gen_shl_sext (operands[0], operands[2], operands[3], operands[1]))
+ FAIL;
+ DONE;
+})
(define_insn "shl_sext_ext"
[(set (match_operand:SI 0 "register_operand" "=r")
@@ -4422,7 +4372,6 @@ label:
"#"
"TARGET_SH1"
[(const_int 0)]
- "
{
int low_word = (TARGET_LITTLE_ENDIAN ? 0 : 1);
int high_word = (TARGET_LITTLE_ENDIAN ? 1 : 0);
@@ -4437,7 +4386,7 @@ label:
emit_insn (gen_negc (low_dst, low_src));
emit_insn (gen_negc (high_dst, high_src));
DONE;
-}")
+})
(define_insn "negsi2"
[(set (match_operand:SI 0 "arith_reg_dest" "=r")
@@ -4473,13 +4422,12 @@ label:
"#"
"TARGET_SH1"
[(const_int 0)]
- "
{
emit_insn (gen_cmpgesi_t (operands[1], const0_rtx));
emit_insn (gen_negsi_cond (operands[0], operands[1], operands[1],
const1_rtx));
DONE;
-}")
+})
(define_insn_and_split "*negabssi2"
[(set (match_operand:SI 0 "arith_reg_dest" "=r")
@@ -4488,13 +4436,12 @@ label:
"#"
"TARGET_SH1"
[(const_int 0)]
- "
{
emit_insn (gen_cmpgesi_t (operands[1], const0_rtx));
emit_insn (gen_negsi_cond (operands[0], operands[1], operands[1],
const0_rtx));
DONE;
-}")
+})
;; The SH4 202 can do zero-offset branches without pipeline stalls.
;; This can be used as some kind of conditional execution, which is useful
@@ -4515,7 +4462,6 @@ label:
bf\\t0f\;neg\\t%2,%0\\n0:"
"!TARGET_HARD_SH4"
[(const_int 0)]
- "
{
rtx skip_neg_label = gen_label_rtx ();
@@ -4528,7 +4474,7 @@ label:
emit_label_after (skip_neg_label,
emit_insn (gen_negsi2 (operands[0], operands[1])));
DONE;
-}"
+}
[(set_attr "type" "arith") ;; poor approximation
(set_attr "length" "4")])
@@ -4640,11 +4586,10 @@ label:
"TARGET_SHMEDIA && reload_completed"
[(set (match_dup 0) (ashift:DI (subreg:DI (match_dup 1) 0) (const_int 48)))
(set (match_dup 0) (lshiftrt:DI (match_dup 0) (const_int 48)))]
- "
{
if (GET_CODE (operands[1]) == TRUNCATE)
operands[1] = XEXP (operands[1], 0);
-}")
+})
;; ??? when a truncated input to a zero_extend is reloaded, reload will
;; reload the entire truncate expression.
@@ -4655,7 +4600,9 @@ label:
"#"
"TARGET_SHMEDIA && reload_completed"
[(set (match_dup 0) (match_dup 1))]
- "operands[0] = gen_rtx_REG (DImode, true_regnum (operands[0]));")
+{
+ operands[0] = gen_rtx_REG (DImode, true_regnum (operands[0]));
+})
(define_insn "zero_extendqidi2"
[(set (match_operand:DI 0 "register_operand" "=r,r")
@@ -4674,11 +4621,10 @@ label:
[(set (match_operand:SI 0 "arith_reg_operand" "")
(zero_extend:SI (match_operand:HI 1 "general_extend_operand" "")))]
""
- "
{
if (! TARGET_SHMEDIA && ! arith_reg_operand (operands[1], HImode))
operands[1] = copy_to_mode_reg (HImode, operands[1]);
-}")
+})
(define_insn "*zero_extendhisi2_compact"
[(set (match_operand:SI 0 "arith_reg_dest" "=r")
@@ -4706,7 +4652,6 @@ label:
"TARGET_SHMEDIA && reload_completed"
[(set (match_dup 0) (ashift:SI (match_dup 2) (const_int 16)))
(set (match_dup 0) (lshiftrt:SI (match_dup 0) (const_int 16)))]
- "
{
rtx op1 = operands[1];
@@ -4715,17 +4660,16 @@ label:
operands[2]
= simplify_gen_subreg (SImode, op1, GET_MODE (op1),
subreg_lowpart_offset (SImode, GET_MODE (op1)));
-}")
+})
(define_expand "zero_extendqisi2"
[(set (match_operand:SI 0 "arith_reg_operand" "")
(zero_extend:SI (match_operand:QI 1 "general_extend_operand" "")))]
""
- "
{
if (! TARGET_SHMEDIA && ! arith_reg_operand (operands[1], QImode))
operands[1] = copy_to_mode_reg (QImode, operands[1]);
-}")
+})
(define_insn "*zero_extendqisi2_compact"
[(set (match_operand:SI 0 "arith_reg_dest" "=r")
@@ -4795,11 +4739,10 @@ label:
"TARGET_SHMEDIA && reload_completed"
[(set (match_dup 0) (ashift:DI (subreg:DI (match_dup 1) 0) (const_int 48)))
(set (match_dup 0) (ashiftrt:DI (match_dup 0) (const_int 48)))]
- "
{
if (GET_CODE (operands[1]) == TRUNCATE)
operands[1] = XEXP (operands[1], 0);
-}")
+})
(define_insn "extendqidi2"
[(set (match_operand:DI 0 "register_operand" "=r,r")
@@ -4820,11 +4763,10 @@ label:
"TARGET_SHMEDIA && reload_completed"
[(set (match_dup 0) (ashift:DI (subreg:DI (match_dup 1) 0) (const_int 56)))
(set (match_dup 0) (ashiftrt:DI (match_dup 0) (const_int 56)))]
- "
{
if (GET_CODE (operands[1]) == TRUNCATE)
operands[1] = XEXP (operands[1], 0);
-}")
+})
(define_expand "extendhisi2"
[(set (match_operand:SI 0 "arith_reg_dest" "=r,r")
@@ -4860,7 +4802,6 @@ label:
"TARGET_SHMEDIA && reload_completed"
[(set (match_dup 0) (ashift:SI (match_dup 2) (const_int 16)))
(set (match_dup 0) (ashiftrt:SI (match_dup 0) (const_int 16)))]
- "
{
rtx op1 = operands[1];
if (GET_CODE (op1) == TRUNCATE)
@@ -4868,7 +4809,7 @@ label:
operands[2]
= simplify_gen_subreg (SImode, op1, GET_MODE (op1),
subreg_lowpart_offset (SImode, GET_MODE (op1)));
-}")
+})
(define_expand "extendqisi2"
[(set (match_operand:SI 0 "arith_reg_dest" "")
@@ -4941,7 +4882,6 @@ label:
"TARGET_SHMEDIA && reload_completed"
[(set (match_dup 0) (ashift:SI (match_dup 2) (const_int 24)))
(set (match_dup 0) (ashiftrt:SI (match_dup 0) (const_int 24)))]
- "
{
rtx op1 = operands[1];
if (GET_CODE (op1) == TRUNCATE)
@@ -4949,7 +4889,7 @@ label:
operands[2]
= simplify_gen_subreg (SImode, op1, GET_MODE (op1),
subreg_lowpart_offset (SImode, GET_MODE (op1)));
-}")
+})
(define_expand "extendqihi2"
[(set (match_operand:HI 0 "arith_reg_dest" "")
@@ -4964,9 +4904,9 @@ label:
"exts.b %1,%0"
[(set_attr "type" "arith")])
-/* It would seem useful to combine the truncXi patterns into the movXi
- patterns, but unary operators are ignored when matching constraints,
- so we need separate patterns. */
+;; It would seem useful to combine the truncXi patterns into the movXi
+;; patterns, but unary operators are ignored when matching constraints,
+;; so we need separate patterns.
(define_insn "truncdisi2"
[(set (match_operand:SI 0 "general_movdst_operand" "=r,m,m,f,r,f")
(truncate:SI (match_operand:DI 1 "register_operand" "r,r,f,r,f,f")))]
@@ -5085,7 +5025,6 @@ label:
(define_expand "push_fpscr"
[(const_int 0)]
"TARGET_SH2E"
- "
{
rtx insn = emit_insn (gen_fpu_switch (gen_frame_mem (PSImode,
gen_rtx_PRE_DEC (Pmode,
@@ -5093,12 +5032,11 @@ label:
get_fpscr_rtx ()));
add_reg_note (insn, REG_INC, stack_pointer_rtx);
DONE;
-}")
+})
(define_expand "pop_fpscr"
[(const_int 0)]
"TARGET_SH2E"
- "
{
rtx insn = emit_insn (gen_fpu_switch (get_fpscr_rtx (),
gen_frame_mem (PSImode,
@@ -5106,7 +5044,7 @@ label:
stack_pointer_rtx))));
add_reg_note (insn, REG_INC, stack_pointer_rtx);
DONE;
-}")
+})
;; These two patterns can happen as the result of optimization, when
;; comparisons get simplified to a move of zero or 1 into the T reg.
@@ -5270,11 +5208,10 @@ label:
"#"
"&& ! currently_expanding_to_rtl"
[(set (match_dup 0) (match_dup 1))]
- "
{
if (TARGET_SHCOMPACT && crtl->saves_all_registers)
operands[1] = gen_frame_mem (SImode, return_address_pointer_rtx);
-}")
+})
;; The '?'s in the following constraints may not reflect the time taken
;; to perform the move. They are there to discourage the use of floating-
@@ -5344,7 +5281,6 @@ label:
(const_int 0)] UNSPEC_EXTRACT_U16))))]
"TARGET_SHMEDIA && reload_completed
&& MOVI_SHORI_BASE_OPERAND_P (operands[1])"
- "
{
if (GET_CODE (operands[1]) == LABEL_REF
&& GET_CODE (XEXP (operands[1], 0)) == CODE_LABEL)
@@ -5363,7 +5299,7 @@ label:
&& (GET_CODE (XEXP (XVECEXP (unspec, 0, 0), 0)) == CODE_LABEL))
LABEL_NUSES (XEXP (XVECEXP (unspec, 0, 0), 0)) += 2;
}
-}")
+})
(define_expand "movsi_const_16bit"
[(set (match_operand:SI 0 "arith_reg_operand" "=r")
@@ -5379,14 +5315,13 @@ label:
"TARGET_SHMEDIA && reload_completed
&& MOVI_SHORI_BASE_OPERAND_P (operands[1])"
[(const_int 0)]
- "
{
rtx insn = emit_insn (gen_movsi_const (operands[0], operands[1]));
set_unique_reg_note (insn, REG_EQUAL, copy_rtx (operands[1]));
DONE;
-}")
+})
(define_split
[(set (match_operand:SI 0 "register_operand" "")
@@ -5401,14 +5336,16 @@ label:
[(set (match_operand:SI 0 "general_movdst_operand" "")
(match_operand:SI 1 "general_movsrc_operand" ""))]
""
- "{ if (prepare_move_operands (operands, SImode)) DONE; }")
+{
+ if (prepare_move_operands (operands, SImode))
+ DONE;
+})
(define_expand "ic_invalidate_line"
[(parallel [(unspec_volatile [(match_operand:SI 0 "register_operand" "+r")
(match_dup 1)] UNSPEC_ICACHE)
(clobber (scratch:SI))])]
"TARGET_HARD_SH4 || TARGET_SH5"
- "
{
if (TARGET_SHMEDIA)
{
@@ -5417,7 +5354,7 @@ label:
}
else if (TARGET_SHCOMPACT)
{
- operands[1] = function_symbol (NULL, \"__ic_invalidate\", SFUNC_STATIC);
+ operands[1] = function_symbol (NULL, "__ic_invalidate", SFUNC_STATIC);
operands[1] = force_reg (Pmode, operands[1]);
emit_insn (gen_ic_invalidate_line_compact (operands[0], operands[1]));
DONE;
@@ -5430,7 +5367,7 @@ label:
operands[0] = force_reg (Pmode, operands[0]);
operands[1] = force_reg (Pmode, GEN_INT (trunc_int_for_mode (0xf0000008,
Pmode)));
-}")
+})
;; The address %0 is assumed to be 4-aligned at least. Thus, by ORing
;; 0xf0000008, we get the low-oder bits *1*00 (binary), which fits
@@ -5480,19 +5417,18 @@ label:
(match_operand:SI 1 "" "")
(match_operand:SI 2 "" "")]
"TARGET_SHCOMPACT"
- "
{
rtx sfun, tramp;
tramp = force_reg (Pmode, operands[0]);
- sfun = force_reg (Pmode, function_symbol (NULL, \"__init_trampoline\",
+ sfun = force_reg (Pmode, function_symbol (NULL, "__init_trampoline",
SFUNC_STATIC));
emit_move_insn (gen_rtx_REG (SImode, R2_REG), operands[1]);
emit_move_insn (gen_rtx_REG (SImode, R3_REG), operands[2]);
emit_insn (gen_initialize_trampoline_compact (tramp, sfun));
DONE;
-}")
+})
(define_insn "initialize_trampoline_compact"
[(unspec_volatile [(match_operand:SI 0 "register_operand" "z")
@@ -5510,7 +5446,10 @@ label:
[(set (match_operand:QI 0 "general_operand" "")
(match_operand:QI 1 "general_operand" ""))]
""
- "{ if (prepare_move_operands (operands, QImode)) DONE; }")
+{
+ if (prepare_move_operands (operands, QImode))
+ DONE;
+})
;; If movqi_reg_reg is specified as an alternative of movqi, movqi will be
;; selected to copy QImode regs. If one of them happens to be allocated
@@ -5614,7 +5553,6 @@ label:
(set (match_operand:QI 0 "arith_reg_operand" "=r")
(truncate:QI (match_dup 3)))]
"TARGET_SHMEDIA"
- "
{
rtx inner = XEXP (operands[1], 0);
int regno = REGNO (inner);
@@ -5622,7 +5560,7 @@ label:
regno += HARD_REGNO_NREGS (regno, GET_MODE (inner)) - 1;
operands[1] = gen_rtx_REG (SImode, regno);
operands[3] = gen_rtx_REG (DImode, REGNO (operands[2]));
-}")
+})
;; When storing r0, we have to avoid reg+reg addressing.
(define_insn "movhi_i"
@@ -5675,7 +5613,10 @@ label:
[(set (match_operand:HI 0 "general_movdst_operand" "")
(match_operand:HI 1 "general_movsrc_operand" ""))]
""
- "{ if (prepare_move_operands (operands, HImode)) DONE; }")
+{
+ if (prepare_move_operands (operands, HImode))
+ DONE;
+})
(define_expand "reload_inhi"
[(set (match_operand:SI 2 "" "=&r")
@@ -5683,7 +5624,6 @@ label:
(set (match_operand:HI 0 "arith_reg_operand" "=r")
(truncate:HI (match_dup 3)))]
"TARGET_SHMEDIA"
- "
{
rtx inner = XEXP (operands[1], 0);
int regno = REGNO (inner);
@@ -5691,7 +5631,7 @@ label:
regno += HARD_REGNO_NREGS (regno, GET_MODE (inner)) - 1;
operands[1] = gen_rtx_REG (SImode, regno);
operands[3] = gen_rtx_REG (DImode, REGNO (operands[2]));
-}")
+})
;; x/r can be created by inlining/cse, e.g. for execute/961213-1.c
;; compiled with -m2 -ml -O3 -funroll-loops
@@ -5714,7 +5654,6 @@ label:
"TARGET_SH1 && reload_completed"
[(set (match_dup 2) (match_dup 3))
(set (match_dup 4) (match_dup 5))]
- "
{
int regno;
@@ -5758,7 +5697,7 @@ label:
if (operands[2] == 0 || operands[3] == 0
|| operands[4] == 0 || operands[5] == 0)
FAIL;
-}")
+})
;; The '?'s in the following constraints may not reflect the time taken
;; to perform the move. They are there to discourage the use of floating-
@@ -5820,7 +5759,6 @@ label:
"TARGET_SHMEDIA && reload_completed
&& MOVI_SHORI_BASE_OPERAND_P (operands[1])"
[(set (match_dup 0) (match_dup 1))]
- "
{
rtx insn;
@@ -5832,7 +5770,7 @@ label:
set_unique_reg_note (insn, REG_EQUAL, copy_rtx (operands[1]));
DONE;
-}")
+})
(define_expand "movdi_const"
[(set (match_operand:DI 0 "arith_reg_operand" "=r")
@@ -5852,10 +5790,9 @@ label:
(const_int 0)] UNSPEC_EXTRACT_U16))))]
"TARGET_SHMEDIA64 && reload_completed
&& MOVI_SHORI_BASE_OPERAND_P (operands[1])"
- "
{
sh_mark_label (operands[1], 4);
-}")
+})
(define_expand "movdi_const_32bit"
[(set (match_operand:DI 0 "arith_reg_operand" "=r")
@@ -5867,10 +5804,9 @@ label:
(const_int 0)] UNSPEC_EXTRACT_U16))))]
"TARGET_SHMEDIA32 && reload_completed
&& MOVI_SHORI_BASE_OPERAND_P (operands[1])"
- "
{
sh_mark_label (operands[1], 2);
-}")
+})
(define_expand "movdi_const_16bit"
[(set (match_operand:DI 0 "arith_reg_operand" "=r")
@@ -5888,7 +5824,6 @@ label:
&& ! satisfies_constraint_I16 (operands[1])"
[(set (match_dup 0) (match_dup 2))
(match_dup 1)]
- "
{
unsigned HOST_WIDE_INT val = INTVAL (operands[1]);
unsigned HOST_WIDE_INT low = val;
@@ -5985,7 +5920,7 @@ label:
}
while (0);
operands[2] = GEN_INT (val2);
-}")
+})
(define_split
[(set (match_operand:DI 0 "ext_dest_operand" "")
@@ -5995,7 +5930,6 @@ label:
[(set (match_dup 0) (match_dup 2))
(set (match_dup 0)
(ior:DI (ashift:DI (match_dup 0) (const_int 16)) (match_dup 1)))]
- "
{
unsigned HOST_WIDE_INT low = CONST_DOUBLE_LOW (operands[1]);
unsigned HOST_WIDE_INT high = CONST_DOUBLE_HIGH (operands[1]);
@@ -6022,7 +5956,7 @@ label:
operands[2] = GEN_INT (low);
else
operands[2] = immed_double_const (low, high, DImode);
-}")
+})
(define_insn "shori_media"
[(set (match_operand:DI 0 "ext_dest_operand" "=r,r")
@@ -6047,7 +5981,10 @@ label:
[(set (match_operand:DI 0 "general_movdst_operand" "")
(match_operand:DI 1 "general_movsrc_operand" ""))]
""
- "{ if (prepare_move_operands (operands, DImode)) DONE; }")
+{
+ if (prepare_move_operands (operands, DImode))
+ DONE;
+})
(define_insn "movdf_media"
[(set (match_operand:DF 0 "general_movdst_operand" "=f,f,r,r,r,f,m,r,m")
@@ -6085,7 +6022,6 @@ label:
(match_operand:DF 1 "immediate_operand" ""))]
"TARGET_SHMEDIA && reload_completed"
[(set (match_dup 3) (match_dup 2))]
- "
{
int endian = WORDS_BIG_ENDIAN ? 1 : 0;
long values[2];
@@ -6106,7 +6042,7 @@ label:
}
operands[3] = gen_rtx_REG (DImode, true_regnum (operands[0]));
-}")
+})
;; ??? This should be a define expand.
@@ -6120,7 +6056,9 @@ label:
|| (REG_P (operands[1]) && REGNO (operands[1]) == 3))
&& (arith_reg_operand (operands[0], DFmode)
|| arith_reg_operand (operands[1], DFmode))"
- "* return output_movedouble (insn, operands, DFmode);"
+{
+ return output_movedouble (insn, operands, DFmode);
+}
[(set_attr "length" "4")
(set_attr "type" "move,pcload,load,store")])
@@ -6192,7 +6130,6 @@ label:
"(TARGET_SH4 || TARGET_SH2A_DOUBLE) && reload_completed
&& (true_regnum (operands[0]) < 16) != (true_regnum (operands[1]) < 16)"
[(const_int 0)]
- "
{
rtx insn, tos;
@@ -6219,7 +6156,7 @@ label:
else
add_reg_note (insn, REG_INC, stack_pointer_rtx);
DONE;
-}")
+})
;; local-alloc sometimes allocates scratch registers even when not required,
;; so we must be prepared to handle these.
@@ -6235,7 +6172,6 @@ label:
&& true_regnum (operands[0]) < 16
&& true_regnum (operands[1]) < 16"
[(set (match_dup 0) (match_dup 1))]
- "
{
/* If this was a reg <-> mem operation with base + index reg addressing,
we have to handle this in a special way. */
@@ -6295,7 +6231,7 @@ label:
DONE;
}
}
-}")
+})
;; Split away the clobber of r0 after machine_dependent_reorg has fixed pcloads.
(define_split
@@ -6345,7 +6281,6 @@ label:
&& FP_OR_XD_REGISTER_P (true_regnum (operands[0]))
&& FP_OR_XD_REGISTER_P (true_regnum (operands[1]))"
[(const_int 0)]
- "
{
int dst = true_regnum (operands[0]), src = true_regnum (operands[1]);
emit_insn (gen_movsf_ie (gen_rtx_REG (SFmode, dst),
@@ -6353,7 +6288,7 @@ label:
emit_insn (gen_movsf_ie (gen_rtx_REG (SFmode, dst + 1),
gen_rtx_REG (SFmode, src + 1), operands[2]));
DONE;
-}")
+})
(define_split
[(set (match_operand:DF 0 "register_operand" "")
@@ -6364,7 +6299,6 @@ label:
&& FP_OR_XD_REGISTER_P (true_regnum (operands[0]))
&& find_regno_note (insn, REG_DEAD, true_regnum (operands[1]))"
[(const_int 0)]
- "
{
int regno = true_regnum (operands[0]);
rtx insn;
@@ -6380,7 +6314,7 @@ label:
change_address (mem, SFmode, NULL_RTX),
operands[2]));
DONE;
-}")
+})
(define_split
[(set (match_operand:DF 0 "register_operand" "")
@@ -6530,7 +6464,6 @@ label:
"TARGET_SH1 && reload_completed"
[(set (match_dup 2) (match_dup 3))
(set (match_dup 4) (match_dup 5))]
- "
{
int regno;
@@ -6574,7 +6507,7 @@ label:
if (operands[2] == 0 || operands[3] == 0
|| operands[4] == 0 || operands[5] == 0)
FAIL;
-}")
+})
;; If a base address generated by LEGITIMIZE_ADDRESS for SImode is
;; used only once, let combine add in the index again.
@@ -6586,7 +6519,6 @@ label:
"TARGET_SH1 && ! reload_in_progress && ! reload_completed
&& ALLOW_INDEXED_ADDRESS"
[(use (reg:SI R0_REG))]
- "
{
rtx addr, reg, const_int;
@@ -6605,7 +6537,7 @@ label:
change_address (operands[1], VOIDmode,
gen_rtx_PLUS (SImode, reg, operands[2])));
DONE;
-}")
+})
(define_split
[(set (match_operand:SI 1 "" "")
@@ -6614,7 +6546,6 @@ label:
"TARGET_SH1 && ! reload_in_progress && ! reload_completed
&& ALLOW_INDEXED_ADDRESS"
[(use (reg:SI R0_REG))]
- "
{
rtx addr, reg, const_int;
@@ -6633,15 +6564,15 @@ label:
gen_rtx_PLUS (SImode, reg, operands[2])),
operands[0]);
DONE;
-}")
+})
(define_expand "movdf"
[(set (match_operand:DF 0 "general_movdst_operand" "")
(match_operand:DF 1 "general_movsrc_operand" ""))]
""
- "
{
- if (prepare_move_operands (operands, DFmode)) DONE;
+ if (prepare_move_operands (operands, DFmode))
+ DONE;
if (TARGET_SHMEDIA)
{
if (TARGET_SHMEDIA_FPU)
@@ -6655,7 +6586,7 @@ label:
emit_df_insn (gen_movdf_i4 (operands[0], operands[1], get_fpscr_rtx ()));
DONE;
}
-}")
+})
;;This is incompatible with the way gcc uses subregs.
;;(define_insn "movv2sf_i"
@@ -6677,65 +6608,59 @@ label:
"#"
"TARGET_SHMEDIA_FPU && reload_completed"
[(set (match_dup 0) (match_dup 1))]
- "
{
operands[0] = simplify_gen_subreg (DFmode, operands[0], V2SFmode, 0);
operands[1] = simplify_gen_subreg (DFmode, operands[1], V2SFmode, 0);
-}")
+})
(define_expand "movv2sf"
[(set (match_operand:V2SF 0 "general_movdst_operand" "")
(match_operand:V2SF 1 "nonimmediate_operand" ""))]
"TARGET_SHMEDIA_FPU"
- "
{
if (prepare_move_operands (operands, V2SFmode))
DONE;
-}")
+})
(define_expand "addv2sf3"
[(match_operand:V2SF 0 "fp_arith_reg_operand" "")
(match_operand:V2SF 1 "fp_arith_reg_operand" "")
(match_operand:V2SF 2 "fp_arith_reg_operand" "")]
"TARGET_SHMEDIA_FPU"
- "
{
sh_expand_binop_v2sf (PLUS, operands[0], operands[1], operands[2]);
DONE;
-}")
+})
(define_expand "subv2sf3"
[(match_operand:V2SF 0 "fp_arith_reg_operand" "")
(match_operand:V2SF 1 "fp_arith_reg_operand" "")
(match_operand:V2SF 2 "fp_arith_reg_operand" "")]
"TARGET_SHMEDIA_FPU"
- "
{
sh_expand_binop_v2sf (MINUS, operands[0], operands[1], operands[2]);
DONE;
-}")
+})
(define_expand "mulv2sf3"
[(match_operand:V2SF 0 "fp_arith_reg_operand" "")
(match_operand:V2SF 1 "fp_arith_reg_operand" "")
(match_operand:V2SF 2 "fp_arith_reg_operand" "")]
"TARGET_SHMEDIA_FPU"
- "
{
sh_expand_binop_v2sf (MULT, operands[0], operands[1], operands[2]);
DONE;
-}")
+})
(define_expand "divv2sf3"
[(match_operand:V2SF 0 "fp_arith_reg_operand" "")
(match_operand:V2SF 1 "fp_arith_reg_operand" "")
(match_operand:V2SF 2 "fp_arith_reg_operand" "")]
"TARGET_SHMEDIA_FPU"
- "
{
sh_expand_binop_v2sf (DIV, operands[0], operands[1], operands[2]);
DONE;
-}")
+})
(define_insn_and_split "*movv4sf_i"
[(set (match_operand:V4SF 0 "general_movdst_operand" "=f,rf,r,m,mf")
@@ -6744,7 +6669,6 @@ label:
"#"
"&& reload_completed"
[(const_int 0)]
- "
{
int i;
@@ -6768,18 +6692,17 @@ label:
}
DONE;
-}"
+}
[(set_attr "length" "8")])
(define_expand "movv4sf"
[(set (match_operand:V4SF 0 "nonimmediate_operand" "")
(match_operand:V4SF 1 "general_operand" ""))]
"TARGET_SHMEDIA_FPU"
- "
{
if (prepare_move_operands (operands, V4SFmode))
DONE;
-}")
+})
(define_insn_and_split "*movv16sf_i"
[(set (match_operand:V16SF 0 "nonimmediate_operand" "=f,f,m")
@@ -6788,7 +6711,6 @@ label:
"#"
"&& reload_completed"
[(const_int 0)]
- "
{
int i;
@@ -6818,18 +6740,17 @@ label:
}
DONE;
-}"
+}
[(set_attr "length" "32")])
(define_expand "movv16sf"
[(set (match_operand:V16SF 0 "nonimmediate_operand" "=f,f,m")
(match_operand:V16SF 1 "nonimmediate_operand" "f,m,f"))]
"TARGET_SHMEDIA_FPU"
- "
{
if (prepare_move_operands (operands, V16SFmode))
DONE;
-}")
+})
(define_insn "movsf_media"
[(set (match_operand:SF 0 "general_movdst_operand" "=f,f,r,r,r,f,m,r,m")
@@ -6876,7 +6797,6 @@ label:
"TARGET_SHMEDIA && reload_completed
&& ! FP_REGISTER_P (true_regnum (operands[0]))"
[(set (match_dup 3) (match_dup 2))]
- "
{
long values;
REAL_VALUE_TYPE value;
@@ -6886,7 +6806,7 @@ label:
operands[2] = GEN_INT (values);
operands[3] = gen_rtx_REG (DImode, true_regnum (operands[0]));
-}")
+})
(define_insn "movsf_i"
[(set (match_operand:SF 0 "general_movdst_operand" "=r,r,r,r,m,l,r")
@@ -6918,7 +6838,6 @@ label:
"f,r,G,H,FQ,mf,f,FQ,mr,r,y,f,>,fr,y,r,y,>,y"))
(use (match_operand:PSI 2 "fpscr_operand" "c,c,c,c,c,c,c,c,c,c,c,c,c,c,c,c,c,c,c"))
(clobber (match_scratch:SI 3 "=X,X,Bsc,Bsc,&z,X,X,X,X,X,X,X,X,y,X,X,X,X,X"))]
-
"TARGET_SH2E
&& (arith_reg_operand (operands[0], SFmode)
|| arith_reg_operand (operands[1], SFmode)
@@ -7001,7 +6920,6 @@ label:
[(set (match_operand:SF 0 "general_movdst_operand" "")
(match_operand:SF 1 "general_movsrc_operand" ""))]
""
- "
{
if (prepare_move_operands (operands, SFmode))
DONE;
@@ -7018,7 +6936,7 @@ label:
emit_sf_insn (gen_movsf_ie (operands[0], operands[1], get_fpscr_rtx ()));
DONE;
}
-}")
+})
(define_insn "mov_nop"
[(set (match_operand 0 "any_register_operand" "") (match_dup 0))]
@@ -7045,7 +6963,6 @@ label:
(define_expand "ptabs"
[(set (match_operand 0 "" "=b") (match_operand 1 "" "r"))]
"TARGET_SHMEDIA"
- "
{
if (!TARGET_PT_FIXED)
{
@@ -7067,7 +6984,7 @@ label:
gen_rtx_fmt_e (TARGET_SHMEDIA32 ? SIGN_EXTEND : TRUNCATE,
PDImode, operands[1])));
}
-}")
+})
;; expanded by ptabs expander.
(define_insn "*extendsipdi_media"
@@ -7128,7 +7045,9 @@ label:
(label_ref (match_operand 0 "" ""))
(pc)))]
"TARGET_SH1"
- "* return output_branch (1, insn, operands);"
+{
+ return output_branch (1, insn, operands);
+}
[(set_attr "type" "cbranch")])
(define_insn "branch_false"
@@ -7136,7 +7055,9 @@ label:
(label_ref (match_operand 0 "" ""))
(pc)))]
"TARGET_SH1"
- "* return output_branch (0, insn, operands);"
+{
+ return output_branch (0, insn, operands);
+}
[(set_attr "type" "cbranch")])
;; Patterns to prevent reorg from re-combining a condbranch with a branch
@@ -7185,7 +7106,6 @@ label:
(match_operand 3 "" "")
(pc)))]
"TARGET_SHMEDIA"
- "
{
enum machine_mode mode = GET_MODE (operands[1]);
if (mode == VOIDmode)
@@ -7221,7 +7141,7 @@ label:
break;
}
operands[3] = gen_rtx_LABEL_REF (Pmode, operands[3]);
-}")
+})
(define_expand "cbranchfp4_media"
[(set (pc)
@@ -7231,7 +7151,6 @@ label:
(match_operand 3 "" "")
(pc)))]
"TARGET_SHMEDIA"
- "
{
rtx tmp = gen_reg_rtx (SImode);
rtx cmp;
@@ -7250,7 +7169,7 @@ label:
operands[1] = tmp;
operands[2] = const0_rtx;
operands[3] = gen_rtx_LABEL_REF (Pmode, operands[3]);
-}")
+})
(define_insn "*beq_media_i"
[(set (pc)
@@ -7344,14 +7263,12 @@ label:
"TARGET_SHMEDIA && TARGET_LITTLE_ENDIAN"
[(set (match_dup 4) (ashift:SI (match_dup 1) (match_dup 5)))
(set (pc) (if_then_else (match_dup 6) (match_dup 0) (pc)))]
-
- "
{
operands[5] = GEN_INT (31 - INTVAL (operands[2]));
operands[6] = (GET_CODE (operands[3]) == EQ
? gen_rtx_GE (VOIDmode, operands[4], const0_rtx)
: gen_rtx_GT (VOIDmode, const0_rtx, operands[4]));
-}")
+})
; operand 0 is the loop count pseudo register
; operand 1 is the number of loop iterations or 0 if it is unknown
@@ -7369,12 +7286,10 @@ label:
(plus:SI (match_dup 0) (const_int -1)))
(clobber (reg:SI T_REG))])]
"TARGET_SH2"
- "
{
if (GET_MODE (operands[0]) != SImode)
FAIL;
-}
-")
+})
(define_insn_and_split "doloop_end_split"
[(set (pc)
@@ -7394,7 +7309,7 @@ label:
(set (pc) (if_then_else (eq (reg:SI T_REG) (const_int 0))
(label_ref (match_dup 1))
(pc)))]
-""
+ ""
[(set_attr "type" "cbranch")])
@@ -7406,14 +7321,13 @@ label:
[(set (pc)
(label_ref (match_operand 0 "" "")))]
"TARGET_SH1 && !find_reg_note (insn, REG_CROSSING_JUMP, NULL_RTX)"
- "*
{
/* The length is 16 if the delay slot is unfilled. */
if (get_attr_length(insn) > 4)
return output_far_jump(insn, operands[0]);
else
- return \"bra %l0%#\";
-}"
+ return "bra %l0%#";
+}
[(set_attr "type" "jump")
(set_attr "needs_delay_slot" "yes")])
@@ -7441,7 +7355,6 @@ label:
[(set (pc)
(label_ref (match_operand 0 "" "")))]
""
- "
{
if (TARGET_SH1)
emit_jump_insn (gen_jump_compact (operands[0]));
@@ -7453,7 +7366,7 @@ label:
operands[0])));
}
DONE;
-}")
+})
(define_insn "force_mode_for_call"
[(use (reg:PSI FPSCR_REG))]
@@ -7470,14 +7383,12 @@ label:
(use (reg:PSI FPSCR_REG))
(clobber (reg:SI PR_REG))]
"TARGET_SH1"
- "*
- {
- if (TARGET_SH2A && (dbr_sequence_length () == 0))
- return \"jsr/n\\t@%0\";
- else
- return \"jsr\\t@%0%#\";
- }"
-
+{
+ if (TARGET_SH2A && (dbr_sequence_length () == 0))
+ return "jsr/n\\t@%0";
+ else
+ return "jsr\\t@%0%#";
+}
[(set_attr "type" "call")
(set (attr "fp_mode")
(if_then_else (eq_attr "fpu_single" "yes")
@@ -7495,14 +7406,13 @@ label:
(use (reg:PSI FPSCR_REG))
(clobber (reg:SI PR_REG))]
"TARGET_SH2A && sh2a_is_function_vector_call (operands[0])"
- "*
{
unsigned HOST_WIDE_INT vect_num;
vect_num = sh2a_get_function_vector_number (operands[0]);
operands[2] = GEN_INT (vect_num * 4);
- return \"jsr/n\\t@@(%O2,tbr)\";
-}"
+ return "jsr/n\\t@@(%O2,tbr)";
+}
[(set_attr "type" "call")
(set (attr "fp_mode")
(if_then_else (eq_attr "fpu_single" "yes")
@@ -7539,7 +7449,6 @@ label:
"#"
"reload_completed"
[(const_int 0)]
- "
{
rtx lab = PATTERN (gen_call_site ());
@@ -7549,7 +7458,7 @@ label:
emit_insn (gen_symPLT_label2reg (operands[2], operands[0], lab));
emit_call_insn (gen_calli_pcrel (operands[2], operands[1], copy_rtx (lab)));
DONE;
-}"
+}
[(set_attr "type" "call")
(set (attr "fp_mode")
(if_then_else (eq_attr "fpu_single" "yes")
@@ -7605,13 +7514,12 @@ label:
(use (reg:PSI FPSCR_REG))
(clobber (reg:SI PR_REG))]
"TARGET_SH1"
- "*
- {
- if (TARGET_SH2A && (dbr_sequence_length () == 0))
- return \"jsr/n\\t@%1\";
- else
- return \"jsr\\t@%1%#\";
- }"
+{
+ if (TARGET_SH2A && (dbr_sequence_length () == 0))
+ return "jsr/n\\t@%1";
+ else
+ return "jsr\\t@%1%#";
+}
[(set_attr "type" "call")
(set (attr "fp_mode")
(if_then_else (eq_attr "fpu_single" "yes")
@@ -7630,14 +7538,13 @@ label:
(use (reg:PSI FPSCR_REG))
(clobber (reg:SI PR_REG))]
"TARGET_SH2A && sh2a_is_function_vector_call (operands[1])"
- "*
{
unsigned HOST_WIDE_INT vect_num;
vect_num = sh2a_get_function_vector_number (operands[1]);
operands[3] = GEN_INT (vect_num * 4);
- return \"jsr/n\\t@@(%O3,tbr)\";
-}"
+ return "jsr/n\\t@@(%O3,tbr)";
+}
[(set_attr "type" "call")
(set (attr "fp_mode")
(if_then_else (eq_attr "fpu_single" "yes")
@@ -7674,7 +7581,6 @@ label:
"#"
"reload_completed"
[(const_int 0)]
- "
{
rtx lab = PATTERN (gen_call_site ());
@@ -7685,7 +7591,7 @@ label:
emit_call_insn (gen_call_valuei_pcrel (operands[0], operands[3],
operands[2], copy_rtx (lab)));
DONE;
-}"
+}
[(set_attr "type" "call")
(set (attr "fp_mode")
(if_then_else (eq_attr "fpu_single" "yes")
@@ -7744,7 +7650,6 @@ label:
(use (reg:PSI FPSCR_REG))
(clobber (reg:SI PR_REG))])]
""
- "
{
if (TARGET_SHMEDIA)
{
@@ -7781,8 +7686,7 @@ label:
emit_insn (gen_force_mode_for_call ());
operands[0]
- = function_symbol (NULL, \"__GCC_shcompact_call_trampoline\",
- SFUNC_GOT);
+ = function_symbol (NULL, "__GCC_shcompact_call_trampoline", SFUNC_GOT);
operands[0] = force_reg (SImode, operands[0]);
emit_move_insn (r0, func);
@@ -7832,7 +7736,7 @@ label:
emit_call_insn (gen_calli (operands[0], operands[1]));
DONE;
-}")
+})
(define_insn "call_pop_compact"
[(call (mem:SI (match_operand:SI 0 "arith_reg_operand" "r"))
@@ -7878,7 +7782,6 @@ label:
(set (reg:SI SP_REG) (plus:SI (reg:SI SP_REG)
(match_operand 3 "" "")))])]
"TARGET_SHCOMPACT"
- "
{
rtx cookie_rtx;
long cookie;
@@ -7910,7 +7813,7 @@ label:
run out of registers when adjusting fpscr for the call. */
emit_insn (gen_force_mode_for_call ());
- operands[0] = function_symbol (NULL, \"__GCC_shcompact_call_trampoline\",
+ operands[0] = function_symbol (NULL, "__GCC_shcompact_call_trampoline",
SFUNC_GOT);
operands[0] = force_reg (SImode, operands[0]);
@@ -7925,7 +7828,7 @@ label:
(operands[0], operands[1], operands[2], operands[3]));
DONE;
-}")
+})
(define_expand "call_value"
[(parallel [(set (match_operand 0 "arith_reg_operand" "")
@@ -7935,7 +7838,6 @@ label:
(use (reg:PSI FPSCR_REG))
(clobber (reg:SI PR_REG))])]
""
- "
{
if (TARGET_SHMEDIA)
{
@@ -7973,8 +7875,7 @@ label:
emit_insn (gen_force_mode_for_call ());
operands[1]
- = function_symbol (NULL, \"__GCC_shcompact_call_trampoline\",
- SFUNC_GOT);
+ = function_symbol (NULL, "__GCC_shcompact_call_trampoline", SFUNC_GOT);
operands[1] = force_reg (SImode, operands[1]);
emit_move_insn (r0, func);
@@ -8024,7 +7925,7 @@ label:
emit_call_insn (gen_call_valuei (operands[0], operands[1], operands[2]));
DONE;
-}")
+})
(define_insn "sibcalli"
[(call (mem:SI (match_operand:SI 0 "register_operand" "k"))
@@ -8079,7 +7980,6 @@ label:
"#"
"reload_completed"
[(const_int 0)]
- "
{
rtx lab = PATTERN (gen_call_site ());
rtx call_insn;
@@ -8089,7 +7989,7 @@ label:
copy_rtx (lab)));
SIBLING_CALL_P (call_insn) = 1;
DONE;
-}"
+}
[(set_attr "needs_delay_slot" "yes")
(set (attr "fp_mode")
(if_then_else (eq_attr "fpu_single" "yes")
@@ -8132,7 +8032,6 @@ label:
(use (reg:PSI FPSCR_REG))
(return)])]
""
- "
{
if (TARGET_SHMEDIA)
{
@@ -8179,8 +8078,7 @@ label:
emit_insn (gen_force_mode_for_call ());
operands[0]
- = function_symbol (NULL, \"__GCC_shcompact_call_trampoline\",
- SFUNC_GOT);
+ = function_symbol (NULL, "__GCC_shcompact_call_trampoline", SFUNC_GOT);
operands[0] = force_reg (SImode, operands[0]);
/* We don't need a return trampoline, since the callee will
@@ -8222,7 +8120,7 @@ label:
emit_call_insn (gen_sibcalli (operands[0], operands[1]));
DONE;
-}")
+})
(define_insn "sibcall_valuei"
[(set (match_operand 0 "" "=rf")
@@ -8264,7 +8162,6 @@ label:
"#"
"reload_completed"
[(const_int 0)]
- "
{
rtx lab = PATTERN (gen_call_site ());
rtx call_insn;
@@ -8276,7 +8173,7 @@ label:
copy_rtx (lab)));
SIBLING_CALL_P (call_insn) = 1;
DONE;
-}"
+}
[(set_attr "needs_delay_slot" "yes")
(set (attr "fp_mode")
(if_then_else (eq_attr "fpu_single" "yes")
@@ -8322,7 +8219,6 @@ label:
(use (reg:PSI FPSCR_REG))
(return)])]
""
- "
{
if (TARGET_SHMEDIA)
{
@@ -8370,8 +8266,7 @@ label:
emit_insn (gen_force_mode_for_call ());
operands[1]
- = function_symbol (NULL, \"__GCC_shcompact_call_trampoline\",
- SFUNC_GOT);
+ = function_symbol (NULL, "__GCC_shcompact_call_trampoline", SFUNC_GOT);
operands[1] = force_reg (SImode, operands[1]);
/* We don't need a return trampoline, since the callee will
@@ -8416,7 +8311,7 @@ label:
emit_call_insn (gen_sibcall_valuei (operands[0], operands[1], operands[2]));
DONE;
-}")
+})
(define_insn "call_value_pop_compact"
[(set (match_operand 0 "" "=rf")
@@ -8465,7 +8360,6 @@ label:
(set (reg:SI SP_REG) (plus:SI (reg:SI SP_REG)
(match_operand 4 "" "")))])]
"TARGET_SHCOMPACT"
- "
{
rtx cookie_rtx;
long cookie;
@@ -8498,7 +8392,7 @@ label:
run out of registers when adjusting fpscr for the call. */
emit_insn (gen_force_mode_for_call ());
- operands[1] = function_symbol (NULL, \"__GCC_shcompact_call_trampoline\",
+ operands[1] = function_symbol (NULL, "__GCC_shcompact_call_trampoline",
SFUNC_GOT);
operands[1] = force_reg (SImode, operands[1]);
@@ -8515,12 +8409,11 @@ label:
operands[3], operands[4]));
DONE;
-}")
+})
(define_expand "sibcall_epilogue"
[(return)]
""
- "
{
sh_expand_epilogue (1);
if (TARGET_SHCOMPACT)
@@ -8547,7 +8440,7 @@ label:
}
}
DONE;
-}")
+})
(define_insn "indirect_jump_compact"
[(set (pc)
@@ -8561,11 +8454,10 @@ label:
[(set (pc)
(match_operand 0 "register_operand" ""))]
""
- "
{
if (GET_MODE (operands[0]) != Pmode)
operands[0] = gen_rtx_SUBREG (Pmode, operands[0], 0);
-}")
+})
;; The use of operand 1 / 2 helps us distinguish case table jumps
;; which can be present in structured code from indirect jumps which can not
@@ -8608,7 +8500,6 @@ label:
(match_operand 1 "" "")
(match_operand 2 "" "")])]
"(TARGET_SH2E || TARGET_SH2A) || TARGET_SHMEDIA"
- "
{
int i;
@@ -8627,7 +8518,7 @@ label:
emit_insn (gen_blockage ());
DONE;
-}")
+})
;; ------------------------------------------------------------------------
;; Misc insns
@@ -8675,7 +8566,7 @@ label:
UNSPEC_MOVA))
(set (match_dup 0) (const:SI (unspec:SI [(match_dup 1)] UNSPEC_PIC)))
(set (match_dup 0) (plus:SI (match_dup 0) (reg:SI R0_REG)))]
- "" "
+ ""
{
if (TARGET_VXWORKS_RTP)
{
@@ -8717,8 +8608,7 @@ label:
DONE;
}
-}
-")
+})
;; A helper for GOTaddr2picreg to finish up the initialization of the
;; PIC register.
@@ -8766,21 +8656,19 @@ label:
(define_expand "builtin_setjmp_receiver"
[(match_operand 0 "" "")]
"flag_pic"
- "
{
emit_insn (gen_GOTaddr2picreg ());
DONE;
-}")
+})
(define_expand "call_site"
[(unspec [(match_dup 0)] UNSPEC_CALLER)]
"TARGET_SH1"
- "
{
static HOST_WIDE_INT i = 0;
operands[0] = GEN_INT (i);
i++;
-}")
+})
;; op0 = op1 + r12 but hide it before reload completed. See the comment
;; in symGOT_load expand.
@@ -8811,7 +8699,6 @@ label:
(set (match_dup 3) (plus (match_dup 2) (reg PIC_REG)))
(set (match_operand 0 "" "") (mem (match_dup 3)))]
""
- "
{
rtx mem;
@@ -8851,7 +8738,7 @@ label:
&& GET_CODE (XEXP (operands[1], 0)) == UNSPEC
&& GET_CODE (XVECEXP (XEXP (operands[1], 0), 0, 0)) == SYMBOL_REF
&& strcmp (XSTR (XVECEXP (XEXP (operands[1], 0), 0, 0), 0),
- \"__stack_chk_guard\") == 0)
+ "__stack_chk_guard") == 0)
emit_insn (gen_chk_guard_add (operands[3], operands[2]));
else
emit_move_insn (operands[3], gen_rtx_PLUS (Pmode, operands[2],
@@ -8864,7 +8751,7 @@ label:
emit_move_insn (operands[0], mem);
DONE;
-}")
+})
(define_expand "sym2GOT"
[(const (unspec [(match_operand 0 "" "")] UNSPEC_GOT))]
@@ -8874,7 +8761,6 @@ label:
(define_expand "symGOT2reg"
[(match_operand 0 "" "") (match_operand 1 "" "")]
""
- "
{
rtx gotsym, insn;
@@ -8885,12 +8771,11 @@ label:
MEM_READONLY_P (SET_SRC (PATTERN (insn))) = 1;
DONE;
-}")
+})
(define_expand "symGOTPLT2reg"
[(match_operand 0 "" "") (match_operand 1 "" "")]
""
- "
{
rtx pltsym = gen_rtx_CONST (Pmode,
gen_rtx_UNSPEC (Pmode,
@@ -8898,7 +8783,7 @@ label:
UNSPEC_GOTPLT));
emit_insn (gen_symGOT_load (operands[0], pltsym));
DONE;
-}")
+})
(define_expand "sym2GOTOFF"
[(const (unspec [(match_operand 0 "" "")] UNSPEC_GOTOFF))]
@@ -8908,7 +8793,6 @@ label:
(define_expand "symGOTOFF2reg"
[(match_operand 0 "" "") (match_operand 1 "" "")]
""
- "
{
rtx gotoffsym, insn;
rtx t = (!can_create_pseudo_p ()
@@ -8925,7 +8809,7 @@ label:
set_unique_reg_note (insn, REG_EQUAL, operands[1]);
DONE;
-}")
+})
(define_expand "symPLT_label2reg"
[(set (match_operand:SI 0 "" "")
@@ -8970,22 +8854,20 @@ label:
(clobber (reg:SI PR_REG))
(clobber (scratch:SI))]
"TARGET_SH1"
- "*
-{
- return \"\\
-mov.l\\t1f,r4\\n\\
-\\tmova\\t2f,r0\\n\\
-\\tmov.l\\t2f,r1\\n\\
-\\tadd\\tr0,r1\\n\\
-\\tjsr\\t@r1\\n\\
-\\tadd\\tr12,r4\\n\\
-\\tbra\\t3f\\n\\
-\\tnop\\n\\
-\\t.align\\t2\\n\\
-1:\\t.long\\t%a1@TLSGD\\n\\
-2:\\t.long\\t__tls_get_addr@PLT\\n\\
-3:\";
-}"
+{
+ return "mov.l 1f,r4" "\n"
+ " mova 2f,r0" "\n"
+ " mov.l 2f,r1" "\n"
+ " add r0,r1" "\n"
+ " jsr @r1" "\n"
+ " add r12,r4" "\n"
+ " bra 3f" "\n"
+ " nop" "\n"
+ " .align 2" "\n"
+ "1: .long %a1@TLSGD" "\n"
+ "2: .long __tls_get_addr@PLT" "\n"
+ "3:";
+}
[(set_attr "type" "tls_load")
(set_attr "length" "26")])
@@ -8999,22 +8881,20 @@ mov.l\\t1f,r4\\n\\
(clobber (reg:SI PR_REG))
(clobber (scratch:SI))]
"TARGET_SH1"
- "*
-{
- return \"\\
-mov.l\\t1f,r4\\n\\
-\\tmova\\t2f,r0\\n\\
-\\tmov.l\\t2f,r1\\n\\
-\\tadd\\tr0,r1\\n\\
-\\tjsr\\t@r1\\n\\
-\\tadd\\tr12,r4\\n\\
-\\tbra\\t3f\\n\\
-\\tnop\\n\\
-\\t.align\\t2\\n\\
-1:\\t.long\\t%a1@TLSLDM\\n\\
-2:\\t.long\\t__tls_get_addr@PLT\\n\\
-3:\";
-}"
+{
+ return "mov.l 1f,r4" "\n"
+ " mova 2f,r0" "\n"
+ " mov.l 2f,r1" "\n"
+ " add r0,r1" "\n"
+ " jsr @r1" "\n"
+ " add r12,r4" "\n"
+ " bra 3f" "\n"
+ " nop" "\n"
+ " .align 2" "\n"
+ "1: .long %a1@TLSLDM" "\n"
+ "2: .long __tls_get_addr@PLT" "\n"
+ "3:";
+}
[(set_attr "type" "tls_load")
(set_attr "length" "26")])
@@ -9026,7 +8906,6 @@ mov.l\\t1f,r4\\n\\
(define_expand "symDTPOFF2reg"
[(match_operand 0 "" "") (match_operand 1 "" "") (match_operand 2 "" "")]
""
- "
{
rtx dtpoffsym;
rtx t = (!can_create_pseudo_p ()
@@ -9038,7 +8917,7 @@ mov.l\\t1f,r4\\n\\
emit_move_insn (t, dtpoffsym);
emit_move_insn (operands[0], gen_rtx_PLUS (Pmode, t, operands[2]));
DONE;
-}")
+})
(define_expand "sym2GOTTPOFF"
[(const (unspec [(match_operand 0 "" "")] UNSPEC_GOTTPOFF))]
@@ -9053,18 +8932,16 @@ mov.l\\t1f,r4\\n\\
(use (reg:SI PIC_REG))
(clobber (reg:SI R0_REG))]
""
- "*
-{
- return \"\\
-mov.l\\t1f,r0\\n\\
-\\tstc\\tgbr,%0\\n\\
-\\tmov.l\\t@(r0,r12),r0\\n\\
-\\tbra\\t2f\\n\\
-\\tadd\\tr0,%0\\n\\
-\\t.align\\t2\\n\\
-1:\\t.long\\t%a1\\n\\
-2:\";
-}"
+{
+ return "mov.l 1f,r0" "\n"
+ " stc gbr,%0" "\n"
+ " mov.l @(r0,r12),r0" "\n"
+ " bra 2f" "\n"
+ " add r0,%0" "\n"
+ " .align 2" "\n"
+ "1: .long %a1" "\n"
+ "2:";
+}
[(set_attr "type" "tls_load")
(set_attr "length" "16")])
@@ -9076,7 +8953,6 @@ mov.l\\t1f,r0\\n\\
(define_expand "symTPOFF2reg"
[(match_operand 0 "" "") (match_operand 1 "" "")]
""
- "
{
rtx tpoffsym;
@@ -9084,7 +8960,7 @@ mov.l\\t1f,r0\\n\\
PUT_MODE (tpoffsym, Pmode);
emit_move_insn (operands[0], tpoffsym);
DONE;
-}")
+})
(define_insn "load_gbr"
[(set (match_operand:SI 0 "register_operand" "=r") (reg:SI GBR_REG))
@@ -9107,7 +8983,6 @@ mov.l\\t1f,r0\\n\\
(match_operand:SI 2 "arith_reg_operand" "")
(match_operand 3 "" "") (match_operand 4 "" "")]
""
- "
{
rtx reg = gen_reg_rtx (SImode);
rtx reg2 = gen_reg_rtx (SImode);
@@ -9163,7 +9038,7 @@ mov.l\\t1f,r0\\n\\
machine_dependent_reorg. */
emit_barrier ();
DONE;
-}")
+})
(define_expand "casesi_0"
[(set (match_operand:SI 4 "" "") (match_operand:SI 0 "arith_reg_operand" ""))
@@ -9206,7 +9081,10 @@ mov.l\\t1f,r0\\n\\
(label_ref (match_dup 2))] UNSPEC_CASESI))
(clobber (match_dup 3))])
(set (match_dup 0) (plus:SI (match_dup 0) (reg:SI R0_REG)))]
- "if (GET_CODE (operands[2]) == CODE_LABEL) LABEL_NUSES (operands[2])++;")
+{
+ if (GET_CODE (operands[2]) == CODE_LABEL)
+ LABEL_NUSES (operands[2])++;
+})
(define_split
[(set (match_operand:SI 0 "register_operand" "")
@@ -9220,7 +9098,10 @@ mov.l\\t1f,r0\\n\\
(unspec:SI [(reg:SI R0_REG) (match_dup 1)
(label_ref (match_dup 2))] UNSPEC_CASESI))
(clobber (match_dup 3))])]
- "if (GET_CODE (operands[2]) == CODE_LABEL) LABEL_NUSES (operands[2])++;")
+{
+ if (GET_CODE (operands[2]) == CODE_LABEL)
+ LABEL_NUSES (operands[2])++;
+})
(define_insn "casesi_worker_1"
[(set (match_operand:SI 0 "register_operand" "=r,r")
@@ -9229,7 +9110,6 @@ mov.l\\t1f,r0\\n\\
(label_ref (match_operand 2 "" ""))] UNSPEC_CASESI))
(clobber (match_scratch:SI 3 "=X,1"))]
"TARGET_SH1"
- "*
{
rtx diff_vec = PATTERN (next_real_insn (operands[2]));
@@ -9238,17 +9118,17 @@ mov.l\\t1f,r0\\n\\
switch (GET_MODE (diff_vec))
{
case SImode:
- return \"shll2 %1\;mov.l @(r0,%1),%0\";
+ return "shll2 %1\;mov.l @(r0,%1),%0";
case HImode:
- return \"add %1,%1\;mov.w @(r0,%1),%0\";
+ return "add %1,%1\;mov.w @(r0,%1),%0";
case QImode:
if (ADDR_DIFF_VEC_FLAGS (diff_vec).offset_unsigned)
- return \"mov.b @(r0,%1),%0\;extu.b %0,%0\";
- return \"mov.b @(r0,%1),%0\";
+ return "mov.b @(r0,%1),%0\;extu.b %0,%0";
+ return "mov.b @(r0,%1),%0";
default:
gcc_unreachable ();
}
-}"
+}
[(set_attr "length" "4")])
(define_insn "casesi_worker_2"
@@ -9259,7 +9139,6 @@ mov.l\\t1f,r0\\n\\
(label_ref (match_operand 3 "" ""))] UNSPEC_CASESI))
(clobber (match_operand:SI 4 "" "=X,1"))]
"TARGET_SH2 && reload_completed && flag_pic"
- "*
{
rtx diff_vec = PATTERN (next_real_insn (operands[2]));
const char *load;
@@ -9269,23 +9148,23 @@ mov.l\\t1f,r0\\n\\
switch (GET_MODE (diff_vec))
{
case SImode:
- output_asm_insn (\"shll2 %1\", operands);
- load = \"mov.l @(r0,%1),%0\"; break;
+ output_asm_insn ("shll2 %1", operands);
+ load = "mov.l @(r0,%1),%0"; break;
case HImode:
- output_asm_insn (\"add %1,%1\", operands);
- load = \"mov.w @(r0,%1),%0\"; break;
+ output_asm_insn ("add %1,%1", operands);
+ load = "mov.w @(r0,%1),%0"; break;
case QImode:
if (ADDR_DIFF_VEC_FLAGS (diff_vec).offset_unsigned)
- load = \"mov.b @(r0,%1),%0\;extu.b %0,%0\";
+ load = "mov.b @(r0,%1),%0\;extu.b %0,%0";
else
- load = \"mov.b @(r0,%1),%0\";
+ load = "mov.b @(r0,%1),%0";
break;
default:
gcc_unreachable ();
}
- output_asm_insn (\"add\tr0,%1\;mova\t%O3,r0\\n\", operands);
+ output_asm_insn ("add\tr0,%1\;mova\t%O3,r0\\n", operands);
return load;
-}"
+}
[(set_attr "length" "8")])
(define_insn "casesi_shift_media"
@@ -9294,7 +9173,6 @@ mov.l\\t1f,r0\\n\\
(unspec:DI [(label_ref:DI (match_operand 2 "" ""))]
UNSPEC_CASESI)))]
"TARGET_SHMEDIA"
- "*
{
rtx diff_vec = PATTERN (next_real_insn (operands[2]));
@@ -9303,17 +9181,17 @@ mov.l\\t1f,r0\\n\\
switch (GET_MODE (diff_vec))
{
case SImode:
- return \"shlli %1, 2, %0\";
+ return "shlli %1, 2, %0";
case HImode:
- return \"shlli %1, 1, %0\";
+ return "shlli %1, 1, %0";
case QImode:
if (rtx_equal_p (operands[0], operands[1]))
- return \"\";
- return \"add %1, r63, %0\";
+ return "";
+ return "add %1, r63, %0";
default:
gcc_unreachable ();
}
-}"
+}
[(set_attr "type" "arith_media")])
(define_insn "casesi_load_media"
@@ -9322,7 +9200,6 @@ mov.l\\t1f,r0\\n\\
(match_operand:DI 2 "arith_reg_operand" "r")
(label_ref:DI (match_operand 3 "" ""))] UNSPEC_CASESI)))]
"TARGET_SHMEDIA"
- "*
{
rtx diff_vec = PATTERN (next_real_insn (operands[3]));
@@ -9331,27 +9208,26 @@ mov.l\\t1f,r0\\n\\
switch (GET_MODE (diff_vec))
{
case SImode:
- return \"ldx.l %1, %2, %0\";
+ return "ldx.l %1, %2, %0";
case HImode:
#if 0
if (ADDR_DIFF_VEC_FLAGS (diff_vec).offset_unsigned)
- return \"ldx.uw %1, %2, %0\";
+ return "ldx.uw %1, %2, %0";
#endif
- return \"ldx.w %1, %2, %0\";
+ return "ldx.w %1, %2, %0";
case QImode:
if (ADDR_DIFF_VEC_FLAGS (diff_vec).offset_unsigned)
- return \"ldx.ub %1, %2, %0\";
- return \"ldx.b %1, %2, %0\";
+ return "ldx.ub %1, %2, %0";
+ return "ldx.b %1, %2, %0";
default:
gcc_unreachable ();
}
-}"
+}
[(set_attr "type" "load_media")])
(define_expand "return"
[(return)]
"reload_completed && ! sh_need_epilogue ()"
- "
{
if (TARGET_SHMEDIA)
{
@@ -9365,7 +9241,7 @@ mov.l\\t1f,r0\\n\\
emit_jump_insn (gen_shcompact_return_tramp ());
DONE;
}
-}")
+})
(define_insn "*return_i"
[(return)]
@@ -9375,14 +9251,13 @@ mov.l\\t1f,r0\\n\\
&& reload_completed
&& lookup_attribute (\"trap_exit\",
DECL_ATTRIBUTES (current_function_decl)) == NULL_TREE"
- "*
- {
- if (TARGET_SH2A && (dbr_sequence_length () == 0)
- && !current_function_interrupt)
- return \"rts/n\";
- else
- return \"%@ %#\";
- }"
+{
+ if (TARGET_SH2A && (dbr_sequence_length () == 0)
+ && !current_function_interrupt)
+ return "rts/n";
+ else
+ return "%@ %#";
+}
[(set_attr "type" "return")
(set_attr "needs_delay_slot" "yes")])
@@ -9398,14 +9273,13 @@ mov.l\\t1f,r0\\n\\
[(return)]
"TARGET_SHCOMPACT
&& (crtl->args.info.call_cookie & CALL_COOKIE_RET_TRAMP (1))"
- "
{
rtx reg = gen_rtx_REG (Pmode, R0_REG);
- function_symbol (reg, \"__GCC_shcompact_return_trampoline\", SFUNC_STATIC);
+ function_symbol (reg, "__GCC_shcompact_return_trampoline", SFUNC_STATIC);
emit_jump_insn (gen_shcompact_return_tramp_i ());
DONE;
-}")
+})
(define_insn "shcompact_return_tramp_i"
[(parallel [(return) (use (reg:SI R0_REG))])]
@@ -9430,7 +9304,6 @@ mov.l\\t1f,r0\\n\\
(define_expand "return_media"
[(return)]
"TARGET_SHMEDIA && reload_completed"
- "
{
int tr_regno = sh_media_register_for_return ();
rtx tr;
@@ -9454,7 +9327,7 @@ mov.l\\t1f,r0\\n\\
emit_jump_insn (gen_return_media_i (tr));
DONE;
-}")
+})
(define_insn "shcompact_preserve_incoming_args"
[(set (match_operand:SI 0 "register_operand" "+r")
@@ -9498,17 +9371,19 @@ mov.l\\t1f,r0\\n\\
(define_expand "prologue"
[(const_int 0)]
""
- "sh_expand_prologue (); DONE;")
+{
+ sh_expand_prologue ();
+ DONE;
+})
(define_expand "epilogue"
[(return)]
""
- "
{
sh_expand_epilogue (0);
emit_jump_insn (gen_return ());
DONE;
-}")
+})
(define_expand "eh_return"
[(use (match_operand 0 "register_operand" ""))]
@@ -9547,11 +9422,10 @@ mov.l\\t1f,r0\\n\\
(clobber (match_scratch 1 ""))]
"reload_completed"
[(const_int 0)]
- "
{
sh_set_return_address (operands[0], operands[1]);
DONE;
-}")
+})
(define_insn "blockage"
[(unspec_volatile [(const_int 0)] UNSPECV_BLOCKAGE)]
@@ -9616,7 +9490,6 @@ mov.l\\t1f,r0\\n\\
[(match_operand 2 "logical_operand" "")
(match_operand 3 "cmp_operand" "")]))]
"TARGET_SHMEDIA"
- "
{
enum machine_mode mode = GET_MODE (operands[2]);
enum rtx_code code = GET_CODE (operands[1]);
@@ -9686,7 +9559,7 @@ mov.l\\t1f,r0\\n\\
}
operands[1] = gen_rtx_fmt_ee (code, VOIDmode, operands[2], operands[3]);
-}")
+})
(define_expand "cstoresi4"
[(set (match_operand:SI 0 "register_operand" "=r")
@@ -9694,7 +9567,8 @@ mov.l\\t1f,r0\\n\\
[(match_operand:SI 2 "cmpsi_operand" "")
(match_operand:SI 3 "arith_operand" "")]))]
"TARGET_SH1 || TARGET_SHMEDIA"
- "if (TARGET_SHMEDIA)
+{
+ if (TARGET_SHMEDIA)
{
emit_insn (gen_cstore4_media (operands[0], operands[1],
operands[2], operands[3]));
@@ -9710,7 +9584,7 @@ mov.l\\t1f,r0\\n\\
sh_emit_compare_and_set (operands, SImode);
DONE;
-")
+})
(define_expand "cstoredi4"
[(set (match_operand:SI 0 "register_operand" "=r")
@@ -9718,7 +9592,8 @@ mov.l\\t1f,r0\\n\\
[(match_operand:DI 2 "arith_operand" "")
(match_operand:DI 3 "arith_operand" "")]))]
"TARGET_SH2 || TARGET_SHMEDIA"
- "if (TARGET_SHMEDIA)
+{
+ if (TARGET_SHMEDIA)
{
emit_insn (gen_cstore4_media (operands[0], operands[1],
operands[2], operands[3]));
@@ -9734,7 +9609,7 @@ mov.l\\t1f,r0\\n\\
sh_emit_compare_and_set (operands, DImode);
DONE;
-")
+})
;; Move the complement of the T reg to a reg.
;; On SH2A the movrt insn can be used.
@@ -9843,19 +9718,20 @@ mov.l\\t1f,r0\\n\\
[(match_operand:SF 2 "arith_operand" "")
(match_operand:SF 3 "arith_operand" "")]))]
"TARGET_SH2E || TARGET_SHMEDIA_FPU"
- "if (TARGET_SHMEDIA)
- {
- emit_insn (gen_cstore4_media (operands[0], operands[1],
- operands[2], operands[3]));
- DONE;
- }
+{
+ if (TARGET_SHMEDIA)
+ {
+ emit_insn (gen_cstore4_media (operands[0], operands[1],
+ operands[2], operands[3]));
+ DONE;
+ }
- if (! currently_expanding_to_rtl)
- FAIL;
+ if (! currently_expanding_to_rtl)
+ FAIL;
- sh_emit_compare_and_set (operands, SFmode);
- DONE;
-")
+ sh_emit_compare_and_set (operands, SFmode);
+ DONE;
+})
(define_expand "cstoredf4"
[(set (match_operand:SI 0 "register_operand" "=r")
@@ -9863,19 +9739,20 @@ mov.l\\t1f,r0\\n\\
[(match_operand:DF 2 "arith_operand" "")
(match_operand:DF 3 "arith_operand" "")]))]
"(TARGET_SH4 || TARGET_SH2A_DOUBLE) || TARGET_SHMEDIA_FPU"
- "if (TARGET_SHMEDIA)
- {
- emit_insn (gen_cstore4_media (operands[0], operands[1],
- operands[2], operands[3]));
- DONE;
- }
-
- if (! currently_expanding_to_rtl)
- FAIL;
+{
+ if (TARGET_SHMEDIA)
+ {
+ emit_insn (gen_cstore4_media (operands[0], operands[1],
+ operands[2], operands[3]));
+ DONE;
+ }
+
+ if (! currently_expanding_to_rtl)
+ FAIL;
- sh_emit_compare_and_set (operands, DFmode);
- DONE;
-")
+ sh_emit_compare_and_set (operands, DFmode);
+ DONE;
+})
;; -------------------------------------------------------------------------
;; Instructions to cope with inline literal tables
@@ -9888,12 +9765,11 @@ mov.l\\t1f,r0\\n\\
(match_operand 1 "" "")]
UNSPECV_CONST2)]
""
- "*
{
if (operands[1] != const0_rtx)
assemble_integer (operands[0], 2, BITS_PER_UNIT * 2, 1);
- return \"\";
-}"
+ return "";
+}
[(set_attr "length" "2")
(set_attr "in_delay_slot" "no")])
@@ -9904,15 +9780,14 @@ mov.l\\t1f,r0\\n\\
(match_operand 1 "" "")]
UNSPECV_CONST4)]
""
- "*
{
if (operands[1] != const0_rtx)
{
assemble_integer (operands[0], 4, BITS_PER_UNIT * 4, 1);
mark_symbol_refs_as_used (operands[0]);
}
- return \"\";
-}"
+ return "";
+}
[(set_attr "length" "4")
(set_attr "in_delay_slot" "no")])
@@ -9923,12 +9798,11 @@ mov.l\\t1f,r0\\n\\
(match_operand 1 "" "")]
UNSPECV_CONST8)]
""
- "*
{
if (operands[1] != const0_rtx)
assemble_integer (operands[0], 8, BITS_PER_UNIT * 8, 1);
- return \"\";
-}"
+ return "";
+}
[(set_attr "length" "8")
(set_attr "in_delay_slot" "no")])
@@ -9939,7 +9813,6 @@ mov.l\\t1f,r0\\n\\
(match_operand 1 "" "")]
UNSPECV_CONST4)]
""
- "*
{
if (operands[1] != const0_rtx)
{
@@ -9947,8 +9820,8 @@ mov.l\\t1f,r0\\n\\
REAL_VALUE_FROM_CONST_DOUBLE (d, operands[0]);
assemble_real (d, SFmode, GET_MODE_ALIGNMENT (SFmode));
}
- return \"\";
-}"
+ return "";
+}
[(set_attr "length" "4")
(set_attr "in_delay_slot" "no")])
@@ -9959,7 +9832,6 @@ mov.l\\t1f,r0\\n\\
(match_operand 1 "" "")]
UNSPECV_CONST8)]
""
- "*
{
if (operands[1] != const0_rtx)
{
@@ -9967,8 +9839,8 @@ mov.l\\t1f,r0\\n\\
REAL_VALUE_FROM_CONST_DOUBLE (d, operands[0]);
assemble_real (d, DFmode, GET_MODE_ALIGNMENT (DFmode));
}
- return \"\";
-}"
+ return "";
+}
[(set_attr "length" "8")
(set_attr "in_delay_slot" "no")])
@@ -10009,7 +9881,9 @@ mov.l\\t1f,r0\\n\\
(define_insn "consttable_end"
[(unspec_volatile [(const_int 0)] UNSPECV_CONST_END)]
""
- "* return output_jump_label_table ();"
+{
+ return output_jump_label_table ();
+}
[(set_attr "in_delay_slot" "no")])
; emitted at the end of the window in the literal table.
@@ -10037,12 +9911,11 @@ mov.l\\t1f,r0\\n\\
(clobber (reg:SI R5_REG))
(clobber (reg:SI R0_REG))])]
"TARGET_SH1 && ! TARGET_SH5"
- "
{
if(expand_block_move (operands))
DONE;
else FAIL;
-}")
+})
(define_insn "block_move_real"
[(parallel [(set (mem:BLK (reg:SI R4_REG))
@@ -10211,14 +10084,13 @@ mov.l\\t1f,r0\\n\\
(plus:SF (match_operand:SF 1 "arith_reg_operand" "")
(match_operand:SF 2 "arith_reg_operand" "")))]
"TARGET_SH2E || TARGET_SHMEDIA_FPU"
- "
{
if (TARGET_SH2E)
{
expand_sf_binop (&gen_addsf3_i, operands);
DONE;
}
-}")
+})
(define_insn "*addsf3_media"
[(set (match_operand:SF 0 "fp_arith_reg_operand" "=f")
@@ -10244,7 +10116,6 @@ mov.l\\t1f,r0\\n\\
"#"
"TARGET_SHMEDIA_FPU && reload_completed"
[(set (match_dup 5) (match_dup 6))]
- "
{
int endian = TARGET_LITTLE_ENDIAN ? 0 : 1;
rtx op1 = gen_rtx_REG (SFmode,
@@ -10255,7 +10126,7 @@ mov.l\\t1f,r0\\n\\
(true_regnum (operands[0])
+ (INTVAL (operands[3]) ^ endian)));
operands[6] = gen_rtx_fmt_e (GET_CODE (operands[2]), SFmode, op1);
-}"
+}
[(set_attr "type" "fparith_media")])
(define_insn_and_split "binary_sf_op0"
@@ -10273,7 +10144,6 @@ mov.l\\t1f,r0\\n\\
"#"
"&& reload_completed"
[(set (match_dup 4) (match_dup 5))]
- "
{
int endian = TARGET_LITTLE_ENDIAN ? 0 : 1;
rtx op1 = gen_rtx_REG (SFmode,
@@ -10284,7 +10154,7 @@ mov.l\\t1f,r0\\n\\
operands[4] = gen_rtx_REG (SFmode,
true_regnum (operands[0]) + endian);
operands[5] = gen_rtx_fmt_ee (GET_CODE (operands[3]), SFmode, op1, op2);
-}"
+}
[(set_attr "type" "fparith_media")])
(define_insn_and_split "binary_sf_op1"
@@ -10302,18 +10172,14 @@ mov.l\\t1f,r0\\n\\
"#"
"&& reload_completed"
[(set (match_dup 4) (match_dup 5))]
- "
{
int endian = TARGET_LITTLE_ENDIAN ? 0 : 1;
- rtx op1 = gen_rtx_REG (SFmode,
- true_regnum (operands[1]) + (1 ^ endian));
- rtx op2 = gen_rtx_REG (SFmode,
- true_regnum (operands[2]) + (1 ^ endian));
+ rtx op1 = gen_rtx_REG (SFmode, true_regnum (operands[1]) + (1 ^ endian));
+ rtx op2 = gen_rtx_REG (SFmode, true_regnum (operands[2]) + (1 ^ endian));
- operands[4] = gen_rtx_REG (SFmode,
- true_regnum (operands[0]) + (1 ^ endian));
+ operands[4] = gen_rtx_REG (SFmode, true_regnum (operands[0]) + (1 ^ endian));
operands[5] = gen_rtx_fmt_ee (GET_CODE (operands[3]), SFmode, op1, op2);
-}"
+}
[(set_attr "type" "fparith_media")])
(define_insn "addsf3_i"
@@ -10331,14 +10197,13 @@ mov.l\\t1f,r0\\n\\
(minus:SF (match_operand:SF 1 "fp_arith_reg_operand" "")
(match_operand:SF 2 "fp_arith_reg_operand" "")))]
"TARGET_SH2E || TARGET_SHMEDIA_FPU"
- "
{
if (TARGET_SH2E)
{
expand_sf_binop (&gen_subsf3_i, operands);
DONE;
}
-}")
+})
(define_insn "*subsf3_media"
[(set (match_operand:SF 0 "fp_arith_reg_operand" "=f")
@@ -10386,12 +10251,11 @@ mov.l\\t1f,r0\\n\\
"fmul %2,%0"
"TARGET_SH4 || TARGET_SH2A_SINGLE"
[(const_int 0)]
- "
{
emit_insn (gen_mulsf3_i4 (operands[0], operands[1], operands[2],
get_fpscr_rtx ()));
DONE;
-}"
+}
[(set_attr "type" "fp")])
(define_insn "mulsf3_i4"
@@ -10429,14 +10293,13 @@ mov.l\\t1f,r0\\n\\
(div:SF (match_operand:SF 1 "arith_reg_operand" "")
(match_operand:SF 2 "arith_reg_operand" "")))]
"TARGET_SH2E || TARGET_SHMEDIA_FPU"
- "
{
if (TARGET_SH2E)
{
expand_sf_binop (&gen_divsf3_i, operands);
DONE;
}
-}")
+})
(define_insn "*divsf3_media"
[(set (match_operand:SF 0 "fp_arith_reg_operand" "=f")
@@ -10467,14 +10330,13 @@ mov.l\\t1f,r0\\n\\
[(set (match_operand:SF 0 "fp_arith_reg_operand" "")
(float:SF (match_operand:SI 1 "fpul_operand" "")))]
"TARGET_SH2E || TARGET_SHMEDIA_FPU"
- "
{
if (TARGET_SH4 || TARGET_SH2A_SINGLE)
{
emit_sf_insn (gen_floatsisf2_i4 (operands[0], operands[1], get_fpscr_rtx ()));
DONE;
}
-}")
+})
(define_insn "*floatsisf2_media"
[(set (match_operand:SF 0 "fp_arith_reg_operand" "=f")
@@ -10510,14 +10372,13 @@ mov.l\\t1f,r0\\n\\
[(set (match_operand:SI 0 "fpul_operand" "=y")
(fix:SI (match_operand:SF 1 "fp_arith_reg_operand" "f")))]
"TARGET_SH2E || TARGET_SHMEDIA_FPU"
- "
{
if (TARGET_SH4 || TARGET_SH2A_SINGLE)
{
emit_sf_insn (gen_fix_truncsfsi2_i4 (operands[0], operands[1], get_fpscr_rtx ()));
DONE;
}
-}")
+})
(define_insn "*fix_truncsfsi2_media"
[(set (match_operand:SI 0 "fp_arith_reg_operand" "=f")
@@ -10588,7 +10449,9 @@ mov.l\\t1f,r0\\n\\
(eq:SI (match_operand:SF 0 "fp_arith_reg_operand" "f")
(match_operand:SF 1 "fp_arith_reg_operand" "f"))))]
"TARGET_SH2E && TARGET_IEEE && ! (TARGET_SH4 || TARGET_SH2A_SINGLE)"
- "* return output_ieee_ccmpeq (insn, operands);"
+{
+ return output_ieee_ccmpeq (insn, operands);
+}
[(set_attr "length" "4")])
@@ -10619,7 +10482,9 @@ mov.l\\t1f,r0\\n\\
(match_operand:SF 1 "fp_arith_reg_operand" "f"))))
(use (match_operand:PSI 2 "fpscr_operand" "c"))]
"TARGET_IEEE && (TARGET_SH4 || TARGET_SH2A_SINGLE)"
- "* return output_ieee_ccmpeq (insn, operands);"
+{
+ return output_ieee_ccmpeq (insn, operands);
+}
[(set_attr "length" "4")
(set_attr "fp_mode" "single")])
@@ -10663,7 +10528,6 @@ mov.l\\t1f,r0\\n\\
(match_operand 3 "" "")
(pc)))]
"TARGET_SH2E || TARGET_SHMEDIA_FPU"
- "
{
if (TARGET_SHMEDIA)
emit_jump_insn (gen_cbranchfp4_media (operands[0], operands[1], operands[2],
@@ -10671,20 +10535,19 @@ mov.l\\t1f,r0\\n\\
else
sh_emit_compare_and_branch (operands, SFmode);
DONE;
-}")
+})
(define_expand "negsf2"
[(set (match_operand:SF 0 "fp_arith_reg_operand" "")
(neg:SF (match_operand:SF 1 "fp_arith_reg_operand" "")))]
"TARGET_SH2E || TARGET_SHMEDIA_FPU"
- "
{
if (TARGET_SH2E)
{
expand_sf_unop (&gen_negsf2_i, operands);
DONE;
}
-}")
+})
(define_insn "*negsf2_media"
[(set (match_operand:SF 0 "fp_arith_reg_operand" "=f")
@@ -10706,14 +10569,13 @@ mov.l\\t1f,r0\\n\\
[(set (match_operand:SF 0 "fp_arith_reg_operand" "")
(sqrt:SF (match_operand:SF 1 "fp_arith_reg_operand" "")))]
"TARGET_SH3E || TARGET_SHMEDIA_FPU"
- "
{
if (TARGET_SH3E)
{
expand_sf_unop (&gen_sqrtsf2_i, operands);
DONE;
}
-}")
+})
(define_insn "*sqrtsf2_media"
[(set (match_operand:SF 0 "fp_arith_reg_operand" "=f")
@@ -10763,7 +10625,6 @@ mov.l\\t1f,r0\\n\\
(unspec:SF [(match_operand:SF 1 "fp_arith_reg_operand" "")]
UNSPEC_FSINA))]
"TARGET_SH4A_FP && flag_unsafe_math_optimizations"
- "
{
rtx scaled = gen_reg_rtx (SFmode);
rtx truncated = gen_reg_rtx (SImode);
@@ -10776,14 +10637,13 @@ mov.l\\t1f,r0\\n\\
get_fpscr_rtx ()));
emit_move_insn (operands[0], gen_rtx_SUBREG (SFmode, fsca, 0));
DONE;
-}")
+})
(define_expand "cossf2"
[(set (match_operand:SF 0 "nonimmediate_operand" "")
(unspec:SF [(match_operand:SF 1 "fp_arith_reg_operand" "")]
UNSPEC_FCOSA))]
"TARGET_SH4A_FP && flag_unsafe_math_optimizations"
- "
{
rtx scaled = gen_reg_rtx (SFmode);
rtx truncated = gen_reg_rtx (SImode);
@@ -10796,14 +10656,13 @@ mov.l\\t1f,r0\\n\\
get_fpscr_rtx ()));
emit_move_insn (operands[0], gen_rtx_SUBREG (SFmode, fsca, 4));
DONE;
-}")
+})
(define_expand "sindf2"
[(set (match_operand:DF 0 "fp_arith_reg_operand" "")
(unspec:DF [(match_operand:DF 1 "fp_arith_reg_operand" "")]
UNSPEC_FSINA))]
"TARGET_SH4A_FP && ! TARGET_FPU_SINGLE && flag_unsafe_math_optimizations"
- "
{
rtx scaled = gen_reg_rtx (DFmode);
rtx truncated = gen_reg_rtx (SImode);
@@ -10818,14 +10677,13 @@ mov.l\\t1f,r0\\n\\
emit_move_insn (sfresult, gen_rtx_SUBREG (SFmode, fsca, 0));
emit_df_insn (gen_extendsfdf2 (operands[0], sfresult));
DONE;
-}")
+})
(define_expand "cosdf2"
[(set (match_operand:DF 0 "fp_arith_reg_operand" "")
(unspec:DF [(match_operand:DF 1 "fp_arith_reg_operand" "")]
UNSPEC_FCOSA))]
"TARGET_SH4A_FP && ! TARGET_FPU_SINGLE && flag_unsafe_math_optimizations"
- "
{
rtx scaled = gen_reg_rtx (DFmode);
rtx truncated = gen_reg_rtx (SImode);
@@ -10840,20 +10698,19 @@ mov.l\\t1f,r0\\n\\
emit_move_insn (sfresult, gen_rtx_SUBREG (SFmode, fsca, 4));
emit_df_insn (gen_extendsfdf2 (operands[0], sfresult));
DONE;
-}")
+})
(define_expand "abssf2"
[(set (match_operand:SF 0 "fp_arith_reg_operand" "")
(abs:SF (match_operand:SF 1 "fp_arith_reg_operand" "")))]
"TARGET_SH2E || TARGET_SHMEDIA_FPU"
- "
{
if (TARGET_SH2E)
{
expand_sf_unop (&gen_abssf2_i, operands);
DONE;
}
-}")
+})
(define_insn "*abssf2_media"
[(set (match_operand:SF 0 "fp_arith_reg_operand" "=f")
@@ -10876,14 +10733,13 @@ mov.l\\t1f,r0\\n\\
(plus:DF (match_operand:DF 1 "fp_arith_reg_operand" "")
(match_operand:DF 2 "fp_arith_reg_operand" "")))]
"(TARGET_SH4 || TARGET_SH2A_DOUBLE) || TARGET_SHMEDIA_FPU"
- "
{
if (TARGET_SH4 || TARGET_SH2A_DOUBLE)
{
expand_df_binop (&gen_adddf3_i, operands);
DONE;
}
-}")
+})
(define_insn "*adddf3_media"
[(set (match_operand:DF 0 "fp_arith_reg_operand" "=f")
@@ -10908,14 +10764,13 @@ mov.l\\t1f,r0\\n\\
(minus:DF (match_operand:DF 1 "fp_arith_reg_operand" "")
(match_operand:DF 2 "fp_arith_reg_operand" "")))]
"(TARGET_SH4 || TARGET_SH2A_DOUBLE) || TARGET_SHMEDIA_FPU"
- "
{
if (TARGET_SH4 || TARGET_SH2A_DOUBLE)
{
expand_df_binop (&gen_subdf3_i, operands);
DONE;
}
-}")
+})
(define_insn "*subdf3_media"
[(set (match_operand:DF 0 "fp_arith_reg_operand" "=f")
@@ -10940,14 +10795,13 @@ mov.l\\t1f,r0\\n\\
(mult:DF (match_operand:DF 1 "fp_arith_reg_operand" "")
(match_operand:DF 2 "fp_arith_reg_operand" "")))]
"(TARGET_SH4 || TARGET_SH2A_DOUBLE) || TARGET_SHMEDIA_FPU"
- "
{
if (TARGET_SH4 || TARGET_SH2A_DOUBLE)
{
expand_df_binop (&gen_muldf3_i, operands);
DONE;
}
-}")
+})
(define_insn "*muldf3_media"
[(set (match_operand:DF 0 "fp_arith_reg_operand" "=f")
@@ -10972,14 +10826,13 @@ mov.l\\t1f,r0\\n\\
(div:DF (match_operand:DF 1 "fp_arith_reg_operand" "")
(match_operand:DF 2 "fp_arith_reg_operand" "")))]
"(TARGET_SH4 || TARGET_SH2A_DOUBLE) || TARGET_SHMEDIA_FPU"
- "
{
if (TARGET_SH4 || TARGET_SH2A_DOUBLE)
{
expand_df_binop (&gen_divdf3_i, operands);
DONE;
}
-}")
+})
(define_insn "*divdf3_media"
[(set (match_operand:DF 0 "fp_arith_reg_operand" "=f")
@@ -11010,7 +10863,6 @@ mov.l\\t1f,r0\\n\\
[(set (match_operand:DF 0 "fp_arith_reg_operand" "")
(float:DF (match_operand:SI 1 "fpul_operand" "")))]
"(TARGET_SH4 || TARGET_SH2A_DOUBLE) || TARGET_SHMEDIA_FPU"
- "
{
if (TARGET_SH4 || TARGET_SH2A_DOUBLE)
{
@@ -11018,7 +10870,7 @@ mov.l\\t1f,r0\\n\\
get_fpscr_rtx ()));
DONE;
}
-}")
+})
(define_insn "*floatsidf2_media"
[(set (match_operand:DF 0 "fp_arith_reg_operand" "=f")
@@ -11047,7 +10899,6 @@ mov.l\\t1f,r0\\n\\
[(set (match_operand:SI 0 "fpul_operand" "")
(fix:SI (match_operand:DF 1 "fp_arith_reg_operand" "")))]
"(TARGET_SH4 || TARGET_SH2A_DOUBLE) || TARGET_SHMEDIA_FPU"
- "
{
if (TARGET_SH4 || TARGET_SH2A_DOUBLE)
{
@@ -11055,7 +10906,7 @@ mov.l\\t1f,r0\\n\\
get_fpscr_rtx ()));
DONE;
}
-}")
+})
(define_insn "*fix_truncdfsi2_media"
[(set (match_operand:SI 0 "fp_arith_reg_operand" "=f")
@@ -11123,7 +10974,9 @@ mov.l\\t1f,r0\\n\\
(match_operand:DF 1 "arith_reg_operand" "f"))))
(use (match_operand:PSI 2 "fpscr_operand" "c"))]
"TARGET_IEEE && (TARGET_SH4 || TARGET_SH2A_DOUBLE)"
- "* return output_ieee_ccmpeq (insn, operands);"
+{
+ return output_ieee_ccmpeq (insn, operands);
+}
[(set_attr "length" "4")
(set_attr "fp_mode" "double")])
@@ -11167,7 +11020,6 @@ mov.l\\t1f,r0\\n\\
(match_operand 3 "" "")
(pc)))]
"(TARGET_SH4 || TARGET_SH2A_DOUBLE) || TARGET_SHMEDIA_FPU"
- "
{
if (TARGET_SHMEDIA)
emit_jump_insn (gen_cbranchfp4_media (operands[0], operands[1], operands[2],
@@ -11175,21 +11027,20 @@ mov.l\\t1f,r0\\n\\
else
sh_emit_compare_and_branch (operands, DFmode);
DONE;
-}")
+})
(define_expand "negdf2"
[(set (match_operand:DF 0 "arith_reg_operand" "")
(neg:DF (match_operand:DF 1 "arith_reg_operand" "")))]
"(TARGET_SH4 || TARGET_SH2A_DOUBLE) || TARGET_SHMEDIA_FPU"
- "
{
if (TARGET_SH4 || TARGET_SH2A_DOUBLE)
{
expand_df_unop (&gen_negdf2_i, operands);
DONE;
}
-}")
+})
(define_insn "*negdf2_media"
[(set (match_operand:DF 0 "fp_arith_reg_operand" "=f")
@@ -11211,14 +11062,13 @@ mov.l\\t1f,r0\\n\\
[(set (match_operand:DF 0 "arith_reg_operand" "")
(sqrt:DF (match_operand:DF 1 "arith_reg_operand" "")))]
"(TARGET_SH4 || TARGET_SH2A_DOUBLE) || TARGET_SHMEDIA_FPU"
- "
{
if (TARGET_SH4 || TARGET_SH2A_DOUBLE)
{
expand_df_unop (&gen_sqrtdf2_i, operands);
DONE;
}
-}")
+})
(define_insn "*sqrtdf2_media"
[(set (match_operand:DF 0 "fp_arith_reg_operand" "=f")
@@ -11240,14 +11090,13 @@ mov.l\\t1f,r0\\n\\
[(set (match_operand:DF 0 "arith_reg_operand" "")
(abs:DF (match_operand:DF 1 "arith_reg_operand" "")))]
"(TARGET_SH4 || TARGET_SH2A_DOUBLE) || TARGET_SHMEDIA_FPU"
- "
{
if (TARGET_SH4 || TARGET_SH2A_DOUBLE)
{
expand_df_unop (&gen_absdf2_i, operands);
DONE;
}
-}")
+})
(define_insn "*absdf2_media"
[(set (match_operand:DF 0 "fp_arith_reg_operand" "=f")
@@ -11269,7 +11118,6 @@ mov.l\\t1f,r0\\n\\
[(set (match_operand:DF 0 "fp_arith_reg_operand" "")
(float_extend:DF (match_operand:SF 1 "fpul_operand" "")))]
"(TARGET_SH4 || TARGET_SH2A_DOUBLE) || TARGET_SHMEDIA_FPU"
- "
{
if (TARGET_SH4 || TARGET_SH2A_DOUBLE)
{
@@ -11277,7 +11125,7 @@ mov.l\\t1f,r0\\n\\
get_fpscr_rtx ()));
DONE;
}
-}")
+})
(define_insn "*extendsfdf2_media"
[(set (match_operand:DF 0 "fp_arith_reg_operand" "=f")
@@ -11299,7 +11147,6 @@ mov.l\\t1f,r0\\n\\
[(set (match_operand:SF 0 "fpul_operand" "")
(float_truncate:SF (match_operand:DF 1 "fp_arith_reg_operand" "")))]
"(TARGET_SH4 || TARGET_SH2A_DOUBLE) || TARGET_SHMEDIA_FPU"
- "
{
if (TARGET_SH4 || TARGET_SH2A_DOUBLE)
{
@@ -11307,7 +11154,7 @@ mov.l\\t1f,r0\\n\\
get_fpscr_rtx ()));
DONE;
}
-}")
+})
(define_insn "*truncdfsf2_media"
[(set (match_operand:SF 0 "fp_arith_reg_operand" "=f")
@@ -11334,7 +11181,6 @@ mov.l\\t1f,r0\\n\\
(match_operand:SI 2 "immediate_operand" ""))
(match_operand:SI 3 "general_operand" ""))]
"TARGET_SH1 && ! TARGET_LITTLE_ENDIAN"
- "
{
rtx addr_target, orig_address, shift_reg, qi_val;
HOST_WIDE_INT bitsize, size, v = 0;
@@ -11416,7 +11262,7 @@ mov.l\\t1f,r0\\n\\
}
DONE;
-}")
+})
(define_insn "movua"
[(set (match_operand:SI 0 "register_operand" "=z")
@@ -11950,12 +11796,11 @@ mov.l\\t1f,r0\\n\\
(define_insn "sp_switch_1"
[(const_int 1) (match_operand:SI 0 "symbol_ref_operand" "s")]
"TARGET_SH1"
- "*
{
- output_asm_insn (\"mov.l r0,@-r15\;mov.l %0,r0\", operands);
- output_asm_insn (\"mov.l @r0,r0\;mov.l r15,@-r0\", operands);
- return \"mov r0,r15\";
-}"
+ output_asm_insn ("mov.l r0,@-r15\;mov.l %0,r0", operands);
+ output_asm_insn ("mov.l @r0,r0\;mov.l r15,@-r0", operands);
+ return "mov r0,r15";
+}
[(set_attr "length" "10")])
;; Switch back to the original stack for interrupt functions with the
@@ -11972,7 +11817,10 @@ mov.l\\t1f,r0\\n\\
[(set (match_operand:V8QI 0 "general_movdst_operand" "")
(match_operand:V8QI 1 "general_movsrc_operand" ""))]
"TARGET_SHMEDIA"
- "{ if (prepare_move_operands (operands, V8QImode)) DONE; }")
+{
+ if (prepare_move_operands (operands, V8QImode))
+ DONE;
+})
(define_insn "movv8qi_i"
[(set (match_operand:V8QI 0 "general_movdst_operand" "=r,r,r,rl,m")
@@ -12011,7 +11859,6 @@ mov.l\\t1f,r0\\n\\
|| XVECEXP (operands[1], 0, 1) != constm1_rtx)"
[(set (match_dup 0) (match_dup 1))
(match_dup 2)]
- "
{
int unit_size = GET_MODE_UNIT_SIZE (GET_MODE (operands[1]));
rtx elt1 = XVECEXP (operands[1], 0, 1);
@@ -12040,7 +11887,7 @@ mov.l\\t1f,r0\\n\\
= gen_rtx_PARALLEL (VOIDmode, gen_rtvec (2, operands[1], elt1));
}
}
-}")
+})
(define_split
[(set (match_operand 0 "arith_reg_dest" "")
@@ -12049,7 +11896,6 @@ mov.l\\t1f,r0\\n\\
&& GET_MODE (operands[0]) == GET_MODE (operands[1])
&& sh_vector_mode_supported_p (GET_MODE (operands[0]))"
[(set (match_dup 0) (match_dup 1))]
- "
{
rtx v = operands[1];
enum machine_mode new_mode
@@ -12058,13 +11904,16 @@ mov.l\\t1f,r0\\n\\
operands[0] = gen_rtx_REG (new_mode, true_regnum (operands[0]));
operands[1]
= simplify_subreg (new_mode, operands[1], GET_MODE (operands[1]), 0);
-}")
+})
(define_expand "movv2hi"
[(set (match_operand:V2HI 0 "general_movdst_operand" "")
(match_operand:V2HI 1 "general_movsrc_operand" ""))]
"TARGET_SHMEDIA"
- "{ if (prepare_move_operands (operands, V2HImode)) DONE; }")
+{
+ if (prepare_move_operands (operands, V2HImode))
+ DONE;
+})
(define_insn "movv2hi_i"
[(set (match_operand:V2HI 0 "general_movdst_operand" "=r,r,r,rl,m")
@@ -12089,7 +11938,10 @@ mov.l\\t1f,r0\\n\\
[(set (match_operand:V4HI 0 "general_movdst_operand" "")
(match_operand:V4HI 1 "general_movsrc_operand" ""))]
"TARGET_SHMEDIA"
- "{ if (prepare_move_operands (operands, V4HImode)) DONE; }")
+{
+ if (prepare_move_operands (operands, V4HImode))
+ DONE;
+})
(define_insn "movv4hi_i"
[(set (match_operand:V4HI 0 "general_movdst_operand" "=r,r,r,rl,m")
@@ -12111,7 +11963,10 @@ mov.l\\t1f,r0\\n\\
[(set (match_operand:V2SI 0 "general_movdst_operand" "")
(match_operand:V2SI 1 "general_movsrc_operand" ""))]
"TARGET_SHMEDIA"
- "{ if (prepare_move_operands (operands, V2SImode)) DONE; }")
+{
+ if (prepare_move_operands (operands, V2SImode))
+ DONE;
+})
(define_insn "movv2si_i"
[(set (match_operand:V2SI 0 "general_movdst_operand" "=r,r,r,rl,m")
@@ -12173,7 +12028,6 @@ mov.l\\t1f,r0\\n\\
"#"
"TARGET_SHMEDIA"
[(const_int 0)]
- "
{
rtx src0 = simplify_gen_subreg (V4HImode, operands[1], V2HImode, 0);
rtx src1 = simplify_gen_subreg (V4HImode, operands[2], V2HImode, 0);
@@ -12184,7 +12038,7 @@ mov.l\\t1f,r0\\n\\
emit_insn (gen_addv4hi3 (v4hi_dst, src0, src1));
emit_insn (gen_truncdisi2 (si_dst, di_dst));
DONE;
-}"
+}
[(set_attr "highpart" "must_split")])
(define_insn "ssaddv2si3"
@@ -12313,14 +12167,11 @@ mov.l\\t1f,r0\\n\\
(ashift:DI (match_operand:DI 2 "arith_reg_or_0_operand" "rZ")
(match_operand:HI 4 "mextr_bit_offset" "i"))))]
"TARGET_SHMEDIA && INTVAL (operands[3]) + INTVAL (operands[4]) == 64"
- "*
{
static char templ[21];
-
- sprintf (templ, \"mextr%d\\t%%N1, %%N2, %%0\",
- (int) INTVAL (operands[3]) >> 3);
+ sprintf (templ, "mextr%d\\t%%N1, %%N2, %%0", (int) INTVAL (operands[3]) >> 3);
return templ;
-}"
+}
[(set_attr "type" "arith_media")])
(define_insn "*mextr_lr"
@@ -12330,14 +12181,11 @@ mov.l\\t1f,r0\\n\\
(lshiftrt:DI (match_operand:DI 2 "arith_reg_or_0_operand" "rZ")
(match_operand:HI 4 "mextr_bit_offset" "i"))))]
"TARGET_SHMEDIA && INTVAL (operands[3]) + INTVAL (operands[4]) == 64"
- "*
{
static char templ[21];
-
- sprintf (templ, \"mextr%d\\t%%N2, %%N1, %%0\",
- (int) INTVAL (operands[4]) >> 3);
+ sprintf (templ, "mextr%d\\t%%N2, %%N1, %%0", (int) INTVAL (operands[4]) >> 3);
return templ;
-}"
+}
[(set_attr "type" "arith_media")])
; mextrN can be modelled with vec_select / vec_concat, but the selection
@@ -12347,84 +12195,77 @@ mov.l\\t1f,r0\\n\\
(match_operand:DI 1 "arith_reg_or_0_operand" "rZ")
(match_operand:DI 2 "arith_reg_or_0_operand" "rZ")]
"TARGET_SHMEDIA"
- "
{
emit_insn (gen_mextr_rl (operands[0], operands[1], operands[2],
GEN_INT (1 * 8), GEN_INT (7 * 8)));
DONE;
-}")
+})
(define_expand "mextr2"
[(match_operand:DI 0 "arith_reg_dest" "")
(match_operand:DI 1 "arith_reg_or_0_operand" "rZ")
(match_operand:DI 2 "arith_reg_or_0_operand" "rZ")]
"TARGET_SHMEDIA"
- "
{
emit_insn (gen_mextr_rl (operands[0], operands[1], operands[2],
GEN_INT (2 * 8), GEN_INT (6 * 8)));
DONE;
-}")
+})
(define_expand "mextr3"
[(match_operand:DI 0 "arith_reg_dest" "")
(match_operand:DI 1 "arith_reg_or_0_operand" "rZ")
(match_operand:DI 2 "arith_reg_or_0_operand" "rZ")]
"TARGET_SHMEDIA"
- "
{
emit_insn (gen_mextr_rl (operands[0], operands[1], operands[2],
GEN_INT (3 * 8), GEN_INT (5 * 8)));
DONE;
-}")
+})
(define_expand "mextr4"
[(match_operand:DI 0 "arith_reg_dest" "")
(match_operand:DI 1 "arith_reg_or_0_operand" "rZ")
(match_operand:DI 2 "arith_reg_or_0_operand" "rZ")]
"TARGET_SHMEDIA"
- "
{
emit_insn (gen_mextr_rl (operands[0], operands[1], operands[2],
GEN_INT (4 * 8), GEN_INT (4 * 8)));
DONE;
-}")
+})
(define_expand "mextr5"
[(match_operand:DI 0 "arith_reg_dest" "")
(match_operand:DI 1 "arith_reg_or_0_operand" "rZ")
(match_operand:DI 2 "arith_reg_or_0_operand" "rZ")]
"TARGET_SHMEDIA"
- "
{
emit_insn (gen_mextr_rl (operands[0], operands[1], operands[2],
GEN_INT (5 * 8), GEN_INT (3 * 8)));
DONE;
-}")
+})
(define_expand "mextr6"
[(match_operand:DI 0 "arith_reg_dest" "")
(match_operand:DI 1 "arith_reg_or_0_operand" "rZ")
(match_operand:DI 2 "arith_reg_or_0_operand" "rZ")]
"TARGET_SHMEDIA"
- "
{
emit_insn (gen_mextr_rl (operands[0], operands[1], operands[2],
GEN_INT (6 * 8), GEN_INT (2 * 8)));
DONE;
-}")
+})
(define_expand "mextr7"
[(match_operand:DI 0 "arith_reg_dest" "")
(match_operand:DI 1 "arith_reg_or_0_operand" "rZ")
(match_operand:DI 2 "arith_reg_or_0_operand" "rZ")]
"TARGET_SHMEDIA"
- "
{
emit_insn (gen_mextr_rl (operands[0], operands[1], operands[2],
GEN_INT (7 * 8), GEN_INT (1 * 8)));
DONE;
-}")
+})
(define_expand "mmacfx_wl"
[(match_operand:V2SI 0 "arith_reg_dest" "")
@@ -12432,12 +12273,11 @@ mov.l\\t1f,r0\\n\\
(match_operand:V2HI 2 "extend_reg_operand" "")
(match_operand:V2SI 3 "arith_reg_operand" "")]
"TARGET_SHMEDIA"
- "
{
emit_insn (gen_mmacfx_wl_i (operands[0], operands[3],
operands[1], operands[2]));
DONE;
-}")
+})
;; This could be highpart ignore if it only had inputs 2 or 3, but input 1
;; is depend
@@ -12463,12 +12303,11 @@ mov.l\\t1f,r0\\n\\
(match_operand:V2HI 2 "extend_reg_operand" "")
(match_operand:V2SI 3 "arith_reg_operand" "")]
"TARGET_SHMEDIA"
- "
{
emit_insn (gen_mmacnfx_wl_i (operands[0], operands[3],
operands[1], operands[2]));
DONE;
-}")
+})
(define_insn "mmacnfx_wl_i"
[(set (match_operand:V2SI 0 "arith_reg_dest" "=r")
@@ -12551,24 +12390,22 @@ mov.l\\t1f,r0\\n\\
(match_operand:V4HI 1 "arith_reg_operand" "")
(match_operand:V4HI 2 "arith_reg_operand" "")]
"TARGET_SHMEDIA"
- "
{
emit_insn ((TARGET_LITTLE_ENDIAN ? gen_mmul23_wl : gen_mmul01_wl)
(operands[0], operands[1], operands[2]));
DONE;
-}")
+})
(define_expand "mmullo_wl"
[(match_operand:V2SI 0 "arith_reg_dest" "")
(match_operand:V4HI 1 "arith_reg_operand" "")
(match_operand:V4HI 2 "arith_reg_operand" "")]
"TARGET_SHMEDIA"
- "
{
emit_insn ((TARGET_LITTLE_ENDIAN ? gen_mmul01_wl : gen_mmul23_wl)
(operands[0], operands[1], operands[2]));
DONE;
-}")
+})
(define_insn "mmul23_wl"
[(set (match_operand:V2SI 0 "arith_reg_dest" "=r")
@@ -12578,9 +12415,11 @@ mov.l\\t1f,r0\\n\\
(sign_extend:V4SI (match_operand:V4HI 2 "arith_reg_operand" "r")))
(parallel [(const_int 2) (const_int 3)])))]
"TARGET_SHMEDIA"
- "* return (TARGET_LITTLE_ENDIAN
- ? \"mmulhi.wl %1, %2, %0\"
- : \"mmullo.wl %1, %2, %0\");"
+{
+ return (TARGET_LITTLE_ENDIAN
+ ? "mmulhi.wl %1, %2, %0"
+ : "mmullo.wl %1, %2, %0");
+}
[(set_attr "type" "dmpy_media")
(set (attr "highpart")
(cond [(eq_attr "endian" "big") (const_string "ignore")]
@@ -12594,9 +12433,11 @@ mov.l\\t1f,r0\\n\\
(sign_extend:V4SI (match_operand:V4HI 2 "arith_reg_operand" "r")))
(parallel [(const_int 0) (const_int 1)])))]
"TARGET_SHMEDIA"
- "* return (TARGET_LITTLE_ENDIAN
- ? \"mmullo.wl %1, %2, %0\"
- : \"mmulhi.wl %1, %2, %0\");"
+{
+ return (TARGET_LITTLE_ENDIAN
+ ? "mmullo.wl %1, %2, %0"
+ : "mmulhi.wl %1, %2, %0");
+}
[(set_attr "type" "dmpy_media")
(set (attr "highpart")
(cond [(eq_attr "endian" "little") (const_string "ignore")]
@@ -12609,12 +12450,11 @@ mov.l\\t1f,r0\\n\\
(match_operand:V4HI 2 "arith_reg_operand" "")
(match_operand:DI 3 "arith_reg_operand" "")]
"TARGET_SHMEDIA"
- "
{
emit_insn (gen_mmulsum_wq_i (operands[0], operands[3],
operands[1], operands[2]));
DONE;
-}")
+})
(define_insn "mmulsum_wq_i"
[(set (match_operand:DI 0 "arith_reg_dest" "=r")
@@ -12645,12 +12485,11 @@ mov.l\\t1f,r0\\n\\
(match_operand:V4HI 1 "arith_reg_operand" "r")
(match_operand:QI 2 "extend_reg_or_0_operand" "rZ")]
"TARGET_SHMEDIA"
- "
{
emit_insn ((TARGET_LITTLE_ENDIAN ? gen_mperm_w_little : gen_mperm_w_big)
(operands[0], operands[1], operands[2]));
DONE;
-}")
+})
; This use of vec_select isn't exactly correct according to rtl.texi
; (because not constant), but it seems a straightforward extension.
@@ -12699,12 +12538,11 @@ mov.l\\t1f,r0\\n\\
(match_operand:V8QI 2 "arith_reg_or_0_operand" "")
(match_operand:DI 3 "arith_reg_operand" "")]
"TARGET_SHMEDIA"
- "
{
emit_insn (gen_msad_ubq_i (operands[0], operands[3],
operands[1], operands[2]));
DONE;
-}")
+})
(define_insn "msad_ubq_i"
[(set (match_operand:DI 0 "arith_reg_dest" "=r")
@@ -12805,24 +12643,22 @@ mov.l\\t1f,r0\\n\\
(match_operand:V8QI 1 "arith_reg_or_0_operand" "rZ")
(match_operand:V8QI 2 "arith_reg_or_0_operand" "rZ")]
"TARGET_SHMEDIA"
- "
{
emit_insn ((TARGET_LITTLE_ENDIAN ? gen_mshf4_b : gen_mshf0_b)
(operands[0], operands[1], operands[2]));
DONE;
-}")
+})
(define_expand "mshflo_b"
[(match_operand:V8QI 0 "arith_reg_dest" "")
(match_operand:V8QI 1 "arith_reg_or_0_operand" "rZ")
(match_operand:V8QI 2 "arith_reg_or_0_operand" "rZ")]
"TARGET_SHMEDIA"
- "
{
emit_insn ((TARGET_LITTLE_ENDIAN ? gen_mshf0_b : gen_mshf4_b)
(operands[0], operands[1], operands[2]));
DONE;
-}")
+})
(define_insn "mshf4_b"
[(set
@@ -12833,9 +12669,11 @@ mov.l\\t1f,r0\\n\\
(parallel [(const_int 4) (const_int 12) (const_int 5) (const_int 13)
(const_int 6) (const_int 14) (const_int 7) (const_int 15)])))]
"TARGET_SHMEDIA"
- "* return (TARGET_LITTLE_ENDIAN
- ? \"mshfhi.b %N1, %N2, %0\"
- : \"mshflo.b %N1, %N2, %0\");"
+{
+ return (TARGET_LITTLE_ENDIAN
+ ? "mshfhi.b %N1, %N2, %0"
+ : "mshflo.b %N1, %N2, %0");
+}
[(set_attr "type" "arith_media")
(set (attr "highpart")
(cond [(eq_attr "endian" "big") (const_string "ignore")]
@@ -12850,9 +12688,11 @@ mov.l\\t1f,r0\\n\\
(parallel [(const_int 0) (const_int 8) (const_int 1) (const_int 9)
(const_int 2) (const_int 10) (const_int 3) (const_int 11)])))]
"TARGET_SHMEDIA"
- "* return (TARGET_LITTLE_ENDIAN
- ? \"mshflo.b %N1, %N2, %0\"
- : \"mshfhi.b %N1, %N2, %0\");"
+{
+ return (TARGET_LITTLE_ENDIAN
+ ? "mshflo.b %N1, %N2, %0"
+ : "mshfhi.b %N1, %N2, %0");
+}
[(set_attr "type" "arith_media")
(set (attr "highpart")
(cond [(eq_attr "endian" "little") (const_string "ignore")]
@@ -12863,24 +12703,22 @@ mov.l\\t1f,r0\\n\\
(match_operand:V2SI 1 "arith_reg_or_0_operand" "rZ")
(match_operand:V2SI 2 "arith_reg_or_0_operand" "rZ")]
"TARGET_SHMEDIA"
- "
{
emit_insn ((TARGET_LITTLE_ENDIAN ? gen_mshf4_l : gen_mshf0_l)
(operands[0], operands[1], operands[2]));
DONE;
-}")
+})
(define_expand "mshflo_l"
[(match_operand:V2SI 0 "arith_reg_dest" "")
(match_operand:V2SI 1 "arith_reg_or_0_operand" "rZ")
(match_operand:V2SI 2 "arith_reg_or_0_operand" "rZ")]
"TARGET_SHMEDIA"
- "
{
emit_insn ((TARGET_LITTLE_ENDIAN ? gen_mshf0_l : gen_mshf4_l)
(operands[0], operands[1], operands[2]));
DONE;
-}")
+})
(define_insn "mshf4_l"
[(set (match_operand:V2SI 0 "arith_reg_dest" "=r")
@@ -12889,9 +12727,11 @@ mov.l\\t1f,r0\\n\\
(match_operand:V2SI 2 "arith_reg_or_0_operand" "rZ"))
(parallel [(const_int 1) (const_int 3)])))]
"TARGET_SHMEDIA"
- "* return (TARGET_LITTLE_ENDIAN
- ? \"mshfhi.l %N1, %N2, %0\"
- : \"mshflo.l %N1, %N2, %0\");"
+{
+ return (TARGET_LITTLE_ENDIAN
+ ? "mshfhi.l %N1, %N2, %0"
+ : "mshflo.l %N1, %N2, %0");
+}
[(set_attr "type" "arith_media")
(set (attr "highpart")
(cond [(eq_attr "endian" "big") (const_string "ignore")]
@@ -12904,9 +12744,11 @@ mov.l\\t1f,r0\\n\\
(match_operand:V2SI 2 "arith_reg_or_0_operand" "rZ"))
(parallel [(const_int 0) (const_int 2)])))]
"TARGET_SHMEDIA"
- "* return (TARGET_LITTLE_ENDIAN
- ? \"mshflo.l %N1, %N2, %0\"
- : \"mshfhi.l %N1, %N2, %0\");"
+{
+ return (TARGET_LITTLE_ENDIAN
+ ? "mshflo.l %N1, %N2, %0"
+ : "mshfhi.l %N1, %N2, %0");
+}
[(set_attr "type" "arith_media")
(set (attr "highpart")
(cond [(eq_attr "endian" "little") (const_string "ignore")]
@@ -12917,24 +12759,22 @@ mov.l\\t1f,r0\\n\\
(match_operand:V4HI 1 "arith_reg_or_0_operand" "rZ")
(match_operand:V4HI 2 "arith_reg_or_0_operand" "rZ")]
"TARGET_SHMEDIA"
- "
{
emit_insn ((TARGET_LITTLE_ENDIAN ? gen_mshf4_w : gen_mshf0_w)
(operands[0], operands[1], operands[2]));
DONE;
-}")
+})
(define_expand "mshflo_w"
[(match_operand:V4HI 0 "arith_reg_dest" "")
(match_operand:V4HI 1 "arith_reg_or_0_operand" "rZ")
(match_operand:V4HI 2 "arith_reg_or_0_operand" "rZ")]
"TARGET_SHMEDIA"
- "
{
emit_insn ((TARGET_LITTLE_ENDIAN ? gen_mshf0_w : gen_mshf4_w)
(operands[0], operands[1], operands[2]));
DONE;
-}")
+})
(define_insn "mshf4_w"
[(set (match_operand:V4HI 0 "arith_reg_dest" "=r")
@@ -12943,9 +12783,11 @@ mov.l\\t1f,r0\\n\\
(match_operand:V4HI 2 "arith_reg_or_0_operand" "rZ"))
(parallel [(const_int 2) (const_int 6) (const_int 3) (const_int 7)])))]
"TARGET_SHMEDIA"
- "* return (TARGET_LITTLE_ENDIAN
- ? \"mshfhi.w %N1, %N2, %0\"
- : \"mshflo.w %N1, %N2, %0\");"
+{
+ return (TARGET_LITTLE_ENDIAN
+ ? "mshfhi.w %N1, %N2, %0"
+ : "mshflo.w %N1, %N2, %0");
+}
[(set_attr "type" "arith_media")
(set (attr "highpart")
(cond [(eq_attr "endian" "big") (const_string "ignore")]
@@ -12958,9 +12800,11 @@ mov.l\\t1f,r0\\n\\
(match_operand:V4HI 2 "arith_reg_or_0_operand" "rZ"))
(parallel [(const_int 0) (const_int 4) (const_int 1) (const_int 5)])))]
"TARGET_SHMEDIA"
- "* return (TARGET_LITTLE_ENDIAN
- ? \"mshflo.w %N1, %N2, %0\"
- : \"mshfhi.w %N1, %N2, %0\");"
+{
+ return (TARGET_LITTLE_ENDIAN
+ ? "mshflo.w %N1, %N2, %0"
+ : "mshfhi.w %N1, %N2, %0");
+}
[(set_attr "type" "arith_media")
(set (attr "highpart")
(cond [(eq_attr "endian" "little") (const_string "ignore")]
@@ -12992,13 +12836,12 @@ mov.l\\t1f,r0\\n\\
&& ! GENERAL_REGISTER_P (true_regnum (operands[0]))"
[(set (match_dup 3) (match_dup 4))
(set (match_dup 5) (match_dup 6))]
- "
{
operands[3] = gen_lowpart (SImode, operands[0]);
operands[4] = gen_highpart (SImode, operands[1]);
operands[5] = gen_highpart (SImode, operands[0]);
operands[6] = gen_highpart (SImode, operands[2]);
-}"
+}
[(set_attr "type" "arith_media")])
(define_insn "*mshfhi_l_di_rev"
@@ -13020,7 +12863,6 @@ mov.l\\t1f,r0\\n\\
(clobber (match_operand:DI 3 "arith_reg_dest" ""))]
"TARGET_SHMEDIA"
[(const_int 0)]
- "
{
emit_insn (gen_ashldi3_media (operands[3],
simplify_gen_subreg (DImode, operands[1],
@@ -13028,7 +12870,7 @@ mov.l\\t1f,r0\\n\\
GEN_INT (32)));
emit_insn (gen_mshfhi_l_di (operands[0], operands[3], operands[2]));
DONE;
-}")
+})
(define_insn "mshflo_l_di"
[(set (match_operand:DI 0 "arith_reg_dest" "=r")
@@ -13065,14 +12907,13 @@ mov.l\\t1f,r0\\n\\
"#"
"rtx_equal_p (operands[0], operands[1])"
[(const_int 0)]
- "
{
HOST_WIDE_INT v = INTVAL (operands[2]);
emit_insn (gen_shori_media (operands[0], operands[0], GEN_INT (v >> 16)));
emit_insn (gen_shori_media (operands[0], operands[0], GEN_INT (v & 65535)));
DONE;
-}"
+}
[(set_attr "highpart" "ignore")])
@@ -13103,11 +12944,10 @@ mov.l\\t1f,r0\\n\\
&& ! GENERAL_REGISTER_P (true_regnum (operands[0]))"
[(set (match_dup 3) (match_dup 1))
(set (match_dup 4) (match_dup 2))]
- "
{
operands[3] = simplify_gen_subreg (SFmode, operands[0], V2SFmode, 0);
operands[4] = simplify_gen_subreg (SFmode, operands[0], V2SFmode, 4);
-}"
+}
[(set_attr "type" "arith_media")
(set_attr "highpart" "ignore")])
@@ -13138,7 +12978,6 @@ mov.l\\t1f,r0\\n\\
(match_operand 2 "shift_count_reg_operand" "")]))]
"TARGET_SHMEDIA && ! register_operand (operands[2], VOIDmode)"
[(set (match_dup 0) (match_dup 3))]
- "
{
rtx count = operands[2];
enum machine_mode outer_mode = GET_MODE (operands[2]), inner_mode;
@@ -13152,7 +12991,7 @@ mov.l\\t1f,r0\\n\\
subreg_lowpart_offset (outer_mode, inner_mode));
operands[3] = gen_rtx_fmt_ee (GET_CODE (operands[3]), GET_MODE (operands[3]),
operands[1], count);
-}")
+})
(define_insn "ashlv4hi3"
[(set (match_operand:V4HI 0 "arith_reg_dest" "=r")
@@ -13207,7 +13046,6 @@ mov.l\\t1f,r0\\n\\
"#"
"TARGET_SHMEDIA"
[(const_int 0)]
- "
{
rtx src0 = simplify_gen_subreg (V4HImode, operands[1], V2HImode, 0);
rtx src1 = simplify_gen_subreg (V4HImode, operands[2], V2HImode, 0);
@@ -13218,7 +13056,7 @@ mov.l\\t1f,r0\\n\\
emit_insn (gen_subv4hi3 (v4hi_dst, src0, src1));
emit_insn (gen_truncdisi2 (si_dst, di_dst));
DONE;
-}"
+}
[(set_attr "highpart" "must_split")])
(define_insn "sssubv2si3"
@@ -13366,10 +13204,11 @@ mov.l\\t1f,r0\\n\\
"#"
""
[(pc)]
- "emit_insn (gen_ldhi_q (operands[0],
- gen_rtx_PLUS (SImode, operands[1], operands[2])));
- DONE;")
-
+{
+ emit_insn (gen_ldhi_q (operands[0],
+ gen_rtx_PLUS (SImode, operands[1], operands[2])));
+ DONE;
+})
(define_insn_and_split "*ldhi_q_comb1"
[(set (match_operand:DI 0 "arith_reg_dest" "=r")
@@ -13390,10 +13229,11 @@ mov.l\\t1f,r0\\n\\
"#"
""
[(pc)]
- "emit_insn (gen_ldhi_q (operands[0],
- gen_rtx_PLUS (SImode, operands[1], operands[2])));
- DONE;")
-
+{
+ emit_insn (gen_ldhi_q (operands[0],
+ gen_rtx_PLUS (SImode, operands[1], operands[2])));
+ DONE;
+})
(define_insn "ldlo_l"
[(set (match_operand:SI 0 "arith_reg_dest" "=r")
@@ -13429,9 +13269,11 @@ mov.l\\t1f,r0\\n\\
"#"
""
[(pc)]
- "emit_insn (gen_ldlo_q (operands[0],
- gen_rtx_PLUS (SImode, operands[1], operands[2])));
- DONE;")
+{
+ emit_insn (gen_ldlo_q (operands[0],
+ gen_rtx_PLUS (SImode, operands[1], operands[2])));
+ DONE;
+})
(define_insn_and_split "*ldlo_q_comb1"
[(set (match_operand:DI 0 "arith_reg_dest" "=r")
@@ -13449,9 +13291,11 @@ mov.l\\t1f,r0\\n\\
"#"
""
[(pc)]
- "emit_insn (gen_ldlo_q (operands[0],
- gen_rtx_PLUS (SImode, operands[1], operands[2])));
- DONE;")
+{
+ emit_insn (gen_ldlo_q (operands[0],
+ gen_rtx_PLUS (SImode, operands[1], operands[2])));
+ DONE;
+})
(define_insn "sthi_l"
[(set (zero_extract:SI
@@ -13496,9 +13340,11 @@ mov.l\\t1f,r0\\n\\
"#"
""
[(pc)]
- "emit_insn (gen_sthi_q (gen_rtx_PLUS (SImode, operands[0], operands[1]),
- operands[2]));
- DONE;")
+{
+ emit_insn (gen_sthi_q (gen_rtx_PLUS (SImode, operands[0], operands[1]),
+ operands[2]));
+ DONE;
+})
(define_insn_and_split "*sthi_q_comb1"
[(set (zero_extract:DI
@@ -13519,9 +13365,11 @@ mov.l\\t1f,r0\\n\\
"#"
""
[(pc)]
- "emit_insn (gen_sthi_q (gen_rtx_PLUS (SImode, operands[0], operands[1]),
- operands[3]));
- DONE;")
+{
+ emit_insn (gen_sthi_q (gen_rtx_PLUS (SImode, operands[0], operands[1]),
+ operands[3]));
+ DONE;
+})
;; This is highpart user because the address is used as full 64 bit.
(define_insn "stlo_l"
@@ -13558,9 +13406,11 @@ mov.l\\t1f,r0\\n\\
"#"
""
[(pc)]
- "emit_insn (gen_stlo_q (gen_rtx_PLUS (SImode, operands[0], operands[1]),
- operands[2]));
- DONE;")
+{
+ emit_insn (gen_stlo_q (gen_rtx_PLUS (SImode, operands[0], operands[1]),
+ operands[2]));
+ DONE;
+})
(define_insn_and_split "*stlo_q_comb1"
[(set (zero_extract:DI
@@ -13577,9 +13427,11 @@ mov.l\\t1f,r0\\n\\
"#"
""
[(pc)]
- "emit_insn (gen_stlo_q (gen_rtx_PLUS (SImode, operands[0], operands[1]),
- operands[3]));
- DONE;")
+{
+ emit_insn (gen_stlo_q (gen_rtx_PLUS (SImode, operands[0], operands[1]),
+ operands[3]));
+ DONE;
+})
(define_insn "ldhi_l64"
[(set (match_operand:SI 0 "arith_reg_dest" "=r")
@@ -13703,7 +13555,6 @@ mov.l\\t1f,r0\\n\\
[(set (match_operand:DI 0 "arith_reg_dest" "")
(ffs:DI (match_operand:DI 1 "arith_reg_operand" "")))]
"TARGET_SHMEDIA"
- "
{
rtx scratch = gen_reg_rtx (DImode);
rtx last;
@@ -13718,13 +13569,12 @@ mov.l\\t1f,r0\\n\\
set_unique_reg_note (last, REG_EQUAL, gen_rtx_FFS (DImode, operands[0]));
DONE;
-}")
+})
(define_expand "ffssi2"
[(set (match_operand:SI 0 "arith_reg_dest" "")
(ffs:SI (match_operand:SI 1 "arith_reg_operand" "")))]
"TARGET_SHMEDIA"
- "
{
rtx scratch = gen_reg_rtx (SImode);
rtx discratch = gen_reg_rtx (DImode);
@@ -13742,7 +13592,7 @@ mov.l\\t1f,r0\\n\\
set_unique_reg_note (last, REG_EQUAL, gen_rtx_FFS (SImode, operands[0]));
DONE;
-}")
+})
(define_insn "byterev"
[(set (match_operand:V8QI 0 "arith_reg_dest" "=r")
@@ -13759,12 +13609,11 @@ mov.l\\t1f,r0\\n\\
(match_operand:SI 1 "const_int_operand" "n")
(match_operand:SI 2 "const_int_operand" "n"))]
"TARGET_SHMEDIA"
- "*
{
operands[0] = gen_rtx_MEM (QImode, operands[0]);
- output_asm_insn (\"ld%M0.b %m0,r63\", operands);
- return \"\";
-}"
+ output_asm_insn ("ld%M0.b %m0,r63", operands);
+ return "";
+}
[(set_attr "type" "other")])
(define_insn "*prefetch_i4"
@@ -13772,10 +13621,7 @@ mov.l\\t1f,r0\\n\\
(match_operand:SI 1 "const_int_operand" "n")
(match_operand:SI 2 "const_int_operand" "n"))]
"(TARGET_HARD_SH4 || TARGET_SHCOMPACT) && !TARGET_VXWORKS_RTP"
- "*
-{
- return \"pref @%0\";
-}"
+ "pref @%0";
[(set_attr "type" "other")])
;; In user mode, the "pref" instruction will raise a RADDERR exception
@@ -13787,7 +13633,6 @@ mov.l\\t1f,r0\\n\\
(match_operand:SI 2 "const_int_operand" "n"))]
"TARGET_SH2A || ((TARGET_HARD_SH4 || TARGET_SH5)
&& (TARGET_SHMEDIA || !TARGET_VXWORKS_RTP))"
- "
{
if (GET_MODE (operands[0]) != Pmode
|| !CONST_INT_P (operands[1])
@@ -13795,7 +13640,7 @@ mov.l\\t1f,r0\\n\\
FAIL;
if (! TARGET_SHMEDIA)
operands[0] = force_reg (Pmode, operands[0]);
-}")
+})
(define_insn "prefetch_m2a"
[(prefetch (match_operand:SI 0 "register_operand" "r")
@@ -13809,7 +13654,6 @@ mov.l\\t1f,r0\\n\\
[(set (mem:BLK (match_operand:QI 0 "cache_address_operand" "p"))
(unspec:BLK [(const_int 0)] UNSPEC_ALLOCO))]
"TARGET_SHMEDIA32"
- "*
{
rtx xops[2];
@@ -13823,9 +13667,9 @@ mov.l\\t1f,r0\\n\\
xops[0] = operands[0];
xops[1] = const0_rtx;
}
- output_asm_insn (\"alloco %0, %1\", xops);
- return \"\";
-}"
+ output_asm_insn ("alloco %0, %1", xops);
+ return "";
+}
[(set_attr "type" "other")])
(define_split
@@ -13833,14 +13677,13 @@ mov.l\\t1f,r0\\n\\
(match_operand 1 "" ""))]
"TARGET_SHMEDIA && reload_completed"
[(set (match_dup 0) (match_dup 1))]
- "
{
int n_changes = 0;
for_each_rtx (&operands[1], shmedia_cleanup_truncate, &n_changes);
if (!n_changes)
FAIL;
-}")
+})
; Stack Protector Patterns