summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDavid Greene <greened@obbligato.org>2009-06-08 19:16:56 +0000
committerDavid Greene <greened@obbligato.org>2009-06-08 19:16:56 +0000
commitb035445537d357a8a94e249c40dadb4db17fa39d (patch)
treed3eefc1d840dbbbb03bbc2d07e9497afe45e9b88
parentd9173b83dbfe182440e01df9a42297d50fd3fd97 (diff)
downloadbcm5719-llvm-b035445537d357a8a94e249c40dadb4db17fa39d.tar.gz
bcm5719-llvm-b035445537d357a8a94e249c40dadb4db17fa39d.zip
Make !if short-circuit when possible.
llvm-svn: 73076
-rw-r--r--llvm/utils/TableGen/Record.cpp18
1 files changed, 17 insertions, 1 deletions
diff --git a/llvm/utils/TableGen/Record.cpp b/llvm/utils/TableGen/Record.cpp
index 47cab7b5db8..18584ec8a01 100644
--- a/llvm/utils/TableGen/Record.cpp
+++ b/llvm/utils/TableGen/Record.cpp
@@ -965,9 +965,25 @@ Init *TernOpInit::Fold(Record *CurRec, MultiClass *CurMultiClass) {
Init *TernOpInit::resolveReferences(Record &R, const RecordVal *RV) {
Init *lhs = LHS->resolveReferences(R, RV);
+
+ if (Opc == IF && lhs != LHS) {
+ IntInit *Value = dynamic_cast<IntInit*>(lhs);
+ if (Value != 0) {
+ // Short-circuit
+ if (Value->getValue()) {
+ Init *mhs = MHS->resolveReferences(R, RV);
+ return (new TernOpInit(getOpcode(), lhs, mhs, RHS, getType()))->Fold(&R, 0);
+ }
+ else {
+ Init *rhs = RHS->resolveReferences(R, RV);
+ return (new TernOpInit(getOpcode(), lhs, MHS, rhs, getType()))->Fold(&R, 0);
+ }
+ }
+ }
+
Init *mhs = MHS->resolveReferences(R, RV);
Init *rhs = RHS->resolveReferences(R, RV);
-
+
if (LHS != lhs || MHS != mhs || RHS != rhs)
return (new TernOpInit(getOpcode(), lhs, mhs, rhs, getType()))->Fold(&R, 0);
return Fold(&R, 0);
OpenPOWER on IntegriCloud