annotate llvm/test/TableGen/UnsetBitInit.td @ 207:2e18cbf3894f

LLVM12
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Tue, 08 Jun 2021 06:07:14 +0900
parents 1d019706d866
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
150
anatofuz
parents:
diff changeset
1 // RUN: llvm-tblgen %s | FileCheck %s
anatofuz
parents:
diff changeset
2 // XFAIL: vg_leak
anatofuz
parents:
diff changeset
3
anatofuz
parents:
diff changeset
4 // CHECK: --- Defs ---
anatofuz
parents:
diff changeset
5
anatofuz
parents:
diff changeset
6 // Test that P and Q are not replaced by ?. TableGen's codegen emitter backend
anatofuz
parents:
diff changeset
7 // relies on keeping variable references like this around to describe the
anatofuz
parents:
diff changeset
8 // structure of instruction encodings.
anatofuz
parents:
diff changeset
9 //
anatofuz
parents:
diff changeset
10 // CHECK: def A {
anatofuz
parents:
diff changeset
11 // CHECK: bits<8> Inst = { 1, 1, 1, 1, 1, 1, P, Q };
anatofuz
parents:
diff changeset
12 // CHECK: bits<2> src = { ?, ? };
anatofuz
parents:
diff changeset
13 // CHECK: bit P = ?;
anatofuz
parents:
diff changeset
14 // CHECK: bit Q = ?;
anatofuz
parents:
diff changeset
15 // CHECK: }
anatofuz
parents:
diff changeset
16
anatofuz
parents:
diff changeset
17 def A {
anatofuz
parents:
diff changeset
18 bits<8> Inst;
anatofuz
parents:
diff changeset
19 bits<2> src;
anatofuz
parents:
diff changeset
20
anatofuz
parents:
diff changeset
21 bit P;
anatofuz
parents:
diff changeset
22 bit Q;
anatofuz
parents:
diff changeset
23
207
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
24 let Inst{7...2} = 0x3f;
150
anatofuz
parents:
diff changeset
25 let Inst{1} = P;
anatofuz
parents:
diff changeset
26 let Inst{0} = Q;
anatofuz
parents:
diff changeset
27
anatofuz
parents:
diff changeset
28 let P = src{1};
anatofuz
parents:
diff changeset
29 let Q = src{0};
anatofuz
parents:
diff changeset
30 }
anatofuz
parents:
diff changeset
31
anatofuz
parents:
diff changeset
32 class x {
anatofuz
parents:
diff changeset
33 field bits<32> A;
anatofuz
parents:
diff changeset
34 }
anatofuz
parents:
diff changeset
35
anatofuz
parents:
diff changeset
36 class y<bits<2> B> : x {
207
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
37 let A{21...20} = B;
150
anatofuz
parents:
diff changeset
38 }
anatofuz
parents:
diff changeset
39
anatofuz
parents:
diff changeset
40 def z : y<{0,?}>;