Reverts 02940d6d22. Fixes breakage in the modules build.
LLVM loops cannot represent irreducible structures in the CFG. This
change introduce the concept of cycles as a generalization of loops,
along with a CycleInfo analysis that discovers a nested
hierarchy of such cycles. This is based on Havlak (1997), Nesting of
Reducible and Irreducible Loops.
The cycle analysis is implemented as a generic template and then
instatiated for LLVM IR and Machine IR. The template relies on a new
GenericSSAContext template which must be specialized when used for
each IR.
This review is a restart of an older review request:
https://reviews.llvm.org/D83094
Original implementation by Nicolai Hähnle <nicolai.haehnle@amd.com>,
with recent refactoring by Sameer Sahasrabuddhe <sameer.sahasrabuddhe@amd.com>
Differential Revision: https://reviews.llvm.org/D112696
48 lines
1.4 KiB
C++
48 lines
1.4 KiB
C++
//===- SSAContext.cpp -------------------------------------------*- 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
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
/// \file
|
|
///
|
|
/// This file defines a specialization of the GenericSSAContext<X>
|
|
/// template class for LLVM IR.
|
|
///
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#include "llvm/IR/SSAContext.h"
|
|
#include "llvm/IR/Argument.h"
|
|
#include "llvm/IR/BasicBlock.h"
|
|
#include "llvm/IR/Function.h"
|
|
#include "llvm/IR/Instruction.h"
|
|
#include "llvm/Support/raw_ostream.h"
|
|
|
|
using namespace llvm;
|
|
|
|
BasicBlock *SSAContext::getEntryBlock(Function &F) {
|
|
return &F.getEntryBlock();
|
|
}
|
|
|
|
void SSAContext::setFunction(Function &Fn) { F = &Fn; }
|
|
|
|
Printable SSAContext::print(Value *V) const {
|
|
return Printable([V](raw_ostream &Out) { V->print(Out); });
|
|
}
|
|
|
|
Printable SSAContext::print(Instruction *Inst) const {
|
|
return print(cast<Value>(Inst));
|
|
}
|
|
|
|
Printable SSAContext::print(BasicBlock *BB) const {
|
|
if (BB->hasName())
|
|
return Printable([BB](raw_ostream &Out) { Out << BB->getName(); });
|
|
|
|
return Printable([BB](raw_ostream &Out) {
|
|
ModuleSlotTracker MST{BB->getParent()->getParent(), false};
|
|
MST.incorporateFunction(*BB->getParent());
|
|
Out << MST.getLocalSlot(BB);
|
|
});
|
|
}
|