From ec51bc6f3a2ad02e5b76b72459f1051e21a3d9da Mon Sep 17 00:00:00 2001 From: Colin LeMahieu Date: Fri, 5 Dec 2014 21:38:29 +0000 Subject: [PATCH] [Hexagon] Adding sub/and/or reg, imm forms git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@223522 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/Target/Hexagon/HexagonInstrInfo.td | 85 ++++++++++++++-------- test/MC/Disassembler/Hexagon/alu32_alu.txt | 6 ++ 2 files changed, 62 insertions(+), 29 deletions(-) diff --git a/lib/Target/Hexagon/HexagonInstrInfo.td b/lib/Target/Hexagon/HexagonInstrInfo.td index 8f70ace2fcc..31bdf78e1f3 100644 --- a/lib/Target/Hexagon/HexagonInstrInfo.td +++ b/lib/Target/Hexagon/HexagonInstrInfo.td @@ -375,12 +375,68 @@ multiclass Addri_base { let isCodeGenOnly = 0 in defm ADD_ri : Addri_base<"add", add>, ImmRegRel, PredNewRel; +//===----------------------------------------------------------------------===// +// Template class used for the following ALU32 instructions. +// Rd=and(Rs,#s10) +// Rd=or(Rs,#s10) +//===----------------------------------------------------------------------===// +let isExtendable = 1, opExtendable = 2, isExtentSigned = 1, opExtentBits = 10, +InputType = "imm", hasNewValue = 1 in +class T_ALU32ri_logical MinOp> + : ALU32_ri <(outs IntRegs:$Rd), + (ins IntRegs:$Rs, s10Ext:$s10), + "$Rd = "#mnemonic#"($Rs, #$s10)" , + [(set (i32 IntRegs:$Rd), (OpNode (i32 IntRegs:$Rs), s10ExtPred:$s10))]> { + bits<5> Rd; + bits<5> Rs; + bits<10> s10; + let CextOpcode = mnemonic; + + let IClass = 0b0111; + + let Inst{27-24} = 0b0110; + let Inst{23-22} = MinOp; + let Inst{21} = s10{9}; + let Inst{20-16} = Rs; + let Inst{13-5} = s10{8-0}; + let Inst{4-0} = Rd; + } + +let isCodeGenOnly = 0 in { +def OR_ri : T_ALU32ri_logical<"or", or, 0b10>, ImmRegRel; +def AND_ri : T_ALU32ri_logical<"and", and, 0b00>, ImmRegRel; +} + +// Subtract register from immediate +// Rd32=sub(#s10,Rs32) +let isExtendable = 1, opExtendable = 1, isExtentSigned = 1, opExtentBits = 10, +CextOpcode = "sub", InputType = "imm", hasNewValue = 1, isCodeGenOnly = 0 in +def SUB_ri: ALU32_ri <(outs IntRegs:$Rd), (ins s10Ext:$s10, IntRegs:$Rs), + "$Rd = sub(#$s10, $Rs)" , + [(set IntRegs:$Rd, (sub s10ExtPred:$s10, IntRegs:$Rs))] > , + ImmRegRel { + bits<5> Rd; + bits<10> s10; + bits<5> Rs; + + let IClass = 0b0111; + + let Inst{27-22} = 0b011001; + let Inst{21} = s10{9}; + let Inst{20-16} = Rs; + let Inst{13-5} = s10{8-0}; + let Inst{4-0} = Rd; + } + // Nop. let hasSideEffects = 0, isCodeGenOnly = 0 in def A2_nop: ALU32Inst <(outs), (ins), "nop" > { let IClass = 0b0111; let Inst{27-24} = 0b1111; } +// Rd = not(Rs) gets mapped to Rd=sub(#-1, Rs). +def : Pat<(not (i32 IntRegs:$src1)), + (SUB_ri -1, (i32 IntRegs:$src1))>; multiclass ALU32_Pbase { @@ -568,35 +624,6 @@ class COMBINE_imm : let isExtendable = 1, opExtendable = 1, isExtentSigned = 1, opExtentBits = 8 in def COMBINE_Ii : COMBINE_imm; -let isExtendable = 1, opExtendable = 2, isExtentSigned = 1, opExtentBits = 10, -CextOpcode = "OR", InputType = "imm" in -def OR_ri : ALU32_ri<(outs IntRegs:$dst), - (ins IntRegs:$src1, s10Ext:$src2), - "$dst = or($src1, #$src2)", - [(set (i32 IntRegs:$dst), (or (i32 IntRegs:$src1), - s10ExtPred:$src2))]>, ImmRegRel; - -let isExtendable = 1, opExtendable = 2, isExtentSigned = 1, opExtentBits = 10, -InputType = "imm", CextOpcode = "AND" in -def AND_ri : ALU32_ri<(outs IntRegs:$dst), - (ins IntRegs:$src1, s10Ext:$src2), - "$dst = and($src1, #$src2)", - [(set (i32 IntRegs:$dst), (and (i32 IntRegs:$src1), - s10ExtPred:$src2))]>, ImmRegRel; - -// Rd32=sub(#s10,Rs32) -let isExtendable = 1, opExtendable = 1, isExtentSigned = 1, opExtentBits = 10, -CextOpcode = "SUB", InputType = "imm" in -def SUB_ri : ALU32_ri<(outs IntRegs:$dst), - (ins s10Ext:$src1, IntRegs:$src2), - "$dst = sub(#$src1, $src2)", - [(set IntRegs:$dst, (sub s10ExtPred:$src1, IntRegs:$src2))]>, - ImmRegRel; - -// Rd = not(Rs) gets mapped to Rd=sub(#-1, Rs). -def : Pat<(not (i32 IntRegs:$src1)), - (SUB_ri -1, (i32 IntRegs:$src1))>; - // Rd = neg(Rs) gets mapped to Rd=sub(#0, Rs). // Pattern definition for 'neg' was not necessary. diff --git a/test/MC/Disassembler/Hexagon/alu32_alu.txt b/test/MC/Disassembler/Hexagon/alu32_alu.txt index 10ee34f6742..c90a61dd793 100644 --- a/test/MC/Disassembler/Hexagon/alu32_alu.txt +++ b/test/MC/Disassembler/Hexagon/alu32_alu.txt @@ -6,12 +6,18 @@ # CHECK: r17 = add(r21, r31) 0x11 0xdf 0x15 0xf1 # CHECK: r17 = and(r21, r31) +0xf1 0xc3 0x15 0x76 +# CHECK: r17 = and(r21, #31) 0x11 0xdf 0x35 0xf1 # CHECK: r17 = or(r21, r31) +0xf1 0xc3 0x95 0x76 +# CHECK: r17 = or(r21, #31) 0x11 0xdf 0x75 0xf1 # CHECK: r17 = xor(r21, r31) 0x00 0xc0 0x00 0x7f # CHECK: nop +0xb1 0xc2 0x5f 0x76 +# CHECK: r17 = sub(#21, r31) 0x11 0xdf 0x35 0xf3 # CHECK: r17 = sub(r31, r21) 0x11 0xc0 0xbf 0x70