From 77235d345eb11a3705fbb93196eb7817734402a9 Mon Sep 17 00:00:00 2001 From: Craig Topper Date: Fri, 7 Jul 2017 19:56:23 +0000 Subject: [PATCH] [PatternMatch] Implemenet m_SignMask using Constant::isMinSignedValue instead of doing splat detection and analyzing the resulting APInt. llvm-svn: 307433 --- llvm/include/llvm/IR/PatternMatch.h | 21 +++++++++++---------- 1 file changed, 11 insertions(+), 10 deletions(-) diff --git a/llvm/include/llvm/IR/PatternMatch.h b/llvm/include/llvm/IR/PatternMatch.h index 4b03063..acb8952 100644 --- a/llvm/include/llvm/IR/PatternMatch.h +++ b/llvm/include/llvm/IR/PatternMatch.h @@ -204,6 +204,17 @@ struct match_all_ones { /// \brief Match an integer or vector with all bits set to true. inline match_all_ones m_AllOnes() { return match_all_ones(); } +struct match_sign_mask { + template bool match(ITy *V) { + if (const auto *C = dyn_cast(V)) + return C->isMinSignedValue(); + return false; + } +}; + +/// \brief Match an integer or vector with only the sign bit(s) set. +inline match_sign_mask m_SignMask() { return match_sign_mask(); } + struct apint_match { const APInt *&Res; @@ -287,16 +298,6 @@ template struct api_pred_ty : public Predicate { } }; -struct is_sign_mask { - bool isValue(const APInt &C) { return C.isSignMask(); } -}; - -/// \brief Match an integer or vector with only the sign bit(s) set. -inline cst_pred_ty m_SignMask() { - return cst_pred_ty(); -} -inline api_pred_ty m_SignMask(const APInt *&V) { return V; } - struct is_power2 { bool isValue(const APInt &C) { return C.isPowerOf2(); } }; -- 2.7.4