forked from OSchip/llvm-project
141 lines
6.1 KiB
TableGen
141 lines
6.1 KiB
TableGen
include "llvm/Target/Target.td"
|
|
|
|
def TestTargetInstrInfo : InstrInfo;
|
|
|
|
def TestTarget : Target {
|
|
let InstructionSet = TestTargetInstrInfo;
|
|
}
|
|
|
|
class Indexes<int N> {
|
|
list<int> all = [0, 1, 2, 3, 4, 5, 6 , 7,
|
|
8, 9, 10, 11, 12, 13, 14, 15,
|
|
16, 17, 18, 19, 20, 21, 22, 23,
|
|
24, 25, 26, 27, 28, 29, 30, 31];
|
|
list<int> slice =
|
|
!foldl([]<int>, all, acc, cur,
|
|
!listconcat(acc, !if(!lt(cur, N), [cur], [])));
|
|
}
|
|
|
|
#ifdef USE_NAMESPACE
|
|
let Namespace = "TestNamespace" in {
|
|
#endif
|
|
foreach Index = 0...31 in {
|
|
def sub#Index : SubRegIndex<32, !shl(Index, 5)>;
|
|
}
|
|
|
|
foreach Size = {2,4,8,16} in {
|
|
foreach Index = Indexes<!add(33, !mul(Size, -1))>.slice in {
|
|
def !foldl("", Indexes<Size>.slice, acc, cur,
|
|
!strconcat(acc#!if(!eq(acc,""),"","_"), "sub"#!add(cur, Index))) :
|
|
SubRegIndex<!mul(Size, 32), !shl(Index, 5)> {
|
|
let CoveringSubRegIndices =
|
|
!foldl([]<SubRegIndex>, Indexes<Size>.slice, acc, cur,
|
|
!listconcat(acc, [!cast<SubRegIndex>(sub#!add(cur, Index))]));
|
|
}
|
|
}
|
|
}
|
|
|
|
foreach Index = 0...255 in {
|
|
def R#Index : Register <"r"#Index>;
|
|
}
|
|
#ifdef USE_NAMESPACE
|
|
}
|
|
#endif
|
|
|
|
def GPR32 : RegisterClass<"TestTarget", [i32], 32,
|
|
(add (sequence "R%u", 0, 255))>;
|
|
|
|
def GPR64 : RegisterTuples<[sub0, sub1],
|
|
[(decimate (shl GPR32, 0), 1),
|
|
(decimate (shl GPR32, 1), 1)
|
|
]>;
|
|
|
|
def GPR128 : RegisterTuples<[sub0, sub1, sub2, sub3],
|
|
[
|
|
(decimate (shl GPR32, 0), 1),
|
|
(decimate (shl GPR32, 1), 1),
|
|
(decimate (shl GPR32, 2), 1),
|
|
(decimate (shl GPR32, 3), 1)
|
|
]>;
|
|
|
|
def GPR256 : RegisterTuples<[sub0, sub1, sub2, sub3, sub4, sub5, sub6, sub7],
|
|
[
|
|
(decimate (shl GPR32, 0), 1),
|
|
(decimate (shl GPR32, 1), 1),
|
|
(decimate (shl GPR32, 2), 1),
|
|
(decimate (shl GPR32, 3), 1),
|
|
(decimate (shl GPR32, 4), 1),
|
|
(decimate (shl GPR32, 5), 1),
|
|
(decimate (shl GPR32, 6), 1),
|
|
(decimate (shl GPR32, 7), 1)
|
|
]>;
|
|
|
|
def GPR512 : RegisterTuples<[sub0, sub1, sub2, sub3, sub4, sub5, sub6, sub7,
|
|
sub8, sub9, sub10, sub11, sub12, sub13, sub14, sub15],
|
|
[
|
|
(decimate (shl GPR32, 0), 1),
|
|
(decimate (shl GPR32, 1), 1),
|
|
(decimate (shl GPR32, 2), 1),
|
|
(decimate (shl GPR32, 3), 1),
|
|
(decimate (shl GPR32, 4), 1),
|
|
(decimate (shl GPR32, 5), 1),
|
|
(decimate (shl GPR32, 6), 1),
|
|
(decimate (shl GPR32, 7), 1),
|
|
(decimate (shl GPR32, 8), 1),
|
|
(decimate (shl GPR32, 9), 1),
|
|
(decimate (shl GPR32, 10), 1),
|
|
(decimate (shl GPR32, 11), 1),
|
|
(decimate (shl GPR32, 12), 1),
|
|
(decimate (shl GPR32, 13), 1),
|
|
(decimate (shl GPR32, 14), 1),
|
|
(decimate (shl GPR32, 15), 1)
|
|
]>;
|
|
|
|
def GPR1024 : RegisterTuples<[sub0, sub1, sub2, sub3, sub4, sub5, sub6, sub7,
|
|
sub8, sub9, sub10, sub11, sub12, sub13, sub14, sub15,
|
|
sub16, sub17, sub18, sub19, sub20, sub21, sub22, sub23,
|
|
sub24, sub25, sub26, sub27, sub28, sub29, sub30, sub31],
|
|
[
|
|
(decimate (shl GPR32, 0), 1),
|
|
(decimate (shl GPR32, 1), 1),
|
|
(decimate (shl GPR32, 2), 1),
|
|
(decimate (shl GPR32, 3), 1),
|
|
(decimate (shl GPR32, 4), 1),
|
|
(decimate (shl GPR32, 5), 1),
|
|
(decimate (shl GPR32, 6), 1),
|
|
(decimate (shl GPR32, 7), 1),
|
|
(decimate (shl GPR32, 8), 1),
|
|
(decimate (shl GPR32, 9), 1),
|
|
(decimate (shl GPR32, 10), 1),
|
|
(decimate (shl GPR32, 11), 1),
|
|
(decimate (shl GPR32, 12), 1),
|
|
(decimate (shl GPR32, 13), 1),
|
|
(decimate (shl GPR32, 14), 1),
|
|
(decimate (shl GPR32, 15), 1),
|
|
(decimate (shl GPR32, 16), 1),
|
|
(decimate (shl GPR32, 17), 1),
|
|
(decimate (shl GPR32, 18), 1),
|
|
(decimate (shl GPR32, 19), 1),
|
|
(decimate (shl GPR32, 20), 1),
|
|
(decimate (shl GPR32, 21), 1),
|
|
(decimate (shl GPR32, 22), 1),
|
|
(decimate (shl GPR32, 23), 1),
|
|
(decimate (shl GPR32, 24), 1),
|
|
(decimate (shl GPR32, 25), 1),
|
|
(decimate (shl GPR32, 26), 1),
|
|
(decimate (shl GPR32, 27), 1),
|
|
(decimate (shl GPR32, 28), 1),
|
|
(decimate (shl GPR32, 29), 1),
|
|
(decimate (shl GPR32, 30), 1),
|
|
(decimate (shl GPR32, 31), 1)
|
|
]>;
|
|
|
|
#ifdef USE_NAMESPACE
|
|
let Namespace = "TestNamespace" in {
|
|
#endif
|
|
def GPR_64 : RegisterClass<"", [v2i32], 64, (add GPR64)>;
|
|
def GPR_1024 : RegisterClass<"", [v32i32], 1024, (add GPR1024)>;
|
|
#ifdef USE_NAMESPACE
|
|
}
|
|
#endif
|