diff options
author | Bruno Cardoso Lopes <bruno.cardoso@gmail.com> | 2010-06-10 02:42:59 +0000 |
---|---|---|
committer | Bruno Cardoso Lopes <bruno.cardoso@gmail.com> | 2010-06-10 02:42:59 +0000 |
commit | ee65db3add855bfbc4ddc7e45926d1b9bafca8a4 (patch) | |
tree | 66d1077f45dd0e5ec7082137c540e017545a50a7 /test/TableGen | |
parent | 302ef834e0a2fd03e4b435079a9fa6c1e1cdc23b (diff) | |
download | llvm-ee65db3add855bfbc4ddc7e45926d1b9bafca8a4.tar.gz llvm-ee65db3add855bfbc4ddc7e45926d1b9bafca8a4.tar.bz2 llvm-ee65db3add855bfbc4ddc7e45926d1b9bafca8a4.tar.xz |
Teach tablegen to allow "let" expressions inside multiclasses,
providing more ways to factor out commonality from the records.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@105776 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'test/TableGen')
-rw-r--r-- | test/TableGen/LetInsideMultiClasses.td | 29 |
1 files changed, 29 insertions, 0 deletions
diff --git a/test/TableGen/LetInsideMultiClasses.td b/test/TableGen/LetInsideMultiClasses.td new file mode 100644 index 0000000000..9238bf42d9 --- /dev/null +++ b/test/TableGen/LetInsideMultiClasses.td @@ -0,0 +1,29 @@ +// RUN: tblgen %s | grep "bit IsDouble = 1;" | count 3 +// XFAIL: vg_leak + +class Instruction<bits<4> opc, string Name> { + bits<4> opcode = opc; + string name = Name; + bit IsDouble = 0; +} + +multiclass basic_r<bits<4> opc> { + let name = "newname" in { + def rr : Instruction<opc, "rr">; + def rm : Instruction<opc, "rm">; + } + + let name = "othername" in + def rx : Instruction<opc, "rx">; +} + +multiclass basic_ss<bits<4> opc> { + let IsDouble = 0 in + defm SS : basic_r<opc>; + + let IsDouble = 1 in + defm SD : basic_r<opc>; +} + +defm ADD : basic_ss<0xf>; + |