annotate llvm/test/TableGen/dag-functional.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 // CHECK: def A0 {
anatofuz
parents:
diff changeset
7 // CHECK: dag ret = (ops);
anatofuz
parents:
diff changeset
8 // CHECK: }
anatofuz
parents:
diff changeset
9
anatofuz
parents:
diff changeset
10 // CHECK: def A1 {
anatofuz
parents:
diff changeset
11 // CHECK: dag ret = (ops ?:$a, 1:$b, 2);
anatofuz
parents:
diff changeset
12 // CHECK: }
anatofuz
parents:
diff changeset
13
anatofuz
parents:
diff changeset
14 // CHECK: def A2 {
anatofuz
parents:
diff changeset
15 // CHECK: dag ret = (ops (ops ?:$name):$a, (ops 1):$b, (ops "foo"):$c);
anatofuz
parents:
diff changeset
16 // CHECK: }
anatofuz
parents:
diff changeset
17
anatofuz
parents:
diff changeset
18 // CHECK: def A3 {
anatofuz
parents:
diff changeset
19 // CHECK: dag ret = (ops NodeA0:$a, NodeB0:$b);
anatofuz
parents:
diff changeset
20 // CHECK: }
anatofuz
parents:
diff changeset
21
anatofuz
parents:
diff changeset
22 // CHECK: def A4 {
anatofuz
parents:
diff changeset
23 // CHECK: dag ret = (ops NodeA0, NodeB0);
anatofuz
parents:
diff changeset
24 // CHECK: }
anatofuz
parents:
diff changeset
25
anatofuz
parents:
diff changeset
26 // CHECK: def B0 {
anatofuz
parents:
diff changeset
27 // CHECK: dag ret = (ops);
anatofuz
parents:
diff changeset
28 // CHECK: }
anatofuz
parents:
diff changeset
29
anatofuz
parents:
diff changeset
30 // CHECK: def B1 {
anatofuz
parents:
diff changeset
31 // CHECK: dag ret = (ops 1:$a, 2:$b);
anatofuz
parents:
diff changeset
32 // CHECK: }
anatofuz
parents:
diff changeset
33
anatofuz
parents:
diff changeset
34 // CHECK: def C0 {
anatofuz
parents:
diff changeset
35 // CHECK: dag ret1 = (ops ?:$a, ?:$b);
anatofuz
parents:
diff changeset
36 // CHECK: dag ret2 = (ops 1, 2);
anatofuz
parents:
diff changeset
37 // CHECK: }
anatofuz
parents:
diff changeset
38
anatofuz
parents:
diff changeset
39 // CHECK: def D {
anatofuz
parents:
diff changeset
40 // CHECK: dag d1 = (ops 1, ?:$name1, 2, 3);
anatofuz
parents:
diff changeset
41 // CHECK: }
anatofuz
parents:
diff changeset
42
anatofuz
parents:
diff changeset
43 // CHECK: def E0 {
anatofuz
parents:
diff changeset
44 // CHECK: dag ret = (ops 1, 2);
anatofuz
parents:
diff changeset
45 // CHECK: }
anatofuz
parents:
diff changeset
46
anatofuz
parents:
diff changeset
47 class Ops;
anatofuz
parents:
diff changeset
48
anatofuz
parents:
diff changeset
49 def ops : Ops;
anatofuz
parents:
diff changeset
50
anatofuz
parents:
diff changeset
51 class Node<int val, string name> {
anatofuz
parents:
diff changeset
52 int Val = val;
anatofuz
parents:
diff changeset
53 string Name = name;
anatofuz
parents:
diff changeset
54 }
anatofuz
parents:
diff changeset
55
anatofuz
parents:
diff changeset
56 class Aint<list<int> nodes, list<string> names> {
anatofuz
parents:
diff changeset
57 dag ret = !dag(ops, nodes, names);
anatofuz
parents:
diff changeset
58 }
anatofuz
parents:
diff changeset
59
anatofuz
parents:
diff changeset
60 class Adag<list<dag> nodes, list<string> names> {
anatofuz
parents:
diff changeset
61 dag ret = !dag(ops, nodes, names);
anatofuz
parents:
diff changeset
62 }
anatofuz
parents:
diff changeset
63
anatofuz
parents:
diff changeset
64 class NodeBase;
anatofuz
parents:
diff changeset
65
anatofuz
parents:
diff changeset
66 class NodeA<int val> : NodeBase {
anatofuz
parents:
diff changeset
67 int x = val;
anatofuz
parents:
diff changeset
68 }
anatofuz
parents:
diff changeset
69
anatofuz
parents:
diff changeset
70 class NodeB<int val> : NodeBase {
anatofuz
parents:
diff changeset
71 int y = val;
anatofuz
parents:
diff changeset
72 }
anatofuz
parents:
diff changeset
73
anatofuz
parents:
diff changeset
74 class Anode<list<NodeBase> nodes, list<string> names> {
anatofuz
parents:
diff changeset
75 dag ret = !dag(ops, nodes, names);
anatofuz
parents:
diff changeset
76 }
anatofuz
parents:
diff changeset
77
anatofuz
parents:
diff changeset
78 class B<list<Node> nodes> {
anatofuz
parents:
diff changeset
79 dag ret = !foldl((ops), nodes, lhs, rhs, !con(lhs, !dag(ops, [rhs.Val], [rhs.Name])));
anatofuz
parents:
diff changeset
80 }
anatofuz
parents:
diff changeset
81
anatofuz
parents:
diff changeset
82 def A0 : Aint<[], []>;
anatofuz
parents:
diff changeset
83 def A1 : Aint<[?, 1, 2], ["a", "b", ?]>;
anatofuz
parents:
diff changeset
84
anatofuz
parents:
diff changeset
85 def A2 : Adag<[(ops $name), (ops 1), (ops "foo")], ["a", "b", "c"]>;
anatofuz
parents:
diff changeset
86
anatofuz
parents:
diff changeset
87 def NodeA0 : NodeA<0>;
anatofuz
parents:
diff changeset
88 def NodeB0 : NodeB<0>;
anatofuz
parents:
diff changeset
89
anatofuz
parents:
diff changeset
90 def A3 : Anode<[NodeA0, NodeB0], ["a", "b"]>;
anatofuz
parents:
diff changeset
91
anatofuz
parents:
diff changeset
92 def A4 {
anatofuz
parents:
diff changeset
93 // Like A3, but with a literal list directly in the !dag.
anatofuz
parents:
diff changeset
94 dag ret = !dag(ops, [NodeA0, NodeB0], ?);
anatofuz
parents:
diff changeset
95 }
anatofuz
parents:
diff changeset
96
anatofuz
parents:
diff changeset
97 def B0 : B<[]>;
anatofuz
parents:
diff changeset
98 def B1 : B<[Node<1, "a">, Node<2, "b">]>;
anatofuz
parents:
diff changeset
99
anatofuz
parents:
diff changeset
100 class C<list<int> nodes, list<string> names> {
anatofuz
parents:
diff changeset
101 dag ret1 = !dag(ops, ?, names);
anatofuz
parents:
diff changeset
102 dag ret2 = !dag(ops, nodes, ?);
anatofuz
parents:
diff changeset
103 }
anatofuz
parents:
diff changeset
104
anatofuz
parents:
diff changeset
105 def C0 : C<[1, 2], ["a", "b"]>;
anatofuz
parents:
diff changeset
106
anatofuz
parents:
diff changeset
107 def D {
anatofuz
parents:
diff changeset
108 dag d1 = !con((ops 1), (ops $name1), (ops), (ops 2, 3));
anatofuz
parents:
diff changeset
109 }
anatofuz
parents:
diff changeset
110
anatofuz
parents:
diff changeset
111 class E<Ops op> {
anatofuz
parents:
diff changeset
112 // Allow concatenation of DAG nodes with operators from template arguments.
anatofuz
parents:
diff changeset
113 dag ret = !con((op 1), (op 2));
anatofuz
parents:
diff changeset
114 }
anatofuz
parents:
diff changeset
115
anatofuz
parents:
diff changeset
116 def E0 : E<ops>;