diff options
author | Bruno Cardoso Lopes <bruno.cardoso@gmail.com> | 2010-06-05 02:11:52 +0000 |
---|---|---|
committer | Bruno Cardoso Lopes <bruno.cardoso@gmail.com> | 2010-06-05 02:11:52 +0000 |
commit | 270562b3d4c61ae1381cb1b0026bb703b46ff88f (patch) | |
tree | dc95c8cba3a2dd08aa0facb0293c7689bca5e6bb /test | |
parent | 8613b18a5aa80b13bb8c7f470528146f009bed74 (diff) | |
download | external_llvm-270562b3d4c61ae1381cb1b0026bb703b46ff88f.zip external_llvm-270562b3d4c61ae1381cb1b0026bb703b46ff88f.tar.gz external_llvm-270562b3d4c61ae1381cb1b0026bb703b46ff88f.tar.bz2 |
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')
-rw-r--r-- | test/TableGen/DefmInsideMultiClass.td | 25 |
1 files changed, 25 insertions, 0 deletions
diff --git a/test/TableGen/DefmInsideMultiClass.td b/test/TableGen/DefmInsideMultiClass.td new file mode 100644 index 0000000..68cc12d --- /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>; |