summaryrefslogtreecommitdiffstats
path: root/llvm/test/TableGen
diff options
context:
space:
mode:
authorToma Tabacu <toma.tabacu@imgtec.com>2015-04-07 12:10:11 +0000
committerToma Tabacu <toma.tabacu@imgtec.com>2015-04-07 12:10:11 +0000
commit3d5ce49ce5c968aa4b321843f37cdcb4eecdf834 (patch)
tree222b1e296de147b17d2e22f551984394546ea5a0 /llvm/test/TableGen
parent14ed198ff719bf851c10434500ec88740ffca30c (diff)
downloadbcm5719-llvm-3d5ce49ce5c968aa4b321843f37cdcb4eecdf834.tar.gz
bcm5719-llvm-3d5ce49ce5c968aa4b321843f37cdcb4eecdf834.zip
[TableGen] Prevent invalid code generation when emitting AssemblerPredicate conditions.
Summary: The loop which emits AssemblerPredicate conditions also links them together by emitting a '&&'. If the 1st predicate is not an AssemblerPredicate, while the 2nd one is, nothing gets emitted for the 1st one, but we still emit the '&&' because of the 2nd predicate. This generated code looks like "( && Cond2)" and is invalid. Reviewers: dsanders Reviewed By: dsanders Subscribers: dsanders, llvm-commits Differential Revision: http://reviews.llvm.org/D8294 llvm-svn: 234312
Diffstat (limited to 'llvm/test/TableGen')
-rw-r--r--llvm/test/TableGen/AsmPredicateCondsEmission.td31
1 files changed, 31 insertions, 0 deletions
diff --git a/llvm/test/TableGen/AsmPredicateCondsEmission.td b/llvm/test/TableGen/AsmPredicateCondsEmission.td
new file mode 100644
index 00000000000..ba5898fbebd
--- /dev/null
+++ b/llvm/test/TableGen/AsmPredicateCondsEmission.td
@@ -0,0 +1,31 @@
+// RUN: llvm-tblgen -gen-disassembler -I %p/../../include %s | FileCheck %s
+
+// Check that we don't generate invalid code of the form "( && Cond2)" when
+// emitting AssemblerPredicate conditions. In the example below, the invalid
+// code would be: "return ( && (Bits & arch::AssemblerCondition2));".
+
+include "llvm/Target/Target.td"
+
+def archInstrInfo : InstrInfo { }
+
+def arch : Target {
+ let InstructionSet = archInstrInfo;
+}
+
+def Pred1 : Predicate<"Condition1">;
+def Pred2 : Predicate<"Condition2">,
+ AssemblerPredicate<"AssemblerCondition2">;
+
+def foo : Instruction {
+ let Size = 2;
+ let OutOperandList = (outs);
+ let InOperandList = (ins);
+ field bits<16> Inst;
+ let Inst = 0xAAAA;
+ let AsmString = "foo";
+ field bits<16> SoftFail = 0;
+ // This is the important bit:
+ let Predicates = [Pred1, Pred2];
+}
+
+// CHECK: return ((Bits & arch::AssemblerCondition2));
OpenPOWER on IntegriCloud