blob: 336c202b6f94ceea6c0d0a75f072be4881078d60 [file] [log] [blame]
//===- ConvergenceVerifier.cpp - Verify convergence control -----*- C++ -*-===//
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
// See for license information.
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
#include "llvm/IR/ConvergenceVerifier.h"
#include "llvm/IR/Dominators.h"
#include "llvm/IR/GenericConvergenceVerifierImpl.h"
#include "llvm/IR/Instructions.h"
#include "llvm/IR/SSAContext.h"
using namespace llvm;
template <>
const Instruction *
const Instruction &I) {
auto *CB = dyn_cast<CallBase>(&I);
if (!CB)
return nullptr;
unsigned Count =
CheckOrNull(Count <= 1,
"The 'convergencectrl' bundle can occur at most once on a call",
if (!Count)
return nullptr;
auto Bundle = CB->getOperandBundle(LLVMContext::OB_convergencectrl);
CheckOrNull(Bundle->Inputs.size() == 1 &&
"The 'convergencectrl' bundle requires exactly one token use.",
auto *Token = Bundle->Inputs[0].get();
auto *Def = dyn_cast<Instruction>(Token);
Def && isConvergenceControlIntrinsic(SSAContext::getIntrinsicID(*Def)),
"Convergence control tokens can only be produced by calls to the "
"convergence control intrinsics.",
{Context.print(Token), Context.print(&I)});
if (Def)
Tokens[&I] = Def;
return Def;
template <>
bool GenericConvergenceVerifier<SSAContext>::isInsideConvergentFunction(
const InstructionT &I) {
auto *F = I.getFunction();
return F->isConvergent();
template <>
bool GenericConvergenceVerifier<SSAContext>::isConvergent(
const InstructionT &I) {
if (auto *CB = dyn_cast<CallBase>(&I)) {
return CB->isConvergent();
return false;
template class llvm::GenericConvergenceVerifier<SSAContext>;