From: Akira Hatanaka Date: Fri, 21 Dec 2012 22:35:47 +0000 (+0000) Subject: [mips] Refactor logical NOR instructions. X-Git-Url: http://plrg.eecs.uci.edu/git/?a=commitdiff_plain;h=2a732ec272e3bab004a47abb452ad47bc4eb8c7b;p=oota-llvm.git [mips] Refactor logical NOR instructions. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@170937 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Target/Mips/Mips64InstrInfo.td b/lib/Target/Mips/Mips64InstrInfo.td index 39d147fec9e..d25087d9c39 100644 --- a/lib/Target/Mips/Mips64InstrInfo.td +++ b/lib/Target/Mips/Mips64InstrInfo.td @@ -105,7 +105,7 @@ def SLTu64 : SetCC_R<"sltu", setult, CPU64Regs>, ADD_FM<0, 0x2b>; def AND64 : ArithLogicR<"and", CPU64Regs, 1, IIAlu, and>, ADD_FM<0, 0x24>; def OR64 : ArithLogicR<"or", CPU64Regs, 1, IIAlu, or>, ADD_FM<0, 0x25>; def XOR64 : ArithLogicR<"xor", CPU64Regs, 1, IIAlu, xor>, ADD_FM<0, 0x26>; -def NOR64 : LogicNOR<0x00, 0x27, "nor", CPU64Regs>; +def NOR64 : LogicNOR<"nor", CPU64Regs>, ADD_FM<0, 0x27>; /// Shift Instructions def DSLL : shift_rotate_imm64<"dsll", shl>, SRA_FM<0x38, 0>; diff --git a/lib/Target/Mips/MipsInstrInfo.td b/lib/Target/Mips/MipsInstrInfo.td index 909aa6403e5..d9cce0b39a2 100644 --- a/lib/Target/Mips/MipsInstrInfo.td +++ b/lib/Target/Mips/MipsInstrInfo.td @@ -364,11 +364,10 @@ class MArithR func, string instr_asm, SDNode op, bit isComm = 0> : } // Logical -class LogicNOR op, bits<6> func, string instr_asm, RegisterClass RC>: - FR { - let shamt = 0; +class LogicNOR: + InstSE<(outs RC:$rd), (ins RC:$rs, RC:$rt), + !strconcat(opstr, "\t$rd, $rs, $rt"), + [(set RC:$rd, (not (or RC:$rs, RC:$rt)))], IIAlu, FrmR> { let isCommutable = 1; } @@ -881,7 +880,7 @@ def SLTu : SetCC_R<"sltu", setult, CPURegs>, ADD_FM<0, 0x2b>; def AND : ArithLogicR<"and", CPURegs, 1, IIAlu, and>, ADD_FM<0, 0x24>; def OR : ArithLogicR<"or", CPURegs, 1, IIAlu, or>, ADD_FM<0, 0x25>; def XOR : ArithLogicR<"xor", CPURegs, 1, IIAlu, xor>, ADD_FM<0, 0x26>; -def NOR : LogicNOR<0x00, 0x27, "nor", CPURegs>; +def NOR : LogicNOR<"nor", CPURegs>, ADD_FM<0, 0x27>; /// Shift Instructions def SLL : shift_rotate_imm32<"sll", shl>, SRA_FM<0, 0>;