diff options
Diffstat (limited to 'llvm/lib/Analysis/GuardUtils.cpp')
| -rw-r--r-- | llvm/lib/Analysis/GuardUtils.cpp | 49 | 
1 files changed, 49 insertions, 0 deletions
diff --git a/llvm/lib/Analysis/GuardUtils.cpp b/llvm/lib/Analysis/GuardUtils.cpp new file mode 100644 index 000000000000..cad92f6e56bb --- /dev/null +++ b/llvm/lib/Analysis/GuardUtils.cpp @@ -0,0 +1,49 @@ +//===-- GuardUtils.cpp - Utils for work with guards -------------*- C++ -*-===// +// +// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. +// See https://llvm.org/LICENSE.txt for license information. +// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception +// +//===----------------------------------------------------------------------===// +// Utils that are used to perform analyzes related to guards and their +// conditions. +//===----------------------------------------------------------------------===// + +#include "llvm/Analysis/GuardUtils.h" +#include "llvm/IR/PatternMatch.h" + +using namespace llvm; + +bool llvm::isGuard(const User *U) { +  using namespace llvm::PatternMatch; +  return match(U, m_Intrinsic<Intrinsic::experimental_guard>()); +} + +bool llvm::isGuardAsWidenableBranch(const User *U) { +  Value *Condition, *WidenableCondition; +  BasicBlock *GuardedBB, *DeoptBB; +  if (!parseWidenableBranch(U, Condition, WidenableCondition, GuardedBB, +                            DeoptBB)) +    return false; +  using namespace llvm::PatternMatch; +  for (auto &Insn : *DeoptBB) { +    if (match(&Insn, m_Intrinsic<Intrinsic::experimental_deoptimize>())) +      return true; +    if (Insn.mayHaveSideEffects()) +      return false; +  } +  return false; +} + +bool llvm::parseWidenableBranch(const User *U, Value *&Condition, +                                Value *&WidenableCondition, +                                BasicBlock *&IfTrueBB, BasicBlock *&IfFalseBB) { +  using namespace llvm::PatternMatch; +  if (!match(U, m_Br(m_And(m_Value(Condition), m_Value(WidenableCondition)), +                     IfTrueBB, IfFalseBB))) +    return false; +  // TODO: At the moment, we only recognize the branch if the WC call in this +  // specific position.  We should generalize! +  return match(WidenableCondition, +               m_Intrinsic<Intrinsic::experimental_widenable_condition>()); +}  | 
