mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-19 04:32:19 +00:00
[mips] Remove asm string parameter from pseudo instructions. Add InstrItinClass
parameter. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@170661 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
77e85f367c
commit
1e7739f614
@ -46,19 +46,19 @@ class Mult64<bits<6> func, string instr_asm, InstrItinClass itin>:
|
|||||||
class Div64<SDNode op, bits<6> func, string instr_asm, InstrItinClass itin>:
|
class Div64<SDNode op, bits<6> func, string instr_asm, InstrItinClass itin>:
|
||||||
Div<op, func, instr_asm, itin, CPU64Regs, [HI64, LO64]>;
|
Div<op, func, instr_asm, itin, CPU64Regs, [HI64, LO64]>;
|
||||||
|
|
||||||
multiclass Atomic2Ops64<PatFrag Op, string Opstr> {
|
multiclass Atomic2Ops64<PatFrag Op> {
|
||||||
def #NAME# : Atomic2Ops<Op, Opstr, CPU64Regs, CPURegs>,
|
def #NAME# : Atomic2Ops<Op, CPU64Regs, CPURegs>,
|
||||||
Requires<[NotN64, HasStdEnc]>;
|
Requires<[NotN64, HasStdEnc]>;
|
||||||
def _P8 : Atomic2Ops<Op, Opstr, CPU64Regs, CPU64Regs>,
|
def _P8 : Atomic2Ops<Op, CPU64Regs, CPU64Regs>,
|
||||||
Requires<[IsN64, HasStdEnc]> {
|
Requires<[IsN64, HasStdEnc]> {
|
||||||
let isCodeGenOnly = 1;
|
let isCodeGenOnly = 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
multiclass AtomicCmpSwap64<PatFrag Op, string Width> {
|
multiclass AtomicCmpSwap64<PatFrag Op> {
|
||||||
def #NAME# : AtomicCmpSwap<Op, Width, CPU64Regs, CPURegs>,
|
def #NAME# : AtomicCmpSwap<Op, CPU64Regs, CPURegs>,
|
||||||
Requires<[NotN64, HasStdEnc]>;
|
Requires<[NotN64, HasStdEnc]>;
|
||||||
def _P8 : AtomicCmpSwap<Op, Width, CPU64Regs, CPU64Regs>,
|
def _P8 : AtomicCmpSwap<Op, CPU64Regs, CPU64Regs>,
|
||||||
Requires<[IsN64, HasStdEnc]> {
|
Requires<[IsN64, HasStdEnc]> {
|
||||||
let isCodeGenOnly = 1;
|
let isCodeGenOnly = 1;
|
||||||
}
|
}
|
||||||
@ -66,14 +66,14 @@ multiclass AtomicCmpSwap64<PatFrag Op, string Width> {
|
|||||||
}
|
}
|
||||||
let usesCustomInserter = 1, Predicates = [HasStdEnc],
|
let usesCustomInserter = 1, Predicates = [HasStdEnc],
|
||||||
DecoderNamespace = "Mips64" in {
|
DecoderNamespace = "Mips64" in {
|
||||||
defm ATOMIC_LOAD_ADD_I64 : Atomic2Ops64<atomic_load_add_64, "load_add_64">;
|
defm ATOMIC_LOAD_ADD_I64 : Atomic2Ops64<atomic_load_add_64>;
|
||||||
defm ATOMIC_LOAD_SUB_I64 : Atomic2Ops64<atomic_load_sub_64, "load_sub_64">;
|
defm ATOMIC_LOAD_SUB_I64 : Atomic2Ops64<atomic_load_sub_64>;
|
||||||
defm ATOMIC_LOAD_AND_I64 : Atomic2Ops64<atomic_load_and_64, "load_and_64">;
|
defm ATOMIC_LOAD_AND_I64 : Atomic2Ops64<atomic_load_and_64>;
|
||||||
defm ATOMIC_LOAD_OR_I64 : Atomic2Ops64<atomic_load_or_64, "load_or_64">;
|
defm ATOMIC_LOAD_OR_I64 : Atomic2Ops64<atomic_load_or_64>;
|
||||||
defm ATOMIC_LOAD_XOR_I64 : Atomic2Ops64<atomic_load_xor_64, "load_xor_64">;
|
defm ATOMIC_LOAD_XOR_I64 : Atomic2Ops64<atomic_load_xor_64>;
|
||||||
defm ATOMIC_LOAD_NAND_I64 : Atomic2Ops64<atomic_load_nand_64, "load_nand_64">;
|
defm ATOMIC_LOAD_NAND_I64 : Atomic2Ops64<atomic_load_nand_64>;
|
||||||
defm ATOMIC_SWAP_I64 : Atomic2Ops64<atomic_swap_64, "swap_64">;
|
defm ATOMIC_SWAP_I64 : Atomic2Ops64<atomic_swap_64>;
|
||||||
defm ATOMIC_CMP_SWAP_I64 : AtomicCmpSwap64<atomic_cmp_swap_64, "64">;
|
defm ATOMIC_CMP_SWAP_I64 : AtomicCmpSwap64<atomic_cmp_swap_64>;
|
||||||
}
|
}
|
||||||
|
|
||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
|
@ -24,8 +24,9 @@ class DSPInst : MipsInst<(outs), (ins), "", [], NoItinerary, FrmOther> {
|
|||||||
let Predicates = [HasDSP];
|
let Predicates = [HasDSP];
|
||||||
}
|
}
|
||||||
|
|
||||||
class PseudoDSP<dag outs, dag ins, list<dag> pattern>:
|
class PseudoDSP<dag outs, dag ins, list<dag> pattern,
|
||||||
MipsPseudo<outs, ins, "", pattern> {
|
InstrItinClass itin = IIPseudo>:
|
||||||
|
MipsPseudo<outs, ins, pattern, itin> {
|
||||||
let Predicates = [HasDSP];
|
let Predicates = [HasDSP];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -486,7 +486,7 @@ class MULT_DESC_BASE<string instr_asm> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
class BPOSGE32_PSEUDO_DESC_BASE<SDPatternOperator OpNode, InstrItinClass itin> :
|
class BPOSGE32_PSEUDO_DESC_BASE<SDPatternOperator OpNode, InstrItinClass itin> :
|
||||||
MipsPseudo<(outs CPURegs:$dst), (ins), "", [(set CPURegs:$dst, (OpNode))]> {
|
MipsPseudo<(outs CPURegs:$dst), (ins), [(set CPURegs:$dst, (OpNode))]> {
|
||||||
list<Register> Uses = [DSPCtrl];
|
list<Register> Uses = [DSPCtrl];
|
||||||
bit usesCustomInserter = 1;
|
bit usesCustomInserter = 1;
|
||||||
}
|
}
|
||||||
|
@ -437,14 +437,13 @@ def FCMP_D64 : CEQS_FT<"d", FGR64, IIFcmp, MipsFPCmp>, CEQS_FM<17>,
|
|||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
// Floating Point Pseudo-Instructions
|
// Floating Point Pseudo-Instructions
|
||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
def MOVCCRToCCR : PseudoSE<(outs CCR:$dst), (ins CCR:$src),
|
def MOVCCRToCCR : PseudoSE<(outs CCR:$dst), (ins CCR:$src), []>;
|
||||||
"# MOVCCRToCCR", []>;
|
|
||||||
|
|
||||||
// This pseudo instr gets expanded into 2 mtc1 instrs after register
|
// This pseudo instr gets expanded into 2 mtc1 instrs after register
|
||||||
// allocation.
|
// allocation.
|
||||||
def BuildPairF64 :
|
def BuildPairF64 :
|
||||||
PseudoSE<(outs AFGR64:$dst),
|
PseudoSE<(outs AFGR64:$dst),
|
||||||
(ins CPURegs:$lo, CPURegs:$hi), "",
|
(ins CPURegs:$lo, CPURegs:$hi),
|
||||||
[(set AFGR64:$dst, (MipsBuildPairF64 CPURegs:$lo, CPURegs:$hi))]>;
|
[(set AFGR64:$dst, (MipsBuildPairF64 CPURegs:$lo, CPURegs:$hi))]>;
|
||||||
|
|
||||||
// This pseudo instr gets expanded into 2 mfc1 instrs after register
|
// This pseudo instr gets expanded into 2 mfc1 instrs after register
|
||||||
@ -452,7 +451,7 @@ def BuildPairF64 :
|
|||||||
// if n is 0, lower part of src is extracted.
|
// if n is 0, lower part of src is extracted.
|
||||||
// if n is 1, higher part of src is extracted.
|
// if n is 1, higher part of src is extracted.
|
||||||
def ExtractElementF64 :
|
def ExtractElementF64 :
|
||||||
PseudoSE<(outs CPURegs:$dst), (ins AFGR64:$src, i32imm:$n), "",
|
PseudoSE<(outs CPURegs:$dst), (ins AFGR64:$src, i32imm:$n),
|
||||||
[(set CPURegs:$dst, (MipsExtractElementF64 AFGR64:$src, imm:$n))]>;
|
[(set CPURegs:$dst, (MipsExtractElementF64 AFGR64:$src, imm:$n))]>;
|
||||||
|
|
||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
|
@ -80,15 +80,17 @@ class InstSE<dag outs, dag ins, string asmstr, list<dag> pattern,
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Mips Pseudo Instructions Format
|
// Mips Pseudo Instructions Format
|
||||||
class MipsPseudo<dag outs, dag ins, string asmstr, list<dag> pattern>:
|
class MipsPseudo<dag outs, dag ins, list<dag> pattern,
|
||||||
MipsInst<outs, ins, asmstr, pattern, IIPseudo, Pseudo> {
|
InstrItinClass itin = IIPseudo> :
|
||||||
|
MipsInst<outs, ins, "", pattern, itin, Pseudo> {
|
||||||
let isCodeGenOnly = 1;
|
let isCodeGenOnly = 1;
|
||||||
let isPseudo = 1;
|
let isPseudo = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Mips32/64 Pseudo Instruction Format
|
// Mips32/64 Pseudo Instruction Format
|
||||||
class PseudoSE<dag outs, dag ins, string asmstr, list<dag> pattern>:
|
class PseudoSE<dag outs, dag ins, list<dag> pattern,
|
||||||
MipsPseudo<outs, ins, asmstr, pattern> {
|
InstrItinClass itin = IIPseudo>:
|
||||||
|
MipsPseudo<outs, ins, pattern, itin> {
|
||||||
let Predicates = [HasStdEnc];
|
let Predicates = [HasStdEnc];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -789,32 +789,27 @@ class InsBase<bits<6> _funct, string instr_asm, RegisterClass RC>:
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Atomic instructions with 2 source operands (ATOMIC_SWAP & ATOMIC_LOAD_*).
|
// Atomic instructions with 2 source operands (ATOMIC_SWAP & ATOMIC_LOAD_*).
|
||||||
class Atomic2Ops<PatFrag Op, string Opstr, RegisterClass DRC,
|
class Atomic2Ops<PatFrag Op, RegisterClass DRC, RegisterClass PRC> :
|
||||||
RegisterClass PRC> :
|
|
||||||
PseudoSE<(outs DRC:$dst), (ins PRC:$ptr, DRC:$incr),
|
PseudoSE<(outs DRC:$dst), (ins PRC:$ptr, DRC:$incr),
|
||||||
!strconcat("atomic_", Opstr, "\t$dst, $ptr, $incr"),
|
|
||||||
[(set DRC:$dst, (Op PRC:$ptr, DRC:$incr))]>;
|
[(set DRC:$dst, (Op PRC:$ptr, DRC:$incr))]>;
|
||||||
|
|
||||||
multiclass Atomic2Ops32<PatFrag Op, string Opstr> {
|
multiclass Atomic2Ops32<PatFrag Op> {
|
||||||
def #NAME# : Atomic2Ops<Op, Opstr, CPURegs, CPURegs>,
|
def #NAME# : Atomic2Ops<Op, CPURegs, CPURegs>, Requires<[NotN64, HasStdEnc]>;
|
||||||
Requires<[NotN64, HasStdEnc]>;
|
def _P8 : Atomic2Ops<Op, CPURegs, CPU64Regs>,
|
||||||
def _P8 : Atomic2Ops<Op, Opstr, CPURegs, CPU64Regs>,
|
Requires<[IsN64, HasStdEnc]> {
|
||||||
Requires<[IsN64, HasStdEnc]> {
|
|
||||||
let DecoderNamespace = "Mips64";
|
let DecoderNamespace = "Mips64";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Atomic Compare & Swap.
|
// Atomic Compare & Swap.
|
||||||
class AtomicCmpSwap<PatFrag Op, string Width, RegisterClass DRC,
|
class AtomicCmpSwap<PatFrag Op, RegisterClass DRC, RegisterClass PRC> :
|
||||||
RegisterClass PRC> :
|
|
||||||
PseudoSE<(outs DRC:$dst), (ins PRC:$ptr, DRC:$cmp, DRC:$swap),
|
PseudoSE<(outs DRC:$dst), (ins PRC:$ptr, DRC:$cmp, DRC:$swap),
|
||||||
!strconcat("atomic_cmp_swap_", Width, "\t$dst, $ptr, $cmp, $swap"),
|
|
||||||
[(set DRC:$dst, (Op PRC:$ptr, DRC:$cmp, DRC:$swap))]>;
|
[(set DRC:$dst, (Op PRC:$ptr, DRC:$cmp, DRC:$swap))]>;
|
||||||
|
|
||||||
multiclass AtomicCmpSwap32<PatFrag Op, string Width> {
|
multiclass AtomicCmpSwap32<PatFrag Op> {
|
||||||
def #NAME# : AtomicCmpSwap<Op, Width, CPURegs, CPURegs>,
|
def #NAME# : AtomicCmpSwap<Op, CPURegs, CPURegs>,
|
||||||
Requires<[NotN64, HasStdEnc]>;
|
Requires<[NotN64, HasStdEnc]>;
|
||||||
def _P8 : AtomicCmpSwap<Op, Width, CPURegs, CPU64Regs>,
|
def _P8 : AtomicCmpSwap<Op, CPURegs, CPU64Regs>,
|
||||||
Requires<[IsN64, HasStdEnc]> {
|
Requires<[IsN64, HasStdEnc]> {
|
||||||
let DecoderNamespace = "Mips64";
|
let DecoderNamespace = "Mips64";
|
||||||
}
|
}
|
||||||
@ -839,44 +834,42 @@ class SCBase<bits<6> Opc, string opstring, RegisterClass RC, Operand Mem> :
|
|||||||
|
|
||||||
// Return RA.
|
// Return RA.
|
||||||
let isReturn=1, isTerminator=1, hasDelaySlot=1, isBarrier=1, hasCtrlDep=1 in
|
let isReturn=1, isTerminator=1, hasDelaySlot=1, isBarrier=1, hasCtrlDep=1 in
|
||||||
def RetRA : PseudoSE<(outs), (ins), "", [(MipsRet)]>;
|
def RetRA : PseudoSE<(outs), (ins), [(MipsRet)]>;
|
||||||
|
|
||||||
let Defs = [SP], Uses = [SP], hasSideEffects = 1 in {
|
let Defs = [SP], Uses = [SP], hasSideEffects = 1 in {
|
||||||
def ADJCALLSTACKDOWN : MipsPseudo<(outs), (ins i32imm:$amt),
|
def ADJCALLSTACKDOWN : MipsPseudo<(outs), (ins i32imm:$amt),
|
||||||
"!ADJCALLSTACKDOWN $amt",
|
|
||||||
[(callseq_start timm:$amt)]>;
|
[(callseq_start timm:$amt)]>;
|
||||||
def ADJCALLSTACKUP : MipsPseudo<(outs), (ins i32imm:$amt1, i32imm:$amt2),
|
def ADJCALLSTACKUP : MipsPseudo<(outs), (ins i32imm:$amt1, i32imm:$amt2),
|
||||||
"!ADJCALLSTACKUP $amt1",
|
|
||||||
[(callseq_end timm:$amt1, timm:$amt2)]>;
|
[(callseq_end timm:$amt1, timm:$amt2)]>;
|
||||||
}
|
}
|
||||||
|
|
||||||
let usesCustomInserter = 1 in {
|
let usesCustomInserter = 1 in {
|
||||||
defm ATOMIC_LOAD_ADD_I8 : Atomic2Ops32<atomic_load_add_8, "load_add_8">;
|
defm ATOMIC_LOAD_ADD_I8 : Atomic2Ops32<atomic_load_add_8>;
|
||||||
defm ATOMIC_LOAD_ADD_I16 : Atomic2Ops32<atomic_load_add_16, "load_add_16">;
|
defm ATOMIC_LOAD_ADD_I16 : Atomic2Ops32<atomic_load_add_16>;
|
||||||
defm ATOMIC_LOAD_ADD_I32 : Atomic2Ops32<atomic_load_add_32, "load_add_32">;
|
defm ATOMIC_LOAD_ADD_I32 : Atomic2Ops32<atomic_load_add_32>;
|
||||||
defm ATOMIC_LOAD_SUB_I8 : Atomic2Ops32<atomic_load_sub_8, "load_sub_8">;
|
defm ATOMIC_LOAD_SUB_I8 : Atomic2Ops32<atomic_load_sub_8>;
|
||||||
defm ATOMIC_LOAD_SUB_I16 : Atomic2Ops32<atomic_load_sub_16, "load_sub_16">;
|
defm ATOMIC_LOAD_SUB_I16 : Atomic2Ops32<atomic_load_sub_16>;
|
||||||
defm ATOMIC_LOAD_SUB_I32 : Atomic2Ops32<atomic_load_sub_32, "load_sub_32">;
|
defm ATOMIC_LOAD_SUB_I32 : Atomic2Ops32<atomic_load_sub_32>;
|
||||||
defm ATOMIC_LOAD_AND_I8 : Atomic2Ops32<atomic_load_and_8, "load_and_8">;
|
defm ATOMIC_LOAD_AND_I8 : Atomic2Ops32<atomic_load_and_8>;
|
||||||
defm ATOMIC_LOAD_AND_I16 : Atomic2Ops32<atomic_load_and_16, "load_and_16">;
|
defm ATOMIC_LOAD_AND_I16 : Atomic2Ops32<atomic_load_and_16>;
|
||||||
defm ATOMIC_LOAD_AND_I32 : Atomic2Ops32<atomic_load_and_32, "load_and_32">;
|
defm ATOMIC_LOAD_AND_I32 : Atomic2Ops32<atomic_load_and_32>;
|
||||||
defm ATOMIC_LOAD_OR_I8 : Atomic2Ops32<atomic_load_or_8, "load_or_8">;
|
defm ATOMIC_LOAD_OR_I8 : Atomic2Ops32<atomic_load_or_8>;
|
||||||
defm ATOMIC_LOAD_OR_I16 : Atomic2Ops32<atomic_load_or_16, "load_or_16">;
|
defm ATOMIC_LOAD_OR_I16 : Atomic2Ops32<atomic_load_or_16>;
|
||||||
defm ATOMIC_LOAD_OR_I32 : Atomic2Ops32<atomic_load_or_32, "load_or_32">;
|
defm ATOMIC_LOAD_OR_I32 : Atomic2Ops32<atomic_load_or_32>;
|
||||||
defm ATOMIC_LOAD_XOR_I8 : Atomic2Ops32<atomic_load_xor_8, "load_xor_8">;
|
defm ATOMIC_LOAD_XOR_I8 : Atomic2Ops32<atomic_load_xor_8>;
|
||||||
defm ATOMIC_LOAD_XOR_I16 : Atomic2Ops32<atomic_load_xor_16, "load_xor_16">;
|
defm ATOMIC_LOAD_XOR_I16 : Atomic2Ops32<atomic_load_xor_16>;
|
||||||
defm ATOMIC_LOAD_XOR_I32 : Atomic2Ops32<atomic_load_xor_32, "load_xor_32">;
|
defm ATOMIC_LOAD_XOR_I32 : Atomic2Ops32<atomic_load_xor_32>;
|
||||||
defm ATOMIC_LOAD_NAND_I8 : Atomic2Ops32<atomic_load_nand_8, "load_nand_8">;
|
defm ATOMIC_LOAD_NAND_I8 : Atomic2Ops32<atomic_load_nand_8>;
|
||||||
defm ATOMIC_LOAD_NAND_I16 : Atomic2Ops32<atomic_load_nand_16, "load_nand_16">;
|
defm ATOMIC_LOAD_NAND_I16 : Atomic2Ops32<atomic_load_nand_16>;
|
||||||
defm ATOMIC_LOAD_NAND_I32 : Atomic2Ops32<atomic_load_nand_32, "load_nand_32">;
|
defm ATOMIC_LOAD_NAND_I32 : Atomic2Ops32<atomic_load_nand_32>;
|
||||||
|
|
||||||
defm ATOMIC_SWAP_I8 : Atomic2Ops32<atomic_swap_8, "swap_8">;
|
defm ATOMIC_SWAP_I8 : Atomic2Ops32<atomic_swap_8>;
|
||||||
defm ATOMIC_SWAP_I16 : Atomic2Ops32<atomic_swap_16, "swap_16">;
|
defm ATOMIC_SWAP_I16 : Atomic2Ops32<atomic_swap_16>;
|
||||||
defm ATOMIC_SWAP_I32 : Atomic2Ops32<atomic_swap_32, "swap_32">;
|
defm ATOMIC_SWAP_I32 : Atomic2Ops32<atomic_swap_32>;
|
||||||
|
|
||||||
defm ATOMIC_CMP_SWAP_I8 : AtomicCmpSwap32<atomic_cmp_swap_8, "8">;
|
defm ATOMIC_CMP_SWAP_I8 : AtomicCmpSwap32<atomic_cmp_swap_8>;
|
||||||
defm ATOMIC_CMP_SWAP_I16 : AtomicCmpSwap32<atomic_cmp_swap_16, "16">;
|
defm ATOMIC_CMP_SWAP_I16 : AtomicCmpSwap32<atomic_cmp_swap_16>;
|
||||||
defm ATOMIC_CMP_SWAP_I32 : AtomicCmpSwap32<atomic_cmp_swap_32, "32">;
|
defm ATOMIC_CMP_SWAP_I32 : AtomicCmpSwap32<atomic_cmp_swap_32>;
|
||||||
}
|
}
|
||||||
|
|
||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
|
Loading…
x
Reference in New Issue
Block a user