diff options
author | David Greene <greened@obbligato.org> | 2009-06-08 19:16:56 +0000 |
---|---|---|
committer | David Greene <greened@obbligato.org> | 2009-06-08 19:16:56 +0000 |
commit | b035445537d357a8a94e249c40dadb4db17fa39d (patch) | |
tree | d3eefc1d840dbbbb03bbc2d07e9497afe45e9b88 | |
parent | d9173b83dbfe182440e01df9a42297d50fd3fd97 (diff) | |
download | bcm5719-llvm-b035445537d357a8a94e249c40dadb4db17fa39d.tar.gz bcm5719-llvm-b035445537d357a8a94e249c40dadb4db17fa39d.zip |
Make !if short-circuit when possible.
llvm-svn: 73076
-rw-r--r-- | llvm/utils/TableGen/Record.cpp | 18 |
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); |