1*9880d681SAndroid Build Coastguard Worker// RUN: llvm-tblgen %s | FileCheck %s 2*9880d681SAndroid Build Coastguard Worker// XFAIL: vg_leak 3*9880d681SAndroid Build Coastguard Worker 4*9880d681SAndroid Build Coastguard Worker// CHECK: zing = 4 5*9880d681SAndroid Build Coastguard Worker// CHECK: zing = 4 6*9880d681SAndroid Build Coastguard Worker// CHECK: zing = 4 7*9880d681SAndroid Build Coastguard Worker// CHECK: zing = 4 8*9880d681SAndroid Build Coastguard Worker// CHECK-NOT: zing = 4 9*9880d681SAndroid Build Coastguard Worker 10*9880d681SAndroid Build Coastguard Workerclass C1<int A, string B> { 11*9880d681SAndroid Build Coastguard Worker int bar = A; 12*9880d681SAndroid Build Coastguard Worker string thestr = B; 13*9880d681SAndroid Build Coastguard Worker int zing; 14*9880d681SAndroid Build Coastguard Worker} 15*9880d681SAndroid Build Coastguard Worker 16*9880d681SAndroid Build Coastguard Workerdef T : C1<4, "blah">; 17*9880d681SAndroid Build Coastguard Worker 18*9880d681SAndroid Build Coastguard Workermulticlass t<int a> { 19*9880d681SAndroid Build Coastguard Worker def S1 : C1<a, "foo"> { 20*9880d681SAndroid Build Coastguard Worker int foo = 4; 21*9880d681SAndroid Build Coastguard Worker let bar = 1; 22*9880d681SAndroid Build Coastguard Worker } 23*9880d681SAndroid Build Coastguard Worker def S2 : C1<a, "bar">; 24*9880d681SAndroid Build Coastguard Worker} 25*9880d681SAndroid Build Coastguard Worker 26*9880d681SAndroid Build Coastguard Workermulticlass s<int a> { 27*9880d681SAndroid Build Coastguard Worker def S3 : C1<a, "moo"> { 28*9880d681SAndroid Build Coastguard Worker int moo = 3; 29*9880d681SAndroid Build Coastguard Worker let bar = 1; 30*9880d681SAndroid Build Coastguard Worker } 31*9880d681SAndroid Build Coastguard Worker def S4 : C1<a, "baz">; 32*9880d681SAndroid Build Coastguard Worker} 33*9880d681SAndroid Build Coastguard Worker 34*9880d681SAndroid Build Coastguard Workerdefm FOO : t<42>, s<24>; 35*9880d681SAndroid Build Coastguard Worker 36*9880d681SAndroid Build Coastguard Workerdef T4 : C1<6, "foo">; 37*9880d681SAndroid Build Coastguard Worker 38*9880d681SAndroid Build Coastguard Workerlet zing = 4 in 39*9880d681SAndroid Build Coastguard Worker defm BAZ : t<3>, s<4>; 40