1*9880d681SAndroid Build Coastguard Worker// RUN: llvm-tblgen %s | FileCheck %s 2*9880d681SAndroid Build Coastguard Worker 3*9880d681SAndroid Build Coastguard Workerclass Register<string name, int idx> { 4*9880d681SAndroid Build Coastguard Worker string Name = name; 5*9880d681SAndroid Build Coastguard Worker int Index = idx; 6*9880d681SAndroid Build Coastguard Worker} 7*9880d681SAndroid Build Coastguard Worker 8*9880d681SAndroid Build Coastguard Worker// CHECK-NOT: !strconcat 9*9880d681SAndroid Build Coastguard Worker 10*9880d681SAndroid Build Coastguard Workerforeach i = 0-3 in 11*9880d681SAndroid Build Coastguard Worker def Q#i : Register<"Q"#i, i>; 12*9880d681SAndroid Build Coastguard Worker 13*9880d681SAndroid Build Coastguard Worker// CHECK: def Q0 14*9880d681SAndroid Build Coastguard Worker// CHECK: def Q1 15*9880d681SAndroid Build Coastguard Worker// CHECK: def Q2 16*9880d681SAndroid Build Coastguard Worker// CHECK: def Q3 17*9880d681SAndroid Build Coastguard Worker 18*9880d681SAndroid Build Coastguard Workerforeach i = [0, 1, 2, 3, 4, 5, 6, 7] in 19*9880d681SAndroid Build Coastguard Worker def R#i : Register<"R"#i, i>; 20*9880d681SAndroid Build Coastguard Worker 21*9880d681SAndroid Build Coastguard Worker// CHECK: def R0 22*9880d681SAndroid Build Coastguard Worker// CHECK: string Name = "R0"; 23*9880d681SAndroid Build Coastguard Worker// CHECK: int Index = 0; 24*9880d681SAndroid Build Coastguard Worker 25*9880d681SAndroid Build Coastguard Worker// CHECK: def R1 26*9880d681SAndroid Build Coastguard Worker// CHECK: string Name = "R1"; 27*9880d681SAndroid Build Coastguard Worker// CHECK: int Index = 1; 28*9880d681SAndroid Build Coastguard Worker 29*9880d681SAndroid Build Coastguard Worker// CHECK: def R2 30*9880d681SAndroid Build Coastguard Worker// CHECK: string Name = "R2"; 31*9880d681SAndroid Build Coastguard Worker// CHECK: int Index = 2; 32*9880d681SAndroid Build Coastguard Worker 33*9880d681SAndroid Build Coastguard Worker// CHECK: def R3 34*9880d681SAndroid Build Coastguard Worker// CHECK: string Name = "R3"; 35*9880d681SAndroid Build Coastguard Worker// CHECK: int Index = 3; 36*9880d681SAndroid Build Coastguard Worker 37*9880d681SAndroid Build Coastguard Worker// CHECK: def R4 38*9880d681SAndroid Build Coastguard Worker// CHECK: string Name = "R4"; 39*9880d681SAndroid Build Coastguard Worker// CHECK: int Index = 4; 40*9880d681SAndroid Build Coastguard Worker 41*9880d681SAndroid Build Coastguard Worker// CHECK: def R5 42*9880d681SAndroid Build Coastguard Worker// CHECK: string Name = "R5"; 43*9880d681SAndroid Build Coastguard Worker// CHECK: int Index = 5; 44*9880d681SAndroid Build Coastguard Worker 45*9880d681SAndroid Build Coastguard Worker// CHECK: def R6 46*9880d681SAndroid Build Coastguard Worker// CHECK: string Name = "R6"; 47*9880d681SAndroid Build Coastguard Worker// CHECK: int Index = 6; 48*9880d681SAndroid Build Coastguard Worker 49*9880d681SAndroid Build Coastguard Worker// CHECK: def R7 50*9880d681SAndroid Build Coastguard Worker// CHECK: string Name = "R7"; 51*9880d681SAndroid Build Coastguard Worker// CHECK: int Index = 7; 52*9880d681SAndroid Build Coastguard Worker 53*9880d681SAndroid Build Coastguard Workerforeach i = {0-3,9-7} in { 54*9880d681SAndroid Build Coastguard Worker def S#i : Register<"Q"#i, i>; 55*9880d681SAndroid Build Coastguard Worker def : Register<"T"#i, i>; 56*9880d681SAndroid Build Coastguard Worker} 57*9880d681SAndroid Build Coastguard Worker 58*9880d681SAndroid Build Coastguard Worker// CHECK: def S0 59*9880d681SAndroid Build Coastguard Worker// CHECK: def S1 60*9880d681SAndroid Build Coastguard Worker// CHECK: def S2 61*9880d681SAndroid Build Coastguard Worker// CHECK: def S3 62*9880d681SAndroid Build Coastguard Worker// CHECK: def S7 63*9880d681SAndroid Build Coastguard Worker// CHECK: def S8 64*9880d681SAndroid Build Coastguard Worker// CHECK: def S9 65*9880d681SAndroid Build Coastguard Worker 66*9880d681SAndroid Build Coastguard Worker// CHECK: def 67*9880d681SAndroid Build Coastguard Worker// CHECK: string Name = "T0"; 68*9880d681SAndroid Build Coastguard Worker 69*9880d681SAndroid Build Coastguard Worker// CHECK: def 70*9880d681SAndroid Build Coastguard Worker// CHECK: string Name = "T1"; 71*9880d681SAndroid Build Coastguard Worker 72*9880d681SAndroid Build Coastguard Worker// CHECK: def 73*9880d681SAndroid Build Coastguard Worker// CHECK: string Name = "T2"; 74*9880d681SAndroid Build Coastguard Worker 75*9880d681SAndroid Build Coastguard Worker// CHECK: def 76*9880d681SAndroid Build Coastguard Worker// CHECK: string Name = "T3"; 77*9880d681SAndroid Build Coastguard Worker 78*9880d681SAndroid Build Coastguard Worker// CHECK: def 79*9880d681SAndroid Build Coastguard Worker// CHECK: string Name = "T9"; 80*9880d681SAndroid Build Coastguard Worker 81*9880d681SAndroid Build Coastguard Worker// CHECK: def 82*9880d681SAndroid Build Coastguard Worker// CHECK: string Name = "T8"; 83*9880d681SAndroid Build Coastguard Worker 84*9880d681SAndroid Build Coastguard Worker// CHECK: def 85*9880d681SAndroid Build Coastguard Worker// CHECK: string Name = "T7"; 86*9880d681SAndroid Build Coastguard Worker 87