summaryrefslogtreecommitdiff
path: root/test/TableGen
diff options
context:
space:
mode:
authorBruno Cardoso Lopes <bruno.cardoso@gmail.com>2010-06-05 02:11:52 +0000
committerBruno Cardoso Lopes <bruno.cardoso@gmail.com>2010-06-05 02:11:52 +0000
commit270562b3d4c61ae1381cb1b0026bb703b46ff88f (patch)
treedc95c8cba3a2dd08aa0facb0293c7689bca5e6bb /test/TableGen
parent8613b18a5aa80b13bb8c7f470528146f009bed74 (diff)
downloadllvm-270562b3d4c61ae1381cb1b0026bb703b46ff88f.tar.gz
llvm-270562b3d4c61ae1381cb1b0026bb703b46ff88f.tar.bz2
llvm-270562b3d4c61ae1381cb1b0026bb703b46ff88f.tar.xz
Teach tablegen to support 'defm' inside multiclasses.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@105519 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'test/TableGen')
-rw-r--r--test/TableGen/DefmInsideMultiClass.td25
1 files changed, 25 insertions, 0 deletions
diff --git a/test/TableGen/DefmInsideMultiClass.td b/test/TableGen/DefmInsideMultiClass.td
new file mode 100644
index 0000000000..68cc12d568
--- /dev/null
+++ b/test/TableGen/DefmInsideMultiClass.td
@@ -0,0 +1,25 @@
+// RUN: tblgen %s | grep ADDPSrr | count 1
+// XFAIL: vg_leak
+
+class Instruction<bits<4> opc, string Name> {
+ bits<4> opcode = opc;
+ string name = Name;
+}
+
+multiclass basic_r<bits<4> opc> {
+ def rr : Instruction<opc, "rr">;
+ def rm : Instruction<opc, "rm">;
+}
+
+multiclass basic_s<bits<4> opc> {
+ defm SS : basic_r<opc>;
+ defm SD : basic_r<opc>;
+}
+
+multiclass basic_p<bits<4> opc> {
+ defm PS : basic_r<opc>;
+ defm PD : basic_r<opc>;
+}
+
+defm ADD : basic_s<0xf>, basic_p<0xf>;
+defm SUB : basic_s<0xe>, basic_p<0xe>;