diff options
Diffstat (limited to 'opcodes/m32r-opc.c')
-rw-r--r-- | opcodes/m32r-opc.c | 323 |
1 files changed, 81 insertions, 242 deletions
diff --git a/opcodes/m32r-opc.c b/opcodes/m32r-opc.c index f42f141..66e15c4 100644 --- a/opcodes/m32r-opc.c +++ b/opcodes/m32r-opc.c @@ -184,6 +184,7 @@ const CGEN_ATTR_TABLE m32r_cgen_operand_attr_table[] = { { "ABS-ADDR", NULL }, { "FAKE", NULL }, + { "HASH-PREFIX", NULL }, { "NEGATIVE", NULL }, { "PC", NULL }, { "PCREL-ADDR", NULL }, @@ -340,23 +341,23 @@ const CGEN_OPERAND m32r_cgen_operand_table[MAX_OPERANDS] = { 0, 0|(1<<CGEN_OPERAND_UNSIGNED), { 0 } } }, /* simm8: 8 bit signed immediate */ { "simm8", & HW_ENT (HW_H_SINT), 8, 8, - { 0, 0, { 0 } } }, + { 0, 0|(1<<CGEN_OPERAND_HASH_PREFIX), { 0 } } }, /* simm16: 16 bit signed immediate */ { "simm16", & HW_ENT (HW_H_SINT), 16, 16, - { 0, 0, { 0 } } }, + { 0, 0|(1<<CGEN_OPERAND_HASH_PREFIX), { 0 } } }, /* uimm4: 4 bit trap number */ { "uimm4", & HW_ENT (HW_H_UINT), 12, 4, - { 0, 0|(1<<CGEN_OPERAND_UNSIGNED), { 0 } } }, + { 0, 0|(1<<CGEN_OPERAND_HASH_PREFIX)|(1<<CGEN_OPERAND_UNSIGNED), { 0 } } }, /* uimm5: 5 bit shift count */ { "uimm5", & HW_ENT (HW_H_UINT), 11, 5, - { 0, 0|(1<<CGEN_OPERAND_UNSIGNED), { 0 } } }, + { 0, 0|(1<<CGEN_OPERAND_HASH_PREFIX)|(1<<CGEN_OPERAND_UNSIGNED), { 0 } } }, /* uimm16: 16 bit unsigned immediate */ { "uimm16", & HW_ENT (HW_H_UINT), 16, 16, - { 0, 0|(1<<CGEN_OPERAND_UNSIGNED), { 0 } } }, + { 0, 0|(1<<CGEN_OPERAND_HASH_PREFIX)|(1<<CGEN_OPERAND_UNSIGNED), { 0 } } }, /* start-sanitize-m32rx */ /* imm1: 1 bit immediate */ { "imm1", & HW_ENT (HW_H_UINT), 15, 1, - { 0, 0|(1<<CGEN_OPERAND_UNSIGNED), { 0 } } }, + { 0, 0|(1<<CGEN_OPERAND_HASH_PREFIX)|(1<<CGEN_OPERAND_UNSIGNED), { 0 } } }, /* end-sanitize-m32rx */ /* start-sanitize-m32rx */ /* accd: accumulator destination register */ @@ -373,6 +374,9 @@ const CGEN_OPERAND m32r_cgen_operand_table[MAX_OPERANDS] = { "acc", & HW_ENT (HW_H_ACCUMS), 8, 1, { 0, 0|(1<<CGEN_OPERAND_UNSIGNED), { 0 } } }, /* end-sanitize-m32rx */ +/* hash: # prefix */ + { "hash", & HW_ENT (HW_H_SINT), 0, 0, + { 0, 0, { 0 } } }, /* hi16: high 16 bit immediate, sign optional */ { "hi16", & HW_ENT (HW_H_HI16), 16, 16, { 0, 0|(1<<CGEN_OPERAND_SIGN_OPT)|(1<<CGEN_OPERAND_UNSIGNED), { 0 } } }, @@ -384,7 +388,7 @@ const CGEN_OPERAND m32r_cgen_operand_table[MAX_OPERANDS] = { 0, 0|(1<<CGEN_OPERAND_UNSIGNED), { 0 } } }, /* uimm24: 24 bit address */ { "uimm24", & HW_ENT (HW_H_ADDR), 8, 24, - { 0, 0|(1<<CGEN_OPERAND_RELOC)|(1<<CGEN_OPERAND_ABS_ADDR)|(1<<CGEN_OPERAND_UNSIGNED), { 0 } } }, + { 0, 0|(1<<CGEN_OPERAND_HASH_PREFIX)|(1<<CGEN_OPERAND_RELOC)|(1<<CGEN_OPERAND_ABS_ADDR)|(1<<CGEN_OPERAND_UNSIGNED), { 0 } } }, /* disp8: 8 bit displacement */ { "disp8", & HW_ENT (HW_H_IADDR), 8, 8, { 0, 0|(1<<CGEN_OPERAND_RELAX)|(1<<CGEN_OPERAND_RELOC)|(1<<CGEN_OPERAND_PCREL_ADDR), { 0 } } }, @@ -858,7 +862,7 @@ static const CGEN_OPERAND_INSTANCE fmt_70_trap_ops[] = { { 0 } }; -static const CGEN_OPERAND_INSTANCE fmt_72_unlock_ops[] = { +static const CGEN_OPERAND_INSTANCE fmt_71_unlock_ops[] = { { INPUT, & HW_ENT (HW_H_LOCK), CGEN_MODE_UBI, 0, 0 }, { INPUT, & HW_ENT (HW_H_GR), CGEN_MODE_SI, & OP_ENT (SRC1), 0 }, { INPUT, & HW_ENT (HW_H_GR), CGEN_MODE_SI, & OP_ENT (SRC2), 0 }, @@ -867,27 +871,27 @@ static const CGEN_OPERAND_INSTANCE fmt_72_unlock_ops[] = { { 0 } }; -static const CGEN_OPERAND_INSTANCE fmt_75_satb_ops[] = { +static const CGEN_OPERAND_INSTANCE fmt_74_satb_ops[] = { { INPUT, & HW_ENT (HW_H_GR), CGEN_MODE_SI, & OP_ENT (SR), 0 }, { OUTPUT, & HW_ENT (HW_H_GR), CGEN_MODE_SI, & OP_ENT (DR), 0 }, { 0 } }; -static const CGEN_OPERAND_INSTANCE fmt_76_sat_ops[] = { +static const CGEN_OPERAND_INSTANCE fmt_75_sat_ops[] = { { INPUT, & HW_ENT (HW_H_COND), CGEN_MODE_UBI, 0, 0 }, { INPUT, & HW_ENT (HW_H_GR), CGEN_MODE_SI, & OP_ENT (SR), 0 }, { OUTPUT, & HW_ENT (HW_H_GR), CGEN_MODE_SI, & OP_ENT (DR), 0 }, { 0 } }; -static const CGEN_OPERAND_INSTANCE fmt_77_sadd_ops[] = { +static const CGEN_OPERAND_INSTANCE fmt_76_sadd_ops[] = { { INPUT, & HW_ENT (HW_H_ACCUMS), CGEN_MODE_DI, 0, 0 }, { INPUT, & HW_ENT (HW_H_ACCUMS), CGEN_MODE_DI, 0, 1 }, { OUTPUT, & HW_ENT (HW_H_ACCUMS), CGEN_MODE_DI, 0, 0 }, { 0 } }; -static const CGEN_OPERAND_INSTANCE fmt_78_macwu1_ops[] = { +static const CGEN_OPERAND_INSTANCE fmt_77_macwu1_ops[] = { { INPUT, & HW_ENT (HW_H_ACCUMS), CGEN_MODE_DI, 0, 1 }, { INPUT, & HW_ENT (HW_H_GR), CGEN_MODE_SI, & OP_ENT (SRC1), 0 }, { INPUT, & HW_ENT (HW_H_GR), CGEN_MODE_SI, & OP_ENT (SRC2), 0 }, @@ -895,14 +899,14 @@ static const CGEN_OPERAND_INSTANCE fmt_78_macwu1_ops[] = { { 0 } }; -static const CGEN_OPERAND_INSTANCE fmt_79_mulwu1_ops[] = { +static const CGEN_OPERAND_INSTANCE fmt_78_mulwu1_ops[] = { { INPUT, & HW_ENT (HW_H_GR), CGEN_MODE_SI, & OP_ENT (SRC1), 0 }, { INPUT, & HW_ENT (HW_H_GR), CGEN_MODE_SI, & OP_ENT (SRC2), 0 }, { OUTPUT, & HW_ENT (HW_H_ACCUMS), CGEN_MODE_DI, 0, 1 }, { 0 } }; -static const CGEN_OPERAND_INSTANCE fmt_80_sc_ops[] = { +static const CGEN_OPERAND_INSTANCE fmt_79_sc_ops[] = { { INPUT, & HW_ENT (HW_H_COND), CGEN_MODE_UBI, 0, 0 }, { 0 } }; @@ -929,24 +933,15 @@ const CGEN_INSN m32r_cgen_insn_table_entries[MAX_INSNS] = & fmt_0_add_ops[0], { CGEN_INSN_NBOOL_ATTRS, 0|A(PARALLEL), { (1<<MACH_M32R), PIPE_OS } } }, -/* add3 $dr,$sr,#$slo16 */ +/* add3 $dr,$sr,$hash$slo16 */ { { 1, 1, 1, 1 }, "add3", "add3", - { MNEM, ' ', OP (DR), ',', OP (SR), ',', '#', OP (SLO16), 0 }, + { MNEM, ' ', OP (DR), ',', OP (SR), ',', OP (HASH), OP (SLO16), 0 }, { 32, 32, 0xf0f00000 }, 0x80a00000, & fmt_1_add3_ops[0], { CGEN_INSN_NBOOL_ATTRS, 0, { (1<<MACH_M32R), PIPE_NONE } } }, -/* add3 $dr,$sr,$slo16 */ - { - { 1, 1, 1, 1 }, - "add3.a", "add3", - { MNEM, ' ', OP (DR), ',', OP (SR), ',', OP (SLO16), 0 }, - { 32, 32, 0xf0f00000 }, 0x80a00000, - & fmt_1_add3_ops[0], - { CGEN_INSN_NBOOL_ATTRS, 0|A(ALIAS), { (1<<MACH_M32R), PIPE_NONE } } - }, /* and $dr,$sr */ { { 1, 1, 1, 1 }, @@ -956,23 +951,14 @@ const CGEN_INSN m32r_cgen_insn_table_entries[MAX_INSNS] = & fmt_0_add_ops[0], { CGEN_INSN_NBOOL_ATTRS, 0|A(PARALLEL), { (1<<MACH_M32R), PIPE_OS } } }, -/* and3 $dr,$sr,#$uimm16 */ - { - { 1, 1, 1, 1 }, - "and3", "and3", - { MNEM, ' ', OP (DR), ',', OP (SR), ',', '#', OP (UIMM16), 0 }, - { 32, 32, 0xf0f00000 }, 0x80c00000, - & fmt_2_and3_ops[0], - { CGEN_INSN_NBOOL_ATTRS, 0, { (1<<MACH_M32R), PIPE_NONE } } - }, /* and3 $dr,$sr,$uimm16 */ { { 1, 1, 1, 1 }, - "and3.a", "and3", + "and3", "and3", { MNEM, ' ', OP (DR), ',', OP (SR), ',', OP (UIMM16), 0 }, { 32, 32, 0xf0f00000 }, 0x80c00000, & fmt_2_and3_ops[0], - { CGEN_INSN_NBOOL_ATTRS, 0|A(ALIAS), { (1<<MACH_M32R), PIPE_NONE } } + { CGEN_INSN_NBOOL_ATTRS, 0, { (1<<MACH_M32R), PIPE_NONE } } }, /* or $dr,$sr */ { @@ -983,24 +969,15 @@ const CGEN_INSN m32r_cgen_insn_table_entries[MAX_INSNS] = & fmt_0_add_ops[0], { CGEN_INSN_NBOOL_ATTRS, 0|A(PARALLEL), { (1<<MACH_M32R), PIPE_OS } } }, -/* or3 $dr,$sr,#$ulo16 */ +/* or3 $dr,$sr,$hash$ulo16 */ { { 1, 1, 1, 1 }, "or3", "or3", - { MNEM, ' ', OP (DR), ',', OP (SR), ',', '#', OP (ULO16), 0 }, + { MNEM, ' ', OP (DR), ',', OP (SR), ',', OP (HASH), OP (ULO16), 0 }, { 32, 32, 0xf0f00000 }, 0x80e00000, & fmt_3_or3_ops[0], { CGEN_INSN_NBOOL_ATTRS, 0, { (1<<MACH_M32R), PIPE_NONE } } }, -/* or3 $dr,$sr,$ulo16 */ - { - { 1, 1, 1, 1 }, - "or3.a", "or3", - { MNEM, ' ', OP (DR), ',', OP (SR), ',', OP (ULO16), 0 }, - { 32, 32, 0xf0f00000 }, 0x80e00000, - & fmt_3_or3_ops[0], - { CGEN_INSN_NBOOL_ATTRS, 0|A(ALIAS), { (1<<MACH_M32R), PIPE_NONE } } - }, /* xor $dr,$sr */ { { 1, 1, 1, 1 }, @@ -1010,41 +987,23 @@ const CGEN_INSN m32r_cgen_insn_table_entries[MAX_INSNS] = & fmt_0_add_ops[0], { CGEN_INSN_NBOOL_ATTRS, 0|A(PARALLEL), { (1<<MACH_M32R), PIPE_OS } } }, -/* xor3 $dr,$sr,#$uimm16 */ - { - { 1, 1, 1, 1 }, - "xor3", "xor3", - { MNEM, ' ', OP (DR), ',', OP (SR), ',', '#', OP (UIMM16), 0 }, - { 32, 32, 0xf0f00000 }, 0x80d00000, - & fmt_2_and3_ops[0], - { CGEN_INSN_NBOOL_ATTRS, 0, { (1<<MACH_M32R), PIPE_NONE } } - }, /* xor3 $dr,$sr,$uimm16 */ { { 1, 1, 1, 1 }, - "xor3.a", "xor3", + "xor3", "xor3", { MNEM, ' ', OP (DR), ',', OP (SR), ',', OP (UIMM16), 0 }, { 32, 32, 0xf0f00000 }, 0x80d00000, & fmt_2_and3_ops[0], - { CGEN_INSN_NBOOL_ATTRS, 0|A(ALIAS), { (1<<MACH_M32R), PIPE_NONE } } - }, -/* addi $dr,#$simm8 */ - { - { 1, 1, 1, 1 }, - "addi", "addi", - { MNEM, ' ', OP (DR), ',', '#', OP (SIMM8), 0 }, - { 16, 16, 0xf000 }, 0x4000, - & fmt_4_addi_ops[0], - { CGEN_INSN_NBOOL_ATTRS, 0, { (1<<MACH_M32R), PIPE_OS } } + { CGEN_INSN_NBOOL_ATTRS, 0, { (1<<MACH_M32R), PIPE_NONE } } }, /* addi $dr,$simm8 */ { { 1, 1, 1, 1 }, - "addi.a", "addi", + "addi", "addi", { MNEM, ' ', OP (DR), ',', OP (SIMM8), 0 }, { 16, 16, 0xf000 }, 0x4000, & fmt_4_addi_ops[0], - { CGEN_INSN_NBOOL_ATTRS, 0|A(ALIAS), { (1<<MACH_M32R), PIPE_OS } } + { CGEN_INSN_NBOOL_ATTRS, 0, { (1<<MACH_M32R), PIPE_OS } } }, /* addv $dr,$sr */ { @@ -1055,23 +1014,14 @@ const CGEN_INSN m32r_cgen_insn_table_entries[MAX_INSNS] = & fmt_5_addv_ops[0], { CGEN_INSN_NBOOL_ATTRS, 0, { (1<<MACH_M32R), PIPE_OS } } }, -/* addv3 $dr,$sr,#$simm16 */ - { - { 1, 1, 1, 1 }, - "addv3", "addv3", - { MNEM, ' ', OP (DR), ',', OP (SR), ',', '#', OP (SIMM16), 0 }, - { 32, 32, 0xf0f00000 }, 0x80800000, - & fmt_6_addv3_ops[0], - { CGEN_INSN_NBOOL_ATTRS, 0, { (1<<MACH_M32R), PIPE_NONE } } - }, /* addv3 $dr,$sr,$simm16 */ { { 1, 1, 1, 1 }, - "addv3.a", "addv3", + "addv3", "addv3", { MNEM, ' ', OP (DR), ',', OP (SR), ',', OP (SIMM16), 0 }, { 32, 32, 0xf0f00000 }, 0x80800000, & fmt_6_addv3_ops[0], - { CGEN_INSN_NBOOL_ATTRS, 0|A(ALIAS), { (1<<MACH_M32R), PIPE_NONE } } + { CGEN_INSN_NBOOL_ATTRS, 0, { (1<<MACH_M32R), PIPE_NONE } } }, /* addx $dr,$sr */ { @@ -1395,23 +1345,14 @@ const CGEN_INSN m32r_cgen_insn_table_entries[MAX_INSNS] = & fmt_20_cmp_ops[0], { CGEN_INSN_NBOOL_ATTRS, 0, { (1<<MACH_M32R), PIPE_OS } } }, -/* cmpi $src2,#$simm16 */ - { - { 1, 1, 1, 1 }, - "cmpi", "cmpi", - { MNEM, ' ', OP (SRC2), ',', '#', OP (SIMM16), 0 }, - { 32, 32, 0xfff00000 }, 0x80400000, - & fmt_21_cmpi_ops[0], - { CGEN_INSN_NBOOL_ATTRS, 0, { (1<<MACH_M32R), PIPE_NONE } } - }, /* cmpi $src2,$simm16 */ { { 1, 1, 1, 1 }, - "cmpi.a", "cmpi", + "cmpi", "cmpi", { MNEM, ' ', OP (SRC2), ',', OP (SIMM16), 0 }, { 32, 32, 0xfff00000 }, 0x80400000, & fmt_21_cmpi_ops[0], - { CGEN_INSN_NBOOL_ATTRS, 0|A(ALIAS), { (1<<MACH_M32R), PIPE_NONE } } + { CGEN_INSN_NBOOL_ATTRS, 0, { (1<<MACH_M32R), PIPE_NONE } } }, /* cmpu $src1,$src2 */ { @@ -1422,23 +1363,14 @@ const CGEN_INSN m32r_cgen_insn_table_entries[MAX_INSNS] = & fmt_20_cmp_ops[0], { CGEN_INSN_NBOOL_ATTRS, 0, { (1<<MACH_M32R), PIPE_OS } } }, -/* cmpui $src2,#$uimm16 */ - { - { 1, 1, 1, 1 }, - "cmpui", "cmpui", - { MNEM, ' ', OP (SRC2), ',', '#', OP (UIMM16), 0 }, - { 32, 32, 0xfff00000 }, 0x80500000, - & fmt_22_cmpui_ops[0], - { CGEN_INSN_NBOOL_ATTRS, 0, { (1<<MACH_M32R), PIPE_NONE } } - }, /* cmpui $src2,$uimm16 */ { { 1, 1, 1, 1 }, - "cmpui.a", "cmpui", + "cmpui", "cmpui", { MNEM, ' ', OP (SRC2), ',', OP (UIMM16), 0 }, { 32, 32, 0xfff00000 }, 0x80500000, & fmt_22_cmpui_ops[0], - { CGEN_INSN_NBOOL_ATTRS, 0|A(ALIAS), { (1<<MACH_M32R), PIPE_NONE } } + { CGEN_INSN_NBOOL_ATTRS, 0, { (1<<MACH_M32R), PIPE_NONE } } }, /* start-sanitize-m32rx */ /* cmpeq $src1,$src2 */ @@ -1738,74 +1670,47 @@ const CGEN_INSN m32r_cgen_insn_table_entries[MAX_INSNS] = & fmt_36_ld_plus_ops[0], { CGEN_INSN_NBOOL_ATTRS, 0, { (1<<MACH_M32R), PIPE_O } } }, -/* ld24 $dr,#$uimm24 */ - { - { 1, 1, 1, 1 }, - "ld24", "ld24", - { MNEM, ' ', OP (DR), ',', '#', OP (UIMM24), 0 }, - { 32, 32, 0xf0000000 }, 0xe0000000, - & fmt_37_ld24_ops[0], - { CGEN_INSN_NBOOL_ATTRS, 0, { (1<<MACH_M32R), PIPE_NONE } } - }, /* ld24 $dr,$uimm24 */ { { 1, 1, 1, 1 }, - "ld24.a", "ld24", + "ld24", "ld24", { MNEM, ' ', OP (DR), ',', OP (UIMM24), 0 }, { 32, 32, 0xf0000000 }, 0xe0000000, & fmt_37_ld24_ops[0], - { CGEN_INSN_NBOOL_ATTRS, 0|A(ALIAS), { (1<<MACH_M32R), PIPE_NONE } } - }, -/* ldi $dr,#$simm8 */ - { - { 1, 1, 1, 1 }, - "ldi8", "ldi", - { MNEM, ' ', OP (DR), ',', '#', OP (SIMM8), 0 }, - { 16, 16, 0xf000 }, 0x6000, - & fmt_38_ldi8_ops[0], - { CGEN_INSN_NBOOL_ATTRS, 0, { (1<<MACH_M32R), PIPE_OS } } + { CGEN_INSN_NBOOL_ATTRS, 0, { (1<<MACH_M32R), PIPE_NONE } } }, /* ldi $dr,$simm8 */ { { 1, 1, 1, 1 }, - "ldi8.a", "ldi", + "ldi8", "ldi", { MNEM, ' ', OP (DR), ',', OP (SIMM8), 0 }, { 16, 16, 0xf000 }, 0x6000, & fmt_38_ldi8_ops[0], - { CGEN_INSN_NBOOL_ATTRS, 0|A(ALIAS), { (1<<MACH_M32R), PIPE_OS } } - }, -/* ldi8 $dr,#$simm8 */ - { - { 1, 1, 1, 1 }, - "ldi8a", "ldi8", - { MNEM, ' ', OP (DR), ',', '#', OP (SIMM8), 0 }, - { 16, 16, 0xf000 }, 0x6000, - & fmt_38_ldi8_ops[0], - { CGEN_INSN_NBOOL_ATTRS, 0|A(ALIAS), { (1<<MACH_M32R), PIPE_OS } } + { CGEN_INSN_NBOOL_ATTRS, 0, { (1<<MACH_M32R), PIPE_OS } } }, /* ldi8 $dr,$simm8 */ { { 1, 1, 1, 1 }, - "ldi8a.a", "ldi8", + "ldi8a", "ldi8", { MNEM, ' ', OP (DR), ',', OP (SIMM8), 0 }, { 16, 16, 0xf000 }, 0x6000, & fmt_38_ldi8_ops[0], { CGEN_INSN_NBOOL_ATTRS, 0|A(ALIAS), { (1<<MACH_M32R), PIPE_OS } } }, -/* ldi $dr,$slo16 */ +/* ldi $dr,$hash$slo16 */ { { 1, 1, 1, 1 }, "ldi16", "ldi", - { MNEM, ' ', OP (DR), ',', OP (SLO16), 0 }, + { MNEM, ' ', OP (DR), ',', OP (HASH), OP (SLO16), 0 }, { 32, 32, 0xf0ff0000 }, 0x90f00000, & fmt_39_ldi16_ops[0], { CGEN_INSN_NBOOL_ATTRS, 0, { (1<<MACH_M32R), PIPE_NONE } } }, -/* ldi16 $dr,$slo16 */ +/* ldi16 $dr,$hash$slo16 */ { { 1, 1, 1, 1 }, "ldi16a", "ldi16", - { MNEM, ' ', OP (DR), ',', OP (SLO16), 0 }, + { MNEM, ' ', OP (DR), ',', OP (HASH), OP (SLO16), 0 }, { 32, 32, 0xf0ff0000 }, 0x90f00000, & fmt_39_ldi16_ops[0], { CGEN_INSN_NBOOL_ATTRS, 0|A(ALIAS), { (1<<MACH_M32R), PIPE_NONE } } @@ -2130,11 +2035,11 @@ const CGEN_INSN m32r_cgen_insn_table_entries[MAX_INSNS] = }, /* end-sanitize-m32rx */ /* start-sanitize-m32rx */ -/* rac $accd,$accs,#$imm1 */ +/* rac $accd,$accs,$imm1 */ { { 1, 1, 1, 1 }, "rac-dsi", "rac", - { MNEM, ' ', OP (ACCD), ',', OP (ACCS), ',', '#', OP (IMM1), 0 }, + { MNEM, ' ', OP (ACCD), ',', OP (ACCS), ',', OP (IMM1), 0 }, { 16, 16, 0xf3f2 }, 0x5090, & fmt_56_rac_dsi_ops[0], { CGEN_INSN_NBOOL_ATTRS, 0, { (1<<MACH_M32RX), PIPE_S } } @@ -2172,11 +2077,11 @@ const CGEN_INSN m32r_cgen_insn_table_entries[MAX_INSNS] = }, /* end-sanitize-m32rx */ /* start-sanitize-m32rx */ -/* rach $accd,$accs,#$imm1 */ +/* rach $accd,$accs,$imm1 */ { { 1, 1, 1, 1 }, "rach-dsi", "rach", - { MNEM, ' ', OP (ACCD), ',', OP (ACCS), ',', '#', OP (IMM1), 0 }, + { MNEM, ' ', OP (ACCD), ',', OP (ACCS), ',', OP (IMM1), 0 }, { 16, 16, 0xf3f2 }, 0x5080, & fmt_56_rac_dsi_ops[0], { CGEN_INSN_NBOOL_ATTRS, 0, { (1<<MACH_M32RX), PIPE_S } } @@ -2191,24 +2096,15 @@ const CGEN_INSN m32r_cgen_insn_table_entries[MAX_INSNS] = & fmt_57_rte_ops[0], { CGEN_INSN_NBOOL_ATTRS, 0|A(UNCOND_CTI), { (1<<MACH_M32R), PIPE_O } } }, -/* seth $dr,#$hi16 */ +/* seth $dr,$hash$hi16 */ { { 1, 1, 1, 1 }, "seth", "seth", - { MNEM, ' ', OP (DR), ',', '#', OP (HI16), 0 }, + { MNEM, ' ', OP (DR), ',', OP (HASH), OP (HI16), 0 }, { 32, 32, 0xf0ff0000 }, 0xd0c00000, & fmt_58_seth_ops[0], { CGEN_INSN_NBOOL_ATTRS, 0, { (1<<MACH_M32R), PIPE_NONE } } }, -/* seth $dr,$hi16 */ - { - { 1, 1, 1, 1 }, - "seth.a", "seth", - { MNEM, ' ', OP (DR), ',', OP (HI16), 0 }, - { 32, 32, 0xf0ff0000 }, 0xd0c00000, - & fmt_58_seth_ops[0], - { CGEN_INSN_NBOOL_ATTRS, 0|A(ALIAS), { (1<<MACH_M32R), PIPE_NONE } } - }, /* sll $dr,$sr */ { { 1, 1, 1, 1 }, @@ -2218,41 +2114,23 @@ const CGEN_INSN m32r_cgen_insn_table_entries[MAX_INSNS] = & fmt_0_add_ops[0], { CGEN_INSN_NBOOL_ATTRS, 0, { (1<<MACH_M32R), PIPE_O } } }, -/* sll3 $dr,$sr,#$simm16 */ - { - { 1, 1, 1, 1 }, - "sll3", "sll3", - { MNEM, ' ', OP (DR), ',', OP (SR), ',', '#', OP (SIMM16), 0 }, - { 32, 32, 0xf0f00000 }, 0x90c00000, - & fmt_59_sll3_ops[0], - { CGEN_INSN_NBOOL_ATTRS, 0, { (1<<MACH_M32R), PIPE_NONE } } - }, /* sll3 $dr,$sr,$simm16 */ { { 1, 1, 1, 1 }, - "sll3.a", "sll3", + "sll3", "sll3", { MNEM, ' ', OP (DR), ',', OP (SR), ',', OP (SIMM16), 0 }, { 32, 32, 0xf0f00000 }, 0x90c00000, & fmt_59_sll3_ops[0], - { CGEN_INSN_NBOOL_ATTRS, 0|A(ALIAS), { (1<<MACH_M32R), PIPE_NONE } } - }, -/* slli $dr,#$uimm5 */ - { - { 1, 1, 1, 1 }, - "slli", "slli", - { MNEM, ' ', OP (DR), ',', '#', OP (UIMM5), 0 }, - { 16, 16, 0xf0e0 }, 0x5040, - & fmt_60_slli_ops[0], - { CGEN_INSN_NBOOL_ATTRS, 0, { (1<<MACH_M32R), PIPE_O } } + { CGEN_INSN_NBOOL_ATTRS, 0, { (1<<MACH_M32R), PIPE_NONE } } }, /* slli $dr,$uimm5 */ { { 1, 1, 1, 1 }, - "slli.a", "slli", + "slli", "slli", { MNEM, ' ', OP (DR), ',', OP (UIMM5), 0 }, { 16, 16, 0xf0e0 }, 0x5040, & fmt_60_slli_ops[0], - { CGEN_INSN_NBOOL_ATTRS, 0|A(ALIAS), { (1<<MACH_M32R), PIPE_O } } + { CGEN_INSN_NBOOL_ATTRS, 0, { (1<<MACH_M32R), PIPE_O } } }, /* sra $dr,$sr */ { @@ -2263,41 +2141,23 @@ const CGEN_INSN m32r_cgen_insn_table_entries[MAX_INSNS] = & fmt_0_add_ops[0], { CGEN_INSN_NBOOL_ATTRS, 0, { (1<<MACH_M32R), PIPE_O } } }, -/* sra3 $dr,$sr,#$simm16 */ - { - { 1, 1, 1, 1 }, - "sra3", "sra3", - { MNEM, ' ', OP (DR), ',', OP (SR), ',', '#', OP (SIMM16), 0 }, - { 32, 32, 0xf0f00000 }, 0x90a00000, - & fmt_59_sll3_ops[0], - { CGEN_INSN_NBOOL_ATTRS, 0, { (1<<MACH_M32R), PIPE_NONE } } - }, /* sra3 $dr,$sr,$simm16 */ { { 1, 1, 1, 1 }, - "sra3.a", "sra3", + "sra3", "sra3", { MNEM, ' ', OP (DR), ',', OP (SR), ',', OP (SIMM16), 0 }, { 32, 32, 0xf0f00000 }, 0x90a00000, & fmt_59_sll3_ops[0], - { CGEN_INSN_NBOOL_ATTRS, 0|A(ALIAS), { (1<<MACH_M32R), PIPE_NONE } } - }, -/* srai $dr,#$uimm5 */ - { - { 1, 1, 1, 1 }, - "srai", "srai", - { MNEM, ' ', OP (DR), ',', '#', OP (UIMM5), 0 }, - { 16, 16, 0xf0e0 }, 0x5020, - & fmt_60_slli_ops[0], - { CGEN_INSN_NBOOL_ATTRS, 0, { (1<<MACH_M32R), PIPE_O } } + { CGEN_INSN_NBOOL_ATTRS, 0, { (1<<MACH_M32R), PIPE_NONE } } }, /* srai $dr,$uimm5 */ { { 1, 1, 1, 1 }, - "srai.a", "srai", + "srai", "srai", { MNEM, ' ', OP (DR), ',', OP (UIMM5), 0 }, { 16, 16, 0xf0e0 }, 0x5020, & fmt_60_slli_ops[0], - { CGEN_INSN_NBOOL_ATTRS, 0|A(ALIAS), { (1<<MACH_M32R), PIPE_O } } + { CGEN_INSN_NBOOL_ATTRS, 0, { (1<<MACH_M32R), PIPE_O } } }, /* srl $dr,$sr */ { @@ -2308,41 +2168,23 @@ const CGEN_INSN m32r_cgen_insn_table_entries[MAX_INSNS] = & fmt_0_add_ops[0], { CGEN_INSN_NBOOL_ATTRS, 0, { (1<<MACH_M32R), PIPE_O } } }, -/* srl3 $dr,$sr,#$simm16 */ - { - { 1, 1, 1, 1 }, - "srl3", "srl3", - { MNEM, ' ', OP (DR), ',', OP (SR), ',', '#', OP (SIMM16), 0 }, - { 32, 32, 0xf0f00000 }, 0x90800000, - & fmt_59_sll3_ops[0], - { CGEN_INSN_NBOOL_ATTRS, 0, { (1<<MACH_M32R), PIPE_NONE } } - }, /* srl3 $dr,$sr,$simm16 */ { { 1, 1, 1, 1 }, - "srl3.a", "srl3", + "srl3", "srl3", { MNEM, ' ', OP (DR), ',', OP (SR), ',', OP (SIMM16), 0 }, { 32, 32, 0xf0f00000 }, 0x90800000, & fmt_59_sll3_ops[0], - { CGEN_INSN_NBOOL_ATTRS, 0|A(ALIAS), { (1<<MACH_M32R), PIPE_NONE } } - }, -/* srli $dr,#$uimm5 */ - { - { 1, 1, 1, 1 }, - "srli", "srli", - { MNEM, ' ', OP (DR), ',', '#', OP (UIMM5), 0 }, - { 16, 16, 0xf0e0 }, 0x5000, - & fmt_60_slli_ops[0], - { CGEN_INSN_NBOOL_ATTRS, 0, { (1<<MACH_M32R), PIPE_O } } + { CGEN_INSN_NBOOL_ATTRS, 0, { (1<<MACH_M32R), PIPE_NONE } } }, /* srli $dr,$uimm5 */ { { 1, 1, 1, 1 }, - "srli.a", "srli", + "srli", "srli", { MNEM, ' ', OP (DR), ',', OP (UIMM5), 0 }, { 16, 16, 0xf0e0 }, 0x5000, & fmt_60_slli_ops[0], - { CGEN_INSN_NBOOL_ATTRS, 0|A(ALIAS), { (1<<MACH_M32R), PIPE_O } } + { CGEN_INSN_NBOOL_ATTRS, 0, { (1<<MACH_M32R), PIPE_O } } }, /* st $src1,@$src2 */ { @@ -2497,31 +2339,22 @@ const CGEN_INSN m32r_cgen_insn_table_entries[MAX_INSNS] = & fmt_7_addx_ops[0], { CGEN_INSN_NBOOL_ATTRS, 0, { (1<<MACH_M32R), PIPE_OS } } }, -/* trap #$uimm4 */ +/* trap $uimm4 */ { { 1, 1, 1, 1 }, "trap", "trap", - { MNEM, ' ', '#', OP (UIMM4), 0 }, + { MNEM, ' ', OP (UIMM4), 0 }, { 16, 16, 0xfff0 }, 0x10f0, & fmt_70_trap_ops[0], { CGEN_INSN_NBOOL_ATTRS, 0|A(FILL_SLOT)|A(UNCOND_CTI), { (1<<MACH_M32R), PIPE_O } } }, -/* trap $uimm4 */ - { - { 1, 1, 1, 1 }, - "trap.a", "trap", - { MNEM, ' ', OP (UIMM4), 0 }, - { 16, 16, 0xfff0 }, 0x10f0, - 0, - { CGEN_INSN_NBOOL_ATTRS, 0|A(ALIAS)|A(FILL_SLOT)|A(UNCOND_CTI), { (1<<MACH_M32R), PIPE_O } } - }, /* unlock $src1,@$src2 */ { { 1, 1, 1, 1 }, "unlock", "unlock", { MNEM, ' ', OP (SRC1), ',', '@', OP (SRC2), 0 }, { 16, 16, 0xf0f0 }, 0x2050, - & fmt_72_unlock_ops[0], + & fmt_71_unlock_ops[0], { CGEN_INSN_NBOOL_ATTRS, 0, { (1<<MACH_M32R), PIPE_O } } }, /* push $src1 */ @@ -2549,7 +2382,7 @@ const CGEN_INSN m32r_cgen_insn_table_entries[MAX_INSNS] = "satb", "satb", { MNEM, ' ', OP (DR), ',', OP (SR), 0 }, { 32, 32, 0xf0f0ffff }, 0x80000100, - & fmt_75_satb_ops[0], + & fmt_74_satb_ops[0], { CGEN_INSN_NBOOL_ATTRS, 0, { (1<<MACH_M32RX), PIPE_NONE } } }, /* end-sanitize-m32rx */ @@ -2560,7 +2393,7 @@ const CGEN_INSN m32r_cgen_insn_table_entries[MAX_INSNS] = "sath", "sath", { MNEM, ' ', OP (DR), ',', OP (SR), 0 }, { 32, 32, 0xf0f0ffff }, 0x80000200, - & fmt_75_satb_ops[0], + & fmt_74_satb_ops[0], { CGEN_INSN_NBOOL_ATTRS, 0, { (1<<MACH_M32RX), PIPE_NONE } } }, /* end-sanitize-m32rx */ @@ -2571,7 +2404,7 @@ const CGEN_INSN m32r_cgen_insn_table_entries[MAX_INSNS] = "sat", "sat", { MNEM, ' ', OP (DR), ',', OP (SR), 0 }, { 32, 32, 0xf0f0ffff }, 0x80000000, - & fmt_76_sat_ops[0], + & fmt_75_sat_ops[0], { CGEN_INSN_NBOOL_ATTRS, 0, { (1<<MACH_M32RX), PIPE_NONE } } }, /* end-sanitize-m32rx */ @@ -2593,7 +2426,7 @@ const CGEN_INSN m32r_cgen_insn_table_entries[MAX_INSNS] = "sadd", "sadd", { MNEM, 0 }, { 16, 16, 0xffff }, 0x50e4, - & fmt_77_sadd_ops[0], + & fmt_76_sadd_ops[0], { CGEN_INSN_NBOOL_ATTRS, 0, { (1<<MACH_M32RX), PIPE_S } } }, /* end-sanitize-m32rx */ @@ -2604,7 +2437,7 @@ const CGEN_INSN m32r_cgen_insn_table_entries[MAX_INSNS] = "macwu1", "macwu1", { MNEM, ' ', OP (SRC1), ',', OP (SRC2), 0 }, { 16, 16, 0xf0f0 }, 0x50b0, - & fmt_78_macwu1_ops[0], + & fmt_77_macwu1_ops[0], { CGEN_INSN_NBOOL_ATTRS, 0, { (1<<MACH_M32RX), PIPE_S } } }, /* end-sanitize-m32rx */ @@ -2626,7 +2459,7 @@ const CGEN_INSN m32r_cgen_insn_table_entries[MAX_INSNS] = "mulwu1", "mulwu1", { MNEM, ' ', OP (SRC1), ',', OP (SRC2), 0 }, { 16, 16, 0xf0f0 }, 0x50a0, - & fmt_79_mulwu1_ops[0], + & fmt_78_mulwu1_ops[0], { CGEN_INSN_NBOOL_ATTRS, 0, { (1<<MACH_M32RX), PIPE_S } } }, /* end-sanitize-m32rx */ @@ -2637,7 +2470,7 @@ const CGEN_INSN m32r_cgen_insn_table_entries[MAX_INSNS] = "maclh1", "maclh1", { MNEM, ' ', OP (SRC1), ',', OP (SRC2), 0 }, { 16, 16, 0xf0f0 }, 0x50c0, - & fmt_78_macwu1_ops[0], + & fmt_77_macwu1_ops[0], { CGEN_INSN_NBOOL_ATTRS, 0, { (1<<MACH_M32RX), PIPE_S } } }, /* end-sanitize-m32rx */ @@ -2648,7 +2481,7 @@ const CGEN_INSN m32r_cgen_insn_table_entries[MAX_INSNS] = "sc", "sc", { MNEM, 0 }, { 16, 16, 0xffff }, 0x7401, - & fmt_80_sc_ops[0], + & fmt_79_sc_ops[0], { CGEN_INSN_NBOOL_ATTRS, 0, { (1<<MACH_M32RX), PIPE_O } } }, /* end-sanitize-m32rx */ @@ -2659,7 +2492,7 @@ const CGEN_INSN m32r_cgen_insn_table_entries[MAX_INSNS] = "snc", "snc", { MNEM, 0 }, { 16, 16, 0xffff }, 0x7501, - & fmt_80_sc_ops[0], + & fmt_79_sc_ops[0], { CGEN_INSN_NBOOL_ATTRS, 0, { (1<<MACH_M32RX), PIPE_O } } }, /* end-sanitize-m32rx */ @@ -2711,7 +2544,7 @@ m32r_cgen_init_tables (mach) /* Main entry point for stuffing values in cgen_fields. */ -CGEN_INLINE void +void m32r_cgen_set_operand (opindex, valuep, fields) int opindex; const long * valuep; @@ -2772,6 +2605,9 @@ m32r_cgen_set_operand (opindex, valuep, fields) fields->f_acc = * valuep; break; /* end-sanitize-m32rx */ + case M32R_OPERAND_HASH : + fields->f_nil = * valuep; + break; case M32R_OPERAND_HI16 : fields->f_hi16 = * valuep; break; @@ -2803,7 +2639,7 @@ m32r_cgen_set_operand (opindex, valuep, fields) /* Main entry point for getting values from cgen_fields. */ -CGEN_INLINE long +long m32r_cgen_get_operand (opindex, fields) int opindex; const CGEN_FIELDS * fields; @@ -2865,6 +2701,9 @@ m32r_cgen_get_operand (opindex, fields) value = fields->f_acc; break; /* end-sanitize-m32rx */ + case M32R_OPERAND_HASH : + value = fields->f_nil; + break; case M32R_OPERAND_HI16 : value = fields->f_hi16; break; |