[polly] r246383 - Remove isNew from getOrCreateAlloca
Tobias Grosser via llvm-commits
llvm-commits at lists.llvm.org
Sun Aug 30 08:03:59 PDT 2015
Author: grosser
Date: Sun Aug 30 10:03:59 2015
New Revision: 246383
URL: http://llvm.org/viewvc/llvm-project?rev=246383&view=rev
Log:
Remove isNew from getOrCreateAlloca
This commit drops some dead code. Specifically, there is no need to initialize
the virtual memory locations of scalars in BlockGenerator::handleOutsideUsers,
the function that initalizes the escape map that keeps track of out-of-scope
uses of scalar values. We already model instructions inside the scop that
are used outside the scope (escaping instructions) as scalar memory writes at
the position of the instruction. As a result, the virtual memory location of
this instructions is already initialized when code-generating the corresponding
virtual scalar write and consequently does not need to be initialized later on
when generating the set of escaping values.
Code references:
In TempScopInfo::buildScalarDependences we detect scalar cross-statement
dependences for all instructions (including PHIs) that have uses outside of the
scop's region:
// Check whether or not the use is in the SCoP.
if (!R->contains(UseParent)) {
AnyCrossStmtUse = true;
continue;
}
We use this information in TempScopInfo::buildAccessFunctions were we build
scalar write memory accesses for all these instructions:
if (!isa<StoreInst>(Inst) &&
buildScalarDependences(Inst, &R, NonAffineSubRegion)) {
// If the Instruction is used outside the statement, we need to build the
// write access.
IRAccess ScalarAccess(IRAccess::MUST_WRITE, Inst, ZeroOffset, 1, true,
Inst);
Functions.push_back(std::make_pair(ScalarAccess, Inst));
}
Reviewers: jdoerfert
Subscribers: pollydev, llvm-commits
Differential Revision: http://reviews.llvm.org/D12472
Modified:
polly/trunk/include/polly/CodeGen/BlockGenerators.h
polly/trunk/lib/CodeGen/BlockGenerators.cpp
Modified: polly/trunk/include/polly/CodeGen/BlockGenerators.h
URL: http://llvm.org/viewvc/llvm-project/polly/trunk/include/polly/CodeGen/BlockGenerators.h?rev=246383&r1=246382&r2=246383&view=diff
==============================================================================
--- polly/trunk/include/polly/CodeGen/BlockGenerators.h (original)
+++ polly/trunk/include/polly/CodeGen/BlockGenerators.h Sun Aug 30 10:03:59 2015
@@ -348,12 +348,10 @@ protected:
/// @param ScalarBase The demoted scalar value.
/// @param Map The map we should look for a mapped alloca value.
/// @param NameExt The suffix we add to the name of a new created alloca.
- /// @param IsNew If set it will hold true iff the alloca was created.
///
/// @returns The alloca for @p ScalarBase in @p Map.
AllocaInst *getOrCreateAlloca(Value *ScalarBase, ScalarAllocaMapTy &Map,
- const char *NameExt = ".s2a",
- bool *IsNew = nullptr);
+ const char *NameExt);
/// @brief Generate reload of scalars demoted to memory and needed by @p Inst.
///
Modified: polly/trunk/lib/CodeGen/BlockGenerators.cpp
URL: http://llvm.org/viewvc/llvm-project/polly/trunk/lib/CodeGen/BlockGenerators.cpp?rev=246383&r1=246382&r2=246383&view=diff
==============================================================================
--- polly/trunk/lib/CodeGen/BlockGenerators.cpp (original)
+++ polly/trunk/lib/CodeGen/BlockGenerators.cpp Sun Aug 30 10:03:59 2015
@@ -342,16 +342,10 @@ void BlockGenerator::copyBB(ScopStmt &St
AllocaInst *BlockGenerator::getOrCreateAlloca(Value *ScalarBase,
ScalarAllocaMapTy &Map,
- const char *NameExt,
- bool *IsNew) {
-
+ const char *NameExt) {
// Check if an alloca was cached for the base instruction.
AllocaInst *&Addr = Map[ScalarBase];
- // If needed indicate if it was found already or will be created.
- if (IsNew)
- *IsNew = (Addr == nullptr);
-
// If no alloca was found create one and insert it in the entry block.
if (!Addr) {
auto *Ty = ScalarBase->getType();
@@ -379,11 +373,9 @@ AllocaInst *BlockGenerator::getOrCreateP
void BlockGenerator::handleOutsideUsers(const Region &R, Instruction *Inst,
Value *InstCopy) {
- // If there are escape users we get the alloca for this instruction and put
- // it in the EscapeMap for later finalization. However, if the alloca was not
- // created by an already handled scalar dependence we have to initialize it
- // also. Lastly, if the instruction was copied multiple times we already did
- // this and can exit.
+ // If there are escape users we get the alloca for this instruction and put it
+ // in the EscapeMap for later finalization. Lastly, if the instruction was
+ // copied multiple times we already did this and can exit.
if (EscapeMap.count(Inst))
return;
@@ -406,19 +398,10 @@ void BlockGenerator::handleOutsideUsers(
return;
// Get or create an escape alloca for this instruction.
- bool IsNew;
- AllocaInst *ScalarAddr =
- getOrCreateAlloca(Inst, ScalarMap, ".escape", &IsNew);
+ AllocaInst *ScalarAddr = getOrCreateScalarAlloca(Inst);
// Remember that this instruction has escape uses and the escape alloca.
EscapeMap[Inst] = std::make_pair(ScalarAddr, std::move(EscapeUsers));
-
- // If the escape alloca was just created store the instruction in there,
- // otherwise that happened already.
- if (IsNew) {
- assert(InstCopy && "Except PHIs every instruction should have a copy!");
- Builder.CreateStore(InstCopy, ScalarAddr);
- }
}
void BlockGenerator::generateScalarLoads(ScopStmt &Stmt,
More information about the llvm-commits
mailing list