diff options
| author | Chris Lattner <sabre@nondot.org> | 2008-05-09 05:20:27 +0000 |
|---|---|---|
| committer | Chris Lattner <sabre@nondot.org> | 2008-05-09 05:20:27 +0000 |
| commit | f2e4cfd7e283cdbd8968336fbf29ee64aad86b94 (patch) | |
| tree | 193a419fc6bfe518254982a730a8c8ce3a211dd9 /llvm | |
| parent | aaba10e8435b26d71b27a03b4e2efeb86c153891 (diff) | |
| download | bcm5719-llvm-f2e4cfd7e283cdbd8968336fbf29ee64aad86b94.tar.gz bcm5719-llvm-f2e4cfd7e283cdbd8968336fbf29ee64aad86b94.zip | |
add support for pattern matching 'neg'
llvm-svn: 50883
Diffstat (limited to 'llvm')
| -rw-r--r-- | llvm/include/llvm/InstrTypes.h | 6 | ||||
| -rw-r--r-- | llvm/include/llvm/Support/PatternMatch.h | 29 |
2 files changed, 31 insertions, 4 deletions
diff --git a/llvm/include/llvm/InstrTypes.h b/llvm/include/llvm/InstrTypes.h index ef0ee89a3ed..f735602ca8c 100644 --- a/llvm/include/llvm/InstrTypes.h +++ b/llvm/include/llvm/InstrTypes.h @@ -236,10 +236,8 @@ public: /// swapOperands - Exchange the two operands to this instruction. /// This instruction is safe to use on any binary instruction and - /// does not modify the semantics of the instruction. If the - /// instruction is order dependent (SetLT f.e.) the opcode is - /// changed. If the instruction cannot be reversed (ie, it's a Div), - /// then return true. + /// does not modify the semantics of the instruction. If the instruction + /// cannot be reversed (ie, it's a Div), then return true. /// bool swapOperands(); diff --git a/llvm/include/llvm/Support/PatternMatch.h b/llvm/include/llvm/Support/PatternMatch.h index ca558821021..a3951e2dd39 100644 --- a/llvm/include/llvm/Support/PatternMatch.h +++ b/llvm/include/llvm/Support/PatternMatch.h @@ -385,6 +385,35 @@ template<typename LHS> inline not_match<LHS> m_Not(const LHS &L) { return L; } +template<typename LHS_t> +struct neg_match { + LHS_t L; + + neg_match(const LHS_t &LHS) : L(LHS) {} + + template<typename OpTy> + bool match(OpTy *V) { + if (Instruction *I = dyn_cast<Instruction>(V)) + if (I->getOpcode() == Instruction::Sub) + return matchIfNeg(I->getOperand(0), I->getOperand(1)); + if (ConstantExpr *CE = dyn_cast<ConstantExpr>(V)) + if (CE->getOpcode() == Instruction::Sub) + return matchIfNeg(CE->getOperand(0), CE->getOperand(1)); + if (ConstantInt *CI = dyn_cast<ConstantInt>(V)) + return L.match(ConstantExpr::getNeg(CI)); + return false; + } +private: + bool matchIfNeg(Value *LHS, Value *RHS) { + return LHS == ConstantExpr::getZeroValueForNegationExpr(LHS->getType()) && + L.match(RHS); + } +}; + +template<typename LHS> +inline neg_match<LHS> m_Neg(const LHS &L) { return L; } + + //===----------------------------------------------------------------------===// // Matchers for control flow // |

