mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-16 14:31:59 +00:00
[mips][sched] Split IIseb into II_SEB and II_SEH
No functional change since there are no InstrItinData's. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@199396 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
ba8f9dde32
commit
1a6226f236
@ -188,8 +188,8 @@ let DecoderNamespace = "MicroMips", Predicates = [InMicroMips] in {
|
|||||||
def CLO_MM : MMRel, CountLeading1<"clo", GPR32Opnd>, CLO_FM_MM<0x12c>;
|
def CLO_MM : MMRel, CountLeading1<"clo", GPR32Opnd>, CLO_FM_MM<0x12c>;
|
||||||
|
|
||||||
/// Sign Ext In Register Instructions.
|
/// Sign Ext In Register Instructions.
|
||||||
def SEB_MM : MMRel, SignExtInReg<"seb", i8, GPR32Opnd>, SEB_FM_MM<0x0ac>;
|
def SEB_MM : MMRel, SignExtInReg<"seb", i8, GPR32Opnd, II_SEB>, SEB_FM_MM<0x0ac>;
|
||||||
def SEH_MM : MMRel, SignExtInReg<"seh", i16, GPR32Opnd>, SEB_FM_MM<0x0ec>;
|
def SEH_MM : MMRel, SignExtInReg<"seh", i16, GPR32Opnd, II_SEH>, SEB_FM_MM<0x0ec>;
|
||||||
|
|
||||||
/// Word Swap Bytes Within Halfwords
|
/// Word Swap Bytes Within Halfwords
|
||||||
def WSBH_MM : MMRel, SubwordSwap<"wsbh", GPR32Opnd>, SEB_FM_MM<0x1ec>;
|
def WSBH_MM : MMRel, SubwordSwap<"wsbh", GPR32Opnd>, SEB_FM_MM<0x1ec>;
|
||||||
|
@ -192,8 +192,8 @@ def PseudoMFLO64 : PseudoMFLOHI<GPR64, ACC128, MipsMFLO>;
|
|||||||
def PseudoMTLOHI64 : PseudoMTLOHI<ACC128, GPR64>;
|
def PseudoMTLOHI64 : PseudoMTLOHI<ACC128, GPR64>;
|
||||||
|
|
||||||
/// Sign Ext In Register Instructions.
|
/// Sign Ext In Register Instructions.
|
||||||
def SEB64 : SignExtInReg<"seb", i8, GPR64Opnd>, SEB_FM<0x10, 0x20>;
|
def SEB64 : SignExtInReg<"seb", i8, GPR64Opnd, II_SEB>, SEB_FM<0x10, 0x20>;
|
||||||
def SEH64 : SignExtInReg<"seh", i16, GPR64Opnd>, SEB_FM<0x18, 0x20>;
|
def SEH64 : SignExtInReg<"seh", i16, GPR64Opnd, II_SEH>, SEB_FM<0x18, 0x20>;
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Count Leading
|
/// Count Leading
|
||||||
|
@ -768,9 +768,10 @@ class CountLeading1<string opstr, RegisterOperand RO>:
|
|||||||
|
|
||||||
|
|
||||||
// Sign Extend in Register.
|
// Sign Extend in Register.
|
||||||
class SignExtInReg<string opstr, ValueType vt, RegisterOperand RO> :
|
class SignExtInReg<string opstr, ValueType vt, RegisterOperand RO,
|
||||||
|
InstrItinClass itin> :
|
||||||
InstSE<(outs RO:$rd), (ins RO:$rt), !strconcat(opstr, "\t$rd, $rt"),
|
InstSE<(outs RO:$rd), (ins RO:$rt), !strconcat(opstr, "\t$rd, $rt"),
|
||||||
[(set RO:$rd, (sext_inreg RO:$rt, vt))], IIseb, FrmR, opstr> {
|
[(set RO:$rd, (sext_inreg RO:$rt, vt))], itin, FrmR, opstr> {
|
||||||
let Predicates = [HasSEInReg, HasStdEnc];
|
let Predicates = [HasSEInReg, HasStdEnc];
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1082,8 +1083,8 @@ def MFHI : MMRel, MoveFromLOHI<"mfhi", GPR32Opnd, AC0>, MFLO_FM<0x10>;
|
|||||||
def MFLO : MMRel, MoveFromLOHI<"mflo", GPR32Opnd, AC0>, MFLO_FM<0x12>;
|
def MFLO : MMRel, MoveFromLOHI<"mflo", GPR32Opnd, AC0>, MFLO_FM<0x12>;
|
||||||
|
|
||||||
/// Sign Ext In Register Instructions.
|
/// Sign Ext In Register Instructions.
|
||||||
def SEB : MMRel, SignExtInReg<"seb", i8, GPR32Opnd>, SEB_FM<0x10, 0x20>;
|
def SEB : MMRel, SignExtInReg<"seb", i8, GPR32Opnd, II_SEB>, SEB_FM<0x10, 0x20>;
|
||||||
def SEH : MMRel, SignExtInReg<"seh", i16, GPR32Opnd>, SEB_FM<0x18, 0x20>;
|
def SEH : MMRel, SignExtInReg<"seh", i16, GPR32Opnd, II_SEH>, SEB_FM<0x18, 0x20>;
|
||||||
|
|
||||||
/// Count Leading
|
/// Count Leading
|
||||||
def CLZ : MMRel, CountLeading0<"clz", GPR32Opnd>, CLO_FM<0x20>;
|
def CLZ : MMRel, CountLeading0<"clz", GPR32Opnd>, CLO_FM<0x20>;
|
||||||
|
@ -25,7 +25,6 @@ def IIHiLo : InstrItinClass;
|
|||||||
def IIImul : InstrItinClass;
|
def IIImul : InstrItinClass;
|
||||||
def IIImult : InstrItinClass;
|
def IIImult : InstrItinClass;
|
||||||
def IIIdiv : InstrItinClass;
|
def IIIdiv : InstrItinClass;
|
||||||
def IIseb : InstrItinClass;
|
|
||||||
def IIslt : InstrItinClass;
|
def IIslt : InstrItinClass;
|
||||||
def IIFcvt : InstrItinClass;
|
def IIFcvt : InstrItinClass;
|
||||||
def IIFmove : InstrItinClass;
|
def IIFmove : InstrItinClass;
|
||||||
@ -76,6 +75,8 @@ def II_ORI : InstrItinClass;
|
|||||||
def II_RDHWR : InstrItinClass;
|
def II_RDHWR : InstrItinClass;
|
||||||
def II_ROTR : InstrItinClass;
|
def II_ROTR : InstrItinClass;
|
||||||
def II_ROTRV : InstrItinClass;
|
def II_ROTRV : InstrItinClass;
|
||||||
|
def II_SEB : InstrItinClass;
|
||||||
|
def II_SEH : InstrItinClass;
|
||||||
def II_SLL : InstrItinClass;
|
def II_SLL : InstrItinClass;
|
||||||
def II_SLLV : InstrItinClass;
|
def II_SLLV : InstrItinClass;
|
||||||
def II_SRA : InstrItinClass;
|
def II_SRA : InstrItinClass;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user