I plan to use that to optimize mask creation in VPlan predicator by `or`ing edge masks from the post-dominance frontier instead of all predecessors in a subsequent patch. Note that it would require to use the same unmodified post-dom tree for *all* the basic blocks in a VPlan that is already limited to a particular loopnest so the algorithmic complexity concerns behind the "deprecation" notice in the beggining of `DominanceFrontier.h` (and also discussion in the https://discourse.llvm.org/t/dominance-frontiers/21755 thread) don't apply for my use case (at least to the best of my understanding). The change here is to properly use graph-traits for children traversal plus inline `ForwardDominanceFrontierBase` into `DominanceFrontierBase` now that it's used for post-dom-frontier. Since the only planned use-case is in the vectorizer, I'm adding a VPlan-base unittest along with this change. Support for multiple root nodes via using virtual root node to seed the worklist is left to a subsequent PR.
75 lines
2.5 KiB
C++
75 lines
2.5 KiB
C++
//===- MachineDominanceFrontier.cpp ---------------------------------------===//
|
|
//
|
|
// 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
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#include "llvm/CodeGen/MachineDominanceFrontier.h"
|
|
#include "llvm/CodeGen/MachineDominators.h"
|
|
#include "llvm/CodeGen/Passes.h"
|
|
#include "llvm/InitializePasses.h"
|
|
#include "llvm/Pass.h"
|
|
#include "llvm/PassRegistry.h"
|
|
|
|
using namespace llvm;
|
|
|
|
namespace llvm {
|
|
template class DominanceFrontierBase<MachineBasicBlock, false>;
|
|
}
|
|
|
|
char MachineDominanceFrontierWrapperPass::ID = 0;
|
|
|
|
INITIALIZE_PASS_BEGIN(MachineDominanceFrontierWrapperPass,
|
|
"machine-domfrontier",
|
|
"Machine Dominance Frontier Construction", true, true)
|
|
INITIALIZE_PASS_DEPENDENCY(MachineDominatorTreeWrapperPass)
|
|
INITIALIZE_PASS_END(MachineDominanceFrontierWrapperPass, "machine-domfrontier",
|
|
"Machine Dominance Frontier Construction", true, true)
|
|
|
|
MachineDominanceFrontierWrapperPass::MachineDominanceFrontierWrapperPass()
|
|
: MachineFunctionPass(ID) {}
|
|
|
|
char &llvm::MachineDominanceFrontierID =
|
|
MachineDominanceFrontierWrapperPass::ID;
|
|
|
|
bool MachineDominanceFrontier::invalidate(
|
|
MachineFunction &F, const PreservedAnalyses &PA,
|
|
MachineFunctionAnalysisManager::Invalidator &) {
|
|
auto PAC = PA.getChecker<MachineDominanceFrontierAnalysis>();
|
|
return !PAC.preserved() &&
|
|
!PAC.preservedSet<AllAnalysesOn<MachineFunction>>() &&
|
|
!PAC.preservedSet<CFGAnalyses>();
|
|
}
|
|
|
|
bool MachineDominanceFrontierWrapperPass::runOnMachineFunction(
|
|
MachineFunction &) {
|
|
MDF.releaseMemory();
|
|
auto &MDT = getAnalysis<MachineDominatorTreeWrapperPass>().getDomTree();
|
|
MDF.analyze(MDT);
|
|
return false;
|
|
}
|
|
|
|
void MachineDominanceFrontierWrapperPass::releaseMemory() {
|
|
MDF.releaseMemory();
|
|
}
|
|
|
|
void MachineDominanceFrontierWrapperPass::getAnalysisUsage(
|
|
AnalysisUsage &AU) const {
|
|
AU.setPreservesAll();
|
|
AU.addRequired<MachineDominatorTreeWrapperPass>();
|
|
MachineFunctionPass::getAnalysisUsage(AU);
|
|
}
|
|
|
|
AnalysisKey MachineDominanceFrontierAnalysis::Key;
|
|
|
|
MachineDominanceFrontierAnalysis::Result
|
|
MachineDominanceFrontierAnalysis::run(MachineFunction &MF,
|
|
MachineFunctionAnalysisManager &MFAM) {
|
|
MachineDominanceFrontier MDF;
|
|
auto &MDT = MFAM.getResult<MachineDominatorTreeAnalysis>(MF);
|
|
MDF.analyze(MDT);
|
|
return MDF;
|
|
}
|