mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-02 07:32:52 +00:00
[mips] Refactor logical NOR instructions.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@170937 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
a8215f4ec2
commit
2a732ec272
@ -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 AND64 : ArithLogicR<"and", CPU64Regs, 1, IIAlu, and>, ADD_FM<0, 0x24>;
|
||||||
def OR64 : ArithLogicR<"or", CPU64Regs, 1, IIAlu, or>, ADD_FM<0, 0x25>;
|
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 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
|
/// Shift Instructions
|
||||||
def DSLL : shift_rotate_imm64<"dsll", shl>, SRA_FM<0x38, 0>;
|
def DSLL : shift_rotate_imm64<"dsll", shl>, SRA_FM<0x38, 0>;
|
||||||
|
@ -364,11 +364,10 @@ class MArithR<bits<6> func, string instr_asm, SDNode op, bit isComm = 0> :
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Logical
|
// Logical
|
||||||
class LogicNOR<bits<6> op, bits<6> func, string instr_asm, RegisterClass RC>:
|
class LogicNOR<string opstr, RegisterClass RC>:
|
||||||
FR<op, func, (outs RC:$rd), (ins RC:$rs, RC:$rt),
|
InstSE<(outs RC:$rd), (ins RC:$rs, RC:$rt),
|
||||||
!strconcat(instr_asm, "\t$rd, $rs, $rt"),
|
!strconcat(opstr, "\t$rd, $rs, $rt"),
|
||||||
[(set RC:$rd, (not (or RC:$rs, RC:$rt)))], IIAlu> {
|
[(set RC:$rd, (not (or RC:$rs, RC:$rt)))], IIAlu, FrmR> {
|
||||||
let shamt = 0;
|
|
||||||
let isCommutable = 1;
|
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 AND : ArithLogicR<"and", CPURegs, 1, IIAlu, and>, ADD_FM<0, 0x24>;
|
||||||
def OR : ArithLogicR<"or", CPURegs, 1, IIAlu, or>, ADD_FM<0, 0x25>;
|
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 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
|
/// Shift Instructions
|
||||||
def SLL : shift_rotate_imm32<"sll", shl>, SRA_FM<0, 0>;
|
def SLL : shift_rotate_imm32<"sll", shl>, SRA_FM<0, 0>;
|
||||||
|
Loading…
Reference in New Issue
Block a user