annotate llvm/test/TableGen/JSON.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 -dump-json %s | %python %S/JSON-check.py %s
anatofuz
parents:
diff changeset
2
anatofuz
parents:
diff changeset
3 // CHECK: data['!tablegen_json_version'] == 1
anatofuz
parents:
diff changeset
4
anatofuz
parents:
diff changeset
5 // CHECK: all(data[s]['!name'] == s for s in data if not s.startswith("!"))
anatofuz
parents:
diff changeset
6
anatofuz
parents:
diff changeset
7 class Base {}
anatofuz
parents:
diff changeset
8 class Intermediate : Base {}
anatofuz
parents:
diff changeset
9 class Derived : Intermediate {}
anatofuz
parents:
diff changeset
10
anatofuz
parents:
diff changeset
11 def D : Intermediate {}
anatofuz
parents:
diff changeset
12 // CHECK: 'D' in data['!instanceof']['Base']
anatofuz
parents:
diff changeset
13 // CHECK: 'D' in data['!instanceof']['Intermediate']
anatofuz
parents:
diff changeset
14 // CHECK: 'D' not in data['!instanceof']['Derived']
anatofuz
parents:
diff changeset
15 // CHECK: 'Base' in data['D']['!superclasses']
anatofuz
parents:
diff changeset
16 // CHECK: 'Intermediate' in data['D']['!superclasses']
anatofuz
parents:
diff changeset
17 // CHECK: 'Derived' not in data['D']['!superclasses']
anatofuz
parents:
diff changeset
18
anatofuz
parents:
diff changeset
19 def ExampleDagOp;
anatofuz
parents:
diff changeset
20
anatofuz
parents:
diff changeset
21 def FieldKeywordTest {
anatofuz
parents:
diff changeset
22 int a;
anatofuz
parents:
diff changeset
23 field int b;
anatofuz
parents:
diff changeset
24 // CHECK: 'a' not in data['FieldKeywordTest']['!fields']
anatofuz
parents:
diff changeset
25 // CHECK: 'b' in data['FieldKeywordTest']['!fields']
anatofuz
parents:
diff changeset
26 }
anatofuz
parents:
diff changeset
27
anatofuz
parents:
diff changeset
28 class Variables {
anatofuz
parents:
diff changeset
29 int i;
anatofuz
parents:
diff changeset
30 string s;
anatofuz
parents:
diff changeset
31 bit b;
anatofuz
parents:
diff changeset
32 bits<8> bs;
anatofuz
parents:
diff changeset
33 code c;
anatofuz
parents:
diff changeset
34 list<int> li;
anatofuz
parents:
diff changeset
35 Base base;
anatofuz
parents:
diff changeset
36 dag d;
anatofuz
parents:
diff changeset
37 }
anatofuz
parents:
diff changeset
38 def VarNull : Variables {
anatofuz
parents:
diff changeset
39 // A variable not filled in at all has its value set to JSON
anatofuz
parents:
diff changeset
40 // 'null', which translates to Python None
anatofuz
parents:
diff changeset
41 // CHECK: data['VarNull']['i'] is None
anatofuz
parents:
diff changeset
42 }
anatofuz
parents:
diff changeset
43 def VarPrim : Variables {
anatofuz
parents:
diff changeset
44 // Test initializers that map to primitive JSON types
anatofuz
parents:
diff changeset
45
anatofuz
parents:
diff changeset
46 int i = 3;
anatofuz
parents:
diff changeset
47 // CHECK: data['VarPrim']['i'] == 3
anatofuz
parents:
diff changeset
48
anatofuz
parents:
diff changeset
49 // Integer literals should be emitted in the JSON at full 64-bit
anatofuz
parents:
diff changeset
50 // precision, for the benefit of JSON readers that preserve that
anatofuz
parents:
diff changeset
51 // much information. Python's is one such.
anatofuz
parents:
diff changeset
52 int enormous_pos = 9123456789123456789;
anatofuz
parents:
diff changeset
53 int enormous_neg = -9123456789123456789;
anatofuz
parents:
diff changeset
54 // CHECK: data['VarPrim']['enormous_pos'] == 9123456789123456789
anatofuz
parents:
diff changeset
55 // CHECK: data['VarPrim']['enormous_neg'] == -9123456789123456789
anatofuz
parents:
diff changeset
56
anatofuz
parents:
diff changeset
57 string s = "hello, world";
anatofuz
parents:
diff changeset
58 // CHECK: data['VarPrim']['s'] == 'hello, world'
anatofuz
parents:
diff changeset
59
anatofuz
parents:
diff changeset
60 bit b = 0;
anatofuz
parents:
diff changeset
61 // CHECK: data['VarPrim']['b'] == 0
anatofuz
parents:
diff changeset
62
anatofuz
parents:
diff changeset
63 // bits<> arrays are stored in logical order (array[i] is the same
anatofuz
parents:
diff changeset
64 // bit identified in .td files as bs{i}), which means the _visual_
anatofuz
parents:
diff changeset
65 // order of the list (in default rendering) is reversed.
anatofuz
parents:
diff changeset
66 bits<8> bs = { 0,0,0,1,0,1,1,1 };
anatofuz
parents:
diff changeset
67 // CHECK: data['VarPrim']['bs'] == [ 1,1,1,0,1,0,0,0 ]
anatofuz
parents:
diff changeset
68
anatofuz
parents:
diff changeset
69 code c = [{ \" }];
anatofuz
parents:
diff changeset
70 // CHECK: data['VarPrim']['c'] == r' \" '
anatofuz
parents:
diff changeset
71
anatofuz
parents:
diff changeset
72 list<int> li = [ 1, 2, 3, 4 ];
anatofuz
parents:
diff changeset
73 // CHECK: data['VarPrim']['li'] == [ 1, 2, 3, 4 ]
anatofuz
parents:
diff changeset
74 }
anatofuz
parents:
diff changeset
75 def VarObj : Variables {
anatofuz
parents:
diff changeset
76 // Test initializers that map to JSON objects containing a 'kind'
anatofuz
parents:
diff changeset
77 // discriminator
anatofuz
parents:
diff changeset
78
anatofuz
parents:
diff changeset
79 Base base = D;
anatofuz
parents:
diff changeset
80 // CHECK: data['VarObj']['base']['kind'] == 'def'
anatofuz
parents:
diff changeset
81 // CHECK: data['VarObj']['base']['def'] == 'D'
anatofuz
parents:
diff changeset
82 // CHECK: data['VarObj']['base']['printable'] == 'D'
anatofuz
parents:
diff changeset
83
anatofuz
parents:
diff changeset
84 dag d = (ExampleDagOp 22, "hello":$foo);
anatofuz
parents:
diff changeset
85 // CHECK: data['VarObj']['d']['kind'] == 'dag'
anatofuz
parents:
diff changeset
86 // CHECK: data['VarObj']['d']['operator']['kind'] == 'def'
anatofuz
parents:
diff changeset
87 // CHECK: data['VarObj']['d']['operator']['def'] == 'ExampleDagOp'
anatofuz
parents:
diff changeset
88 // CHECK: data['VarObj']['d']['operator']['printable'] == 'ExampleDagOp'
anatofuz
parents:
diff changeset
89 // CHECK: data['VarObj']['d']['args'] == [[22, None], ["hello", "foo"]]
anatofuz
parents:
diff changeset
90 // CHECK: data['VarObj']['d']['printable'] == '(ExampleDagOp 22, "hello":$foo)'
anatofuz
parents:
diff changeset
91
anatofuz
parents:
diff changeset
92 int undef_int;
anatofuz
parents:
diff changeset
93 field int ref_int = undef_int;
anatofuz
parents:
diff changeset
94 // CHECK: data['VarObj']['ref_int']['kind'] == 'var'
anatofuz
parents:
diff changeset
95 // CHECK: data['VarObj']['ref_int']['var'] == 'undef_int'
anatofuz
parents:
diff changeset
96 // CHECK: data['VarObj']['ref_int']['printable'] == 'undef_int'
anatofuz
parents:
diff changeset
97
anatofuz
parents:
diff changeset
98 bits<2> undef_bits;
anatofuz
parents:
diff changeset
99 bits<4> ref_bits;
207
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
100 let ref_bits{3...2} = 0b10;
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
101 let ref_bits{1...0} = undef_bits{1...0};
150
anatofuz
parents:
diff changeset
102 // CHECK: data['VarObj']['ref_bits'][3] == 1
anatofuz
parents:
diff changeset
103 // CHECK: data['VarObj']['ref_bits'][2] == 0
anatofuz
parents:
diff changeset
104 // CHECK: data['VarObj']['ref_bits'][1]['kind'] == 'varbit'
anatofuz
parents:
diff changeset
105 // CHECK: data['VarObj']['ref_bits'][1]['var'] == 'undef_bits'
anatofuz
parents:
diff changeset
106 // CHECK: data['VarObj']['ref_bits'][1]['index'] == 1
anatofuz
parents:
diff changeset
107 // CHECK: data['VarObj']['ref_bits'][1]['printable'] == 'undef_bits{1}'
anatofuz
parents:
diff changeset
108 // CHECK: data['VarObj']['ref_bits'][0]['kind'] == 'varbit'
anatofuz
parents:
diff changeset
109 // CHECK: data['VarObj']['ref_bits'][0]['var'] == 'undef_bits'
anatofuz
parents:
diff changeset
110 // CHECK: data['VarObj']['ref_bits'][0]['index'] == 0
anatofuz
parents:
diff changeset
111 // CHECK: data['VarObj']['ref_bits'][0]['printable'] == 'undef_bits{0}'
anatofuz
parents:
diff changeset
112
anatofuz
parents:
diff changeset
113 field int complex_ref_int = !add(undef_int, 2);
anatofuz
parents:
diff changeset
114 // CHECK: data['VarObj']['complex_ref_int']['kind'] == 'complex'
anatofuz
parents:
diff changeset
115 // CHECK: data['VarObj']['complex_ref_int']['printable'] == '!add(undef_int, 2)'
anatofuz
parents:
diff changeset
116 }
anatofuz
parents:
diff changeset
117
anatofuz
parents:
diff changeset
118 // Test the !anonymous member. This is tricky because when a def is
anatofuz
parents:
diff changeset
119 // anonymous, almost by definition, the test can't reliably predict
anatofuz
parents:
diff changeset
120 // the name it will be stored under! So we have to search all the defs
anatofuz
parents:
diff changeset
121 // in the JSON output looking for the one that has the test integer
anatofuz
parents:
diff changeset
122 // field set to the right value.
anatofuz
parents:
diff changeset
123
anatofuz
parents:
diff changeset
124 def Named { int AnonTestField = 1; }
anatofuz
parents:
diff changeset
125 // CHECK: data['Named']['AnonTestField'] == 1
anatofuz
parents:
diff changeset
126 // CHECK: data['Named']['!anonymous'] is False
anatofuz
parents:
diff changeset
127
anatofuz
parents:
diff changeset
128 def { int AnonTestField = 2; }
anatofuz
parents:
diff changeset
129 // CHECK: next(rec for rec in data.values() if isinstance(rec, dict) and rec.get('AnonTestField') == 2)['!anonymous'] is True
anatofuz
parents:
diff changeset
130
anatofuz
parents:
diff changeset
131 multiclass AnonTestMulticlass<int base> {
anatofuz
parents:
diff changeset
132 def _plus_one { int AnonTestField = !add(base,1); }
anatofuz
parents:
diff changeset
133 def { int AnonTestField = !add(base,2); }
anatofuz
parents:
diff changeset
134 }
anatofuz
parents:
diff changeset
135
anatofuz
parents:
diff changeset
136 defm NamedDefm : AnonTestMulticlass<10>;
anatofuz
parents:
diff changeset
137 // CHECK: data['NamedDefm_plus_one']['!anonymous'] is False
anatofuz
parents:
diff changeset
138 // CHECK: data['NamedDefm_plus_one']['AnonTestField'] == 11
anatofuz
parents:
diff changeset
139 // CHECK: next(rec for rec in data.values() if isinstance(rec, dict) and rec.get('AnonTestField') == 12)['!anonymous'] is True
anatofuz
parents:
diff changeset
140
anatofuz
parents:
diff changeset
141 // D47431 clarifies that a named def inside a multiclass gives a
anatofuz
parents:
diff changeset
142 // *non*-anonymous output record, even if the defm that instantiates
anatofuz
parents:
diff changeset
143 // that multiclass is anonymous.
anatofuz
parents:
diff changeset
144 defm : AnonTestMulticlass<20>;
anatofuz
parents:
diff changeset
145 // CHECK: next(rec for rec in data.values() if isinstance(rec, dict) and rec.get('AnonTestField') == 21)['!anonymous'] is False
anatofuz
parents:
diff changeset
146 // CHECK: next(rec for rec in data.values() if isinstance(rec, dict) and rec.get('AnonTestField') == 22)['!anonymous'] is True