[mips] Guard all short instructions correctly.

Reviewers: smaksimovic, atanasyan, abeserminji

Differential Revision: https://reviews.llvm.org/D47533

llvm-svn: 333645
This commit is contained in:
Simon Dardis 2018-05-31 12:47:01 +00:00
parent ac804c2238
commit d9a453832d
5 changed files with 110 additions and 33 deletions

View File

@ -1692,6 +1692,14 @@ def : MipsInstAlias<"negu $rt, $rs",
def : MipsInstAlias<"negu $rt",
(SUBU_MMR6 GPR32Opnd:$rt, ZERO, GPR32Opnd:$rt), 1>,
ISA_MICROMIPS32R6;
def : MipsInstAlias<"beqz16 $rs, $offset", (BEQZC16_MMR6 GPRMM16Opnd:$rs,
brtarget7_mm:$offset),
0>, ISA_MICROMIPS32R6;
def : MipsInstAlias<"bnez16 $rs, $offset", (BNEZC16_MMR6 GPRMM16Opnd:$rs,
brtarget7_mm:$offset),
0>, ISA_MICROMIPS32R6;
def : MipsInstAlias<"b16 $offset", (BC16_MMR6 brtarget10_mm:$offset), 0>,
ISA_MICROMIPS32R6;
//===----------------------------------------------------------------------===//
//

View File

@ -636,48 +636,58 @@ let FastISelShouldIgnore = 1 in {
LOGIC_FM_MM16<0x1>, ISA_MICROMIPS32_NOT_MIPS32R6;
}
def LBU16_MM : LoadMM16<"lbu16", GPRMM16Opnd, zextloadi8, II_LBU,
mem_mm_4>, LOAD_STORE_FM_MM16<0x02>;
mem_mm_4>, LOAD_STORE_FM_MM16<0x02>, ISA_MICROMIPS;
def LHU16_MM : LoadMM16<"lhu16", GPRMM16Opnd, zextloadi16, II_LHU,
mem_mm_4_lsl1>, LOAD_STORE_FM_MM16<0x0a>;
mem_mm_4_lsl1>, LOAD_STORE_FM_MM16<0x0a>, ISA_MICROMIPS;
def LW16_MM : LoadMM16<"lw16", GPRMM16Opnd, load, II_LW, mem_mm_4_lsl2>,
LOAD_STORE_FM_MM16<0x1a>;
LOAD_STORE_FM_MM16<0x1a>, ISA_MICROMIPS;
def SB16_MM : StoreMM16<"sb16", GPRMM16OpndZero, GPRMM16Opnd, truncstorei8,
II_SB, mem_mm_4>, LOAD_STORE_FM_MM16<0x22>;
II_SB, mem_mm_4>, LOAD_STORE_FM_MM16<0x22>,
ISA_MICROMIPS32_NOT_MIPS32R6;
def SH16_MM : StoreMM16<"sh16", GPRMM16OpndZero, GPRMM16Opnd, truncstorei16,
II_SH, mem_mm_4_lsl1>,
LOAD_STORE_FM_MM16<0x2a>;
LOAD_STORE_FM_MM16<0x2a>, ISA_MICROMIPS32_NOT_MIPS32R6;
def SW16_MM : StoreMM16<"sw16", GPRMM16OpndZero, GPRMM16Opnd, store, II_SW,
mem_mm_4_lsl2>, LOAD_STORE_FM_MM16<0x3a>;
mem_mm_4_lsl2>, LOAD_STORE_FM_MM16<0x3a>,
ISA_MICROMIPS32_NOT_MIPS32R6;
def LWGP_MM : LoadGPMM16<"lw", GPRMM16Opnd, II_LW, mem_mm_gp_simm7_lsl2>,
LOAD_GP_FM_MM16<0x19>;
LOAD_GP_FM_MM16<0x19>, ISA_MICROMIPS;
def LWSP_MM : LoadSPMM16<"lw", GPR32Opnd, II_LW, mem_mm_sp_imm5_lsl2>,
LOAD_STORE_SP_FM_MM16<0x12>;
LOAD_STORE_SP_FM_MM16<0x12>, ISA_MICROMIPS;
def SWSP_MM : StoreSPMM16<"sw", GPR32Opnd, II_SW, mem_mm_sp_imm5_lsl2>,
LOAD_STORE_SP_FM_MM16<0x32>;
def ADDIUR1SP_MM : AddImmUR1SP<"addiur1sp", GPRMM16Opnd>, ADDIUR1SP_FM_MM16;
def ADDIUR2_MM : AddImmUR2<"addiur2", GPRMM16Opnd>, ADDIUR2_FM_MM16;
def ADDIUS5_MM : AddImmUS5<"addius5", GPR32Opnd>, ADDIUS5_FM_MM16;
def ADDIUSP_MM : AddImmUSP<"addiusp">, ADDIUSP_FM_MM16;
LOAD_STORE_SP_FM_MM16<0x32>, ISA_MICROMIPS32_NOT_MIPS32R6;
def ADDIUR1SP_MM : AddImmUR1SP<"addiur1sp", GPRMM16Opnd>, ADDIUR1SP_FM_MM16,
ISA_MICROMIPS;
def ADDIUR2_MM : AddImmUR2<"addiur2", GPRMM16Opnd>, ADDIUR2_FM_MM16,
ISA_MICROMIPS;
def ADDIUS5_MM : AddImmUS5<"addius5", GPR32Opnd>, ADDIUS5_FM_MM16,
ISA_MICROMIPS;
def ADDIUSP_MM : AddImmUSP<"addiusp">, ADDIUSP_FM_MM16, ISA_MICROMIPS;
def MFHI16_MM : MoveFromHILOMM<"mfhi16", GPR32Opnd, AC0>,
MFHILO_FM_MM16<0x10>, ISA_MICROMIPS32_NOT_MIPS32R6;
def MFLO16_MM : MoveFromHILOMM<"mflo16", GPR32Opnd, AC0>,
MFHILO_FM_MM16<0x12>, ISA_MICROMIPS32_NOT_MIPS32R6;
def MOVE16_MM : MoveMM16<"move", GPR32Opnd>, MOVE_FM_MM16<0x03>;
def MOVE16_MM : MoveMM16<"move", GPR32Opnd>, MOVE_FM_MM16<0x03>,
ISA_MICROMIPS32_NOT_MIPS32R6;
def MOVEP_MM : MovePMM16<"movep", GPRMM16OpndMoveP>, MOVEP_FM_MM16,
ISA_MICROMIPS32_NOT_MIPS32R6;
def LI16_MM : LoadImmMM16<"li16", li16_imm, GPRMM16Opnd>, LI_FM_MM16,
IsAsCheapAsAMove;
IsAsCheapAsAMove, ISA_MICROMIPS32_NOT_MIPS32R6;
def JALR16_MM : JumpLinkRegMM16<"jalr", GPR32Opnd>, JALR_FM_MM16<0x0e>,
ISA_MICROMIPS32_NOT_MIPS32R6;
def JALRS16_MM : JumpLinkRegSMM16<"jalrs16", GPR32Opnd>, JALR_FM_MM16<0x0f>;
def JRC16_MM : JumpRegCMM16<"jrc", GPR32Opnd>, JALR_FM_MM16<0x0d>;
def JRADDIUSP : JumpRAddiuStackMM16, JRADDIUSP_FM_MM16<0x18>;
def JR16_MM : JumpRegMM16<"jr16", GPR32Opnd>, JALR_FM_MM16<0x0c>;
def JALRS16_MM : JumpLinkRegSMM16<"jalrs16", GPR32Opnd>, JALR_FM_MM16<0x0f>,
ISA_MICROMIPS32_NOT_MIPS32R6;
def JRC16_MM : JumpRegCMM16<"jrc", GPR32Opnd>, JALR_FM_MM16<0x0d>,
ISA_MICROMIPS32_NOT_MIPS32R6;
def JRADDIUSP : JumpRAddiuStackMM16, JRADDIUSP_FM_MM16<0x18>,
ISA_MICROMIPS32_NOT_MIPS32R6;
def JR16_MM : JumpRegMM16<"jr16", GPR32Opnd>, JALR_FM_MM16<0x0c>,
ISA_MICROMIPS32_NOT_MIPS32R6;
def BEQZ16_MM : CBranchZeroMM<"beqz16", brtarget7_mm, GPRMM16Opnd>,
BEQNEZ_FM_MM16<0x23>;
BEQNEZ_FM_MM16<0x23>, ISA_MICROMIPS32_NOT_MIPS32R6;
def BNEZ16_MM : CBranchZeroMM<"bnez16", brtarget7_mm, GPRMM16Opnd>,
BEQNEZ_FM_MM16<0x2b>;
def B16_MM : UncondBranchMM16<"b16">, B16_FM;
BEQNEZ_FM_MM16<0x2b>, ISA_MICROMIPS32_NOT_MIPS32R6;
def B16_MM : UncondBranchMM16<"b16">, B16_FM, ISA_MICROMIPS32_NOT_MIPS32R6;
def BREAK16_MM : BrkSdbbp16MM<"break16", II_BREAK>, BRKSDBBP16_FM_MM<0x28>,
ISA_MICROMIPS32_NOT_MIPS32R6;
def SDBBP16_MM : BrkSdbbp16MM<"sdbbp16", II_SDBBP>, BRKSDBBP16_FM_MM<0x2C>,

View File

@ -5,8 +5,8 @@
# RUN: | llvm-objdump -d -mattr=micromips - | FileCheck %s
# CHECK: 0: 8f 7e beqzc16 $6, -4
# CHECK: 6: cf fe bc16 -4
# CHECK: c: b7 ff ff fe balc -4
# CHECK: 2: cf fe bc16 -4
# CHECK: 4: b7 ff ff fe balc -4
beqz16 $6, -4
b16 -4

View File

@ -2,53 +2,99 @@
.set noat
addiusp -16 # CHECK: addiusp -16 # encoding: [0x4f,0xf9]
# CHECK: # <MCInst #{{.*}} ADDIUSP_MM
addiusp -1028 # CHECK: addiusp -1028 # encoding: [0x4f,0xff]
# CHECK: # <MCInst #{{.*}} ADDIUSP_MM
addiusp -1032 # CHECK: addiusp -1032 # encoding: [0x4f,0xfd]
# CHECK: # <MCInst #{{.*}} ADDIUSP_MM
addiusp 1024 # CHECK: addiusp 1024 # encoding: [0x4c,0x01]
# CHECK: # <MCInst #{{.*}} ADDIUSP_MM
addiusp 1028 # CHECK: addiusp 1028 # encoding: [0x4c,0x03]
# CHECK: # <MCInst #{{.*}} ADDIUSP_MM
andi16 $16, $2, 31 # CHECK: andi16 $16, $2, 31 # encoding: [0x2c,0x29]
# CHECK: # <MCInst #{{.*}} ANDI16_MM
jraddiusp 20 # CHECK: jraddiusp 20 # encoding: [0x47,0x05]
# CHECK: # <MCInst #{{.*}} JRADDIUSP
addu16 $6, $17, $4 # CHECK: addu16 $6, $17, $4 # encoding: [0x07,0x42]
# CHECK: # <MCInst #{{.*}} ADDU16_MM
subu16 $5, $16, $3 # CHECK: subu16 $5, $16, $3 # encoding: [0x06,0xb1]
# CHECK: # <MCInst #{{.*}} SUBU16_MM
and16 $16, $2 # CHECK: and16 $16, $2 # encoding: [0x44,0x82]
# CHECK: # <MCInst #{{.*}} AND16_MM
not16 $17, $3 # CHECK: not16 $17, $3 # encoding: [0x44,0x0b]
# CHECK: # <MCInst #{{.*}} NOT16_MM
or16 $16, $4 # CHECK: or16 $16, $4 # encoding: [0x44,0xc4]
# CHECK: # <MCInst #{{.*}} OR16_MM
xor16 $17, $5 # CHECK: xor16 $17, $5 # encoding: [0x44,0x4d]
# CHECK: # <MCInst #{{.*}} XOR16_MM
sll16 $3, $16, 5 # CHECK: sll16 $3, $16, 5 # encoding: [0x25,0x8a]
# CHECK: # <MCInst #{{.*}} SLL16_MM
srl16 $4, $17, 6 # CHECK: srl16 $4, $17, 6 # encoding: [0x26,0x1d]
# CHECK: # <MCInst #{{.*}} SRL16_MM
lbu16 $3, 4($17) # CHECK: lbu16 $3, 4($17) # encoding: [0x09,0x94]
# CHECK: # <MCInst #{{.*}} LBU16_MM
lbu16 $3, -1($16) # CHECK: lbu16 $3, -1($16) # encoding: [0x09,0x8f]
# CHECK: # <MCInst #{{.*}} LBU16_MM
lhu16 $3, 4($16) # CHECK: lhu16 $3, 4($16) # encoding: [0x29,0x82]
# CHECK: # <MCInst #{{.*}} LHU16_MM
lw16 $4, 8($17) # CHECK: lw16 $4, 8($17) # encoding: [0x6a,0x12]
# CHECK: # <MCInst #{{.*}} LW16_MM
sb16 $3, 4($16) # CHECK: sb16 $3, 4($16) # encoding: [0x89,0x84]
# CHECK: # <MCInst #{{.*}} SB16_MM
sh16 $4, 8($17) # CHECK: sh16 $4, 8($17) # encoding: [0xaa,0x14]
# CHECK: # <MCInst #{{.*}} SH16_MM
sw16 $4, 4($17) # CHECK: sw16 $4, 4($17) # encoding: [0xea,0x11]
# CHECK: # <MCInst #{{.*}} SW16_MM
sw16 $zero, 4($17) # CHECK: sw16 $zero, 4($17) # encoding: [0xe8,0x11]
# CHECK: # <MCInst #{{.*}} SW16_MM
mfhi16 $9 # CHECK: mfhi16 $9 # encoding: [0x46,0x09]
# CHECK: # <MCInst #{{.*}} MFHI16_MM
mflo16 $9 # CHECK: mflo16 $9 # encoding: [0x46,0x49]
# CHECK: # <MCInst #{{.*}} MFLO16_MM
move $25, $1 # CHECK: move $25, $1 # encoding: [0x0f,0x21]
# CHECK: # <MCInst #{{.*}} MOVE16_MM
jrc $9 # CHECK: jrc $9 # encoding: [0x45,0xa9]
# CHECK: # <MCInst #{{.*}} JRC16_MM
jalr $9 # CHECK: jalr $9 # encoding: [0x45,0xc9]
# CHECK: # <MCInst #{{.*}} JALR16_MM
jalrs16 $9 # CHECK: jalrs16 $9 # encoding: [0x45,0xe9]
# CHECK: # <MCInst #{{.*}} MOVE16_MM
jr16 $9 # CHECK: jr16 $9 # encoding: [0x45,0x89]
# CHECK: # <MCInst #{{.*}} JR16_MM
li16 $3, -1 # CHECK: li16 $3, -1 # encoding: [0xed,0xff]
# CHECK: # <MCInst #{{.*}} LI16_MM
li16 $3, 126 # CHECK: li16 $3, 126 # encoding: [0xed,0xfe]
# CHECK: # <MCInst #{{.*}} LI16_MM
addiur1sp $7, 4 # CHECK: addiur1sp $7, 4 # encoding: [0x6f,0x83]
# CHECK: # <MCInst #{{.*}} ADDIUR1SP_MM
addiur2 $6, $7, -1 # CHECK: addiur2 $6, $7, -1 # encoding: [0x6f,0x7e]
# CHECK: # <MCInst #{{.*}} ADDIUR2_MM
addiur2 $6, $7, 12 # CHECK: addiur2 $6, $7, 12 # encoding: [0x6f,0x76]
# CHECK: # <MCInst #{{.*}} ADDIUR2_MM
addius5 $7, -2 # CHECK: addius5 $7, -2 # encoding: [0x4c,0xfc]
nop # CHECK: nop # encoding: [0x00,0x00,0x00,0x00]
beqz16 $6, 20 # CHECK: beqz16 $6, 20 # encoding: [0x8f,0x0a]
# CHECK: # <MCInst #{{.*}} BEQZ16_MM
bnez16 $6, 20 # CHECK: bnez16 $6, 20 # encoding: [0xaf,0x0a]
# CHECK: # <MCInst #{{.*}} BNEZ16_MM
b16 132 # CHECK: b16 132 # encoding: [0xcc,0x42]
# CHECK: # <MCInst #{{.*}} B16_MM
lwm16 $16, $17, $ra, 8($sp) # CHECK: lwm16 $16, $17, $ra, 8($sp) # encoding: [0x45,0x12]
# CHECK: # <MCInst #{{.*}} LWM16_MM
swm16 $16, $17, $ra, 8($sp) # CHECK: swm16 $16, $17, $ra, 8($sp) # encoding: [0x45,0x52]
# CHECK: # <MCInst #{{.*}} SWM16_MM
movep $5, $6, $2, $3 # CHECK: movep $5, $6, $2, $3 # encoding: [0x84,0x34]
# CHECK: # <MCInst #{{.*}} MOVEP_MM
break16 8 # CHECK: break16 8 # encoding: [0x46,0x88]
# CHECK: # <MCInst #{{.*}} BREAK16_MM
sdbbp16 14 # CHECK: sdbbp16 14 # encoding: [0x46,0xce]
# CHECK: # <MCInst #{{.*}} SDBBP16_MM
lw $3, 32($sp) # CHECK: lw $3, 32($sp) # encoding: [0x48,0x68]
# CHECK: # <MCInst #{{.*}} LWSP_MM
sw $4, 124($sp) # CHECK: sw $4, 124($sp) # encoding: [0xc8,0x9f]
# CHECK: # <MCInst #{{.*}} SWSP_MM
lw $3, 32($gp) # CHECK: lw $3, 32($gp) # encoding: [0x65,0x88]
# CHECK: # <MCInst #{{.*}} LWGP_MM
abs.s $f0, $f2 # CHECK: abs.s $f0, $f2 # encoding: [0x54,0x02,0x03,0x7b]
# CHECK-NEXT: # <MCInst #{{[0-9]+}} FABS_S_MM
abs.d $f4, $f6 # CHECK: abs.d $f4, $f6 # encoding: [0x54,0x86,0x23,0x7b]

View File

@ -6,14 +6,23 @@
addu $3, $4, $5 # CHECK: addu $3, $4, $5 # encoding: [0x00,0xa4,0x19,0x50]
addiupc $4, 100 # CHECK: lapc $4, 100 # encoding: [0x78,0x80,0x00,0x19]
addiur1sp $7, 4 # CHECK: addiur1sp $7, 4 # encoding: [0x6f,0x83]
# CHECK: # <MCInst #{{.*}} ADDIUR1SP_MM
addiur2 $6, $7, -1 # CHECK: addiur2 $6, $7, -1 # encoding: [0x6f,0x7e]
# CHECK: # <MCInst #{{.*}} ADDIUR2_MM
addiur2 $6, $7, 12 # CHECK: addiur2 $6, $7, 12 # encoding: [0x6f,0x76]
# CHECK: # <MCInst #{{.*}} ADDIUR2_MM
addius5 $7, -2 # CHECK: addius5 $7, -2 # encoding: [0x4c,0xfc]
# CHECK: # <MCInst #{{.*}} ADDIUS5_MM
addiusp -1028 # CHECK: addiusp -1028 # encoding: [0x4f,0xff]
# CHECK: # <MCInst #{{.*}} ADDIUSP_MM
addiusp -1032 # CHECK: addiusp -1032 # encoding: [0x4f,0xfd]
# CHECK: # <MCInst #{{.*}} ADDIUSP_MM
addiusp 1024 # CHECK: addiusp 1024 # encoding: [0x4c,0x01]
# CHECK: # <MCInst #{{.*}} ADDIUSP_MM
addiusp 1028 # CHECK: addiusp 1028 # encoding: [0x4c,0x03]
# CHECK: # <MCInst #{{.*}} ADDIUSP_MM
addiusp -16 # CHECK: addiusp -16 # encoding: [0x4f,0xf9]
# CHECK: # <MCInst #{{.*}} ADDIUSP_MM
aluipc $3, 56 # CHECK: aluipc $3, 56 # encoding: [0x78,0x7f,0x00,0x38]
and $3, $4, $5 # CHECK: and $3, $4, $5 # encoding: [0x00,0xa4,0x1a,0x50]
andi $3, $4, 1234 # CHECK: andi $3, $4, 1234 # encoding: [0xd0,0x64,0x04,0xd2]
@ -36,11 +45,15 @@
bnezc $3, 64 # CHECK: bnezc $3, 64 # encoding: [0xa0,0x60,0x00,0x10]
balc 7286128 # CHECK: balc 7286128 # encoding: [0xb4,0x37,0x96,0xb8]
b 132 # CHECK: bc16 132 # encoding: [0xcc,0x42]
# CHECK: # <MCInst #{{.*}} BC16_MMR6
bc 7286128 # CHECK: bc 7286128 # encoding: [0x94,0x37,0x96,0xb8]
# CHECK-NEXT: # <MCInst #{{[0-9]+}} BC_MMR6
# CHECK: # <MCInst #{{.*}} BC_MMR6
bc16 132 # CHECK: bc16 132 # encoding: [0xcc,0x42]
# CHECK: # <MCInst #{{.*}} BC16_MMR6
beqzc16 $6, 20 # CHECK: beqzc16 $6, 20 # encoding: [0x8f,0x0a]
# CHECK: # <MCInst #{{.*}} BEQZC16_MMR6
bnezc16 $6, 20 # CHECK: bnezc16 $6, 20 # encoding: [0xaf,0x0a]
# CHECK: # <MCInst #{{.*}} BNEZC16_MMR6
bitswap $4, $2 # CHECK: bitswap $4, $2 # encoding: [0x00,0x44,0x0b,0x3c]
break # CHECK: break # encoding: [0x00,0x00,0x00,0x07]
break 7 # CHECK: break 7 # encoding: [0x00,0x07,0x00,0x07]