mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-23 03:02:36 +01:00
68092989f3
This file lists every pass in LLVM, and is included by Pass.h, which is very popular. Every time we add, remove, or rename a pass in LLVM, it caused lots of recompilation. I found this fact by looking at this table, which is sorted by the number of times a file was changed over the last 100,000 git commits multiplied by the number of object files that depend on it in the current checkout: recompiles touches affected_files header 342380 95 3604 llvm/include/llvm/ADT/STLExtras.h 314730 234 1345 llvm/include/llvm/InitializePasses.h 307036 118 2602 llvm/include/llvm/ADT/APInt.h 213049 59 3611 llvm/include/llvm/Support/MathExtras.h 170422 47 3626 llvm/include/llvm/Support/Compiler.h 162225 45 3605 llvm/include/llvm/ADT/Optional.h 158319 63 2513 llvm/include/llvm/ADT/Triple.h 140322 39 3598 llvm/include/llvm/ADT/StringRef.h 137647 59 2333 llvm/include/llvm/Support/Error.h 131619 73 1803 llvm/include/llvm/Support/FileSystem.h Before this change, touching InitializePasses.h would cause 1345 files to recompile. After this change, touching it only causes 550 compiles in an incremental rebuild. Reviewers: bkramer, asbirlea, bollu, jdoerfert Differential Revision: https://reviews.llvm.org/D70211
150 lines
6.1 KiB
C++
150 lines
6.1 KiB
C++
//===- LoopTransformWarning.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
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
//
|
|
// Emit warnings if forced code transformations have not been performed.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#include "llvm/Transforms/Scalar/WarnMissedTransforms.h"
|
|
#include "llvm/Analysis/OptimizationRemarkEmitter.h"
|
|
#include "llvm/InitializePasses.h"
|
|
#include "llvm/Transforms/Utils/LoopUtils.h"
|
|
|
|
using namespace llvm;
|
|
|
|
#define DEBUG_TYPE "transform-warning"
|
|
|
|
/// Emit warnings for forced (i.e. user-defined) loop transformations which have
|
|
/// still not been performed.
|
|
static void warnAboutLeftoverTransformations(Loop *L,
|
|
OptimizationRemarkEmitter *ORE) {
|
|
if (hasUnrollTransformation(L) == TM_ForcedByUser) {
|
|
LLVM_DEBUG(dbgs() << "Leftover unroll transformation\n");
|
|
ORE->emit(
|
|
DiagnosticInfoOptimizationFailure(DEBUG_TYPE,
|
|
"FailedRequestedUnrolling",
|
|
L->getStartLoc(), L->getHeader())
|
|
<< "loop not unrolled: the optimizer was unable to perform the "
|
|
"requested transformation; the transformation might be disabled or "
|
|
"specified as part of an unsupported transformation ordering");
|
|
}
|
|
|
|
if (hasUnrollAndJamTransformation(L) == TM_ForcedByUser) {
|
|
LLVM_DEBUG(dbgs() << "Leftover unroll-and-jam transformation\n");
|
|
ORE->emit(
|
|
DiagnosticInfoOptimizationFailure(DEBUG_TYPE,
|
|
"FailedRequestedUnrollAndJamming",
|
|
L->getStartLoc(), L->getHeader())
|
|
<< "loop not unroll-and-jammed: the optimizer was unable to perform "
|
|
"the requested transformation; the transformation might be disabled "
|
|
"or specified as part of an unsupported transformation ordering");
|
|
}
|
|
|
|
if (hasVectorizeTransformation(L) == TM_ForcedByUser) {
|
|
LLVM_DEBUG(dbgs() << "Leftover vectorization transformation\n");
|
|
Optional<int> VectorizeWidth =
|
|
getOptionalIntLoopAttribute(L, "llvm.loop.vectorize.width");
|
|
Optional<int> InterleaveCount =
|
|
getOptionalIntLoopAttribute(L, "llvm.loop.interleave.count");
|
|
|
|
if (VectorizeWidth.getValueOr(0) != 1)
|
|
ORE->emit(
|
|
DiagnosticInfoOptimizationFailure(DEBUG_TYPE,
|
|
"FailedRequestedVectorization",
|
|
L->getStartLoc(), L->getHeader())
|
|
<< "loop not vectorized: the optimizer was unable to perform the "
|
|
"requested transformation; the transformation might be disabled "
|
|
"or specified as part of an unsupported transformation ordering");
|
|
else if (InterleaveCount.getValueOr(0) != 1)
|
|
ORE->emit(
|
|
DiagnosticInfoOptimizationFailure(DEBUG_TYPE,
|
|
"FailedRequestedInterleaving",
|
|
L->getStartLoc(), L->getHeader())
|
|
<< "loop not interleaved: the optimizer was unable to perform the "
|
|
"requested transformation; the transformation might be disabled "
|
|
"or specified as part of an unsupported transformation ordering");
|
|
}
|
|
|
|
if (hasDistributeTransformation(L) == TM_ForcedByUser) {
|
|
LLVM_DEBUG(dbgs() << "Leftover distribute transformation\n");
|
|
ORE->emit(
|
|
DiagnosticInfoOptimizationFailure(DEBUG_TYPE,
|
|
"FailedRequestedDistribution",
|
|
L->getStartLoc(), L->getHeader())
|
|
<< "loop not distributed: the optimizer was unable to perform the "
|
|
"requested transformation; the transformation might be disabled or "
|
|
"specified as part of an unsupported transformation ordering");
|
|
}
|
|
}
|
|
|
|
static void warnAboutLeftoverTransformations(Function *F, LoopInfo *LI,
|
|
OptimizationRemarkEmitter *ORE) {
|
|
for (auto *L : LI->getLoopsInPreorder())
|
|
warnAboutLeftoverTransformations(L, ORE);
|
|
}
|
|
|
|
// New pass manager boilerplate
|
|
PreservedAnalyses
|
|
WarnMissedTransformationsPass::run(Function &F, FunctionAnalysisManager &AM) {
|
|
// Do not warn about not applied transformations if optimizations are
|
|
// disabled.
|
|
if (F.hasOptNone())
|
|
return PreservedAnalyses::all();
|
|
|
|
auto &ORE = AM.getResult<OptimizationRemarkEmitterAnalysis>(F);
|
|
auto &LI = AM.getResult<LoopAnalysis>(F);
|
|
|
|
warnAboutLeftoverTransformations(&F, &LI, &ORE);
|
|
|
|
return PreservedAnalyses::all();
|
|
}
|
|
|
|
// Legacy pass manager boilerplate
|
|
namespace {
|
|
class WarnMissedTransformationsLegacy : public FunctionPass {
|
|
public:
|
|
static char ID;
|
|
|
|
explicit WarnMissedTransformationsLegacy() : FunctionPass(ID) {
|
|
initializeWarnMissedTransformationsLegacyPass(
|
|
*PassRegistry::getPassRegistry());
|
|
}
|
|
|
|
bool runOnFunction(Function &F) override {
|
|
if (skipFunction(F))
|
|
return false;
|
|
|
|
auto &ORE = getAnalysis<OptimizationRemarkEmitterWrapperPass>().getORE();
|
|
auto &LI = getAnalysis<LoopInfoWrapperPass>().getLoopInfo();
|
|
|
|
warnAboutLeftoverTransformations(&F, &LI, &ORE);
|
|
return false;
|
|
}
|
|
|
|
void getAnalysisUsage(AnalysisUsage &AU) const override {
|
|
AU.addRequired<OptimizationRemarkEmitterWrapperPass>();
|
|
AU.addRequired<LoopInfoWrapperPass>();
|
|
|
|
AU.setPreservesAll();
|
|
}
|
|
};
|
|
} // end anonymous namespace
|
|
|
|
char WarnMissedTransformationsLegacy::ID = 0;
|
|
|
|
INITIALIZE_PASS_BEGIN(WarnMissedTransformationsLegacy, "transform-warning",
|
|
"Warn about non-applied transformations", false, false)
|
|
INITIALIZE_PASS_DEPENDENCY(LoopInfoWrapperPass)
|
|
INITIALIZE_PASS_DEPENDENCY(OptimizationRemarkEmitterWrapperPass)
|
|
INITIALIZE_PASS_END(WarnMissedTransformationsLegacy, "transform-warning",
|
|
"Warn about non-applied transformations", false, false)
|
|
|
|
Pass *llvm::createWarnMissedTransformationsPass() {
|
|
return new WarnMissedTransformationsLegacy();
|
|
}
|