2017-10-18 05:27:42 +08:00
|
|
|
//===- Local.cpp - Functions to perform local transformations -------------===//
|
2005-04-22 07:48:37 +08:00
|
|
|
//
|
2003-10-21 03:43:21 +08:00
|
|
|
// The LLVM Compiler Infrastructure
|
|
|
|
//
|
2007-12-30 04:36:04 +08:00
|
|
|
// This file is distributed under the University of Illinois Open Source
|
|
|
|
// License. See LICENSE.TXT for details.
|
2005-04-22 07:48:37 +08:00
|
|
|
//
|
2003-10-21 03:43:21 +08:00
|
|
|
//===----------------------------------------------------------------------===//
|
2002-05-08 02:07:59 +08:00
|
|
|
//
|
|
|
|
// This family of functions perform various local transformations to the
|
|
|
|
// program.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
2018-06-05 05:23:21 +08:00
|
|
|
#include "llvm/Transforms/Utils/Local.h"
|
2017-10-18 05:27:42 +08:00
|
|
|
#include "llvm/ADT/APInt.h"
|
2012-12-04 00:50:05 +08:00
|
|
|
#include "llvm/ADT/DenseMap.h"
|
2017-10-18 05:27:42 +08:00
|
|
|
#include "llvm/ADT/DenseMapInfo.h"
|
2015-06-19 00:01:00 +08:00
|
|
|
#include "llvm/ADT/DenseSet.h"
|
|
|
|
#include "llvm/ADT/Hashing.h"
|
2017-10-18 05:27:42 +08:00
|
|
|
#include "llvm/ADT/None.h"
|
|
|
|
#include "llvm/ADT/Optional.h"
|
2012-12-21 19:18:49 +08:00
|
|
|
#include "llvm/ADT/STLExtras.h"
|
2015-09-29 02:56:07 +08:00
|
|
|
#include "llvm/ADT/SetVector.h"
|
2013-01-02 18:22:59 +08:00
|
|
|
#include "llvm/ADT/SmallPtrSet.h"
|
2017-10-18 05:27:42 +08:00
|
|
|
#include "llvm/ADT/SmallVector.h"
|
2013-08-13 06:38:43 +08:00
|
|
|
#include "llvm/ADT/Statistic.h"
|
2017-10-18 05:27:42 +08:00
|
|
|
#include "llvm/ADT/TinyPtrVector.h"
|
|
|
|
#include "llvm/Analysis/ConstantFolding.h"
|
2015-12-03 07:06:39 +08:00
|
|
|
#include "llvm/Analysis/EHPersonalities.h"
|
2012-12-04 00:50:05 +08:00
|
|
|
#include "llvm/Analysis/InstructionSimplify.h"
|
2016-01-10 15:13:04 +08:00
|
|
|
#include "llvm/Analysis/LazyValueInfo.h"
|
2017-06-06 19:49:48 +08:00
|
|
|
#include "llvm/Analysis/MemoryBuiltins.h"
|
2018-08-17 05:58:44 +08:00
|
|
|
#include "llvm/Analysis/MemorySSAUpdater.h"
|
2017-10-18 05:27:42 +08:00
|
|
|
#include "llvm/Analysis/TargetLibraryInfo.h"
|
2012-12-04 00:50:05 +08:00
|
|
|
#include "llvm/Analysis/ValueTracking.h"
|
2017-10-18 05:27:42 +08:00
|
|
|
#include "llvm/BinaryFormat/Dwarf.h"
|
|
|
|
#include "llvm/IR/Argument.h"
|
|
|
|
#include "llvm/IR/Attributes.h"
|
|
|
|
#include "llvm/IR/BasicBlock.h"
|
2014-03-04 19:45:46 +08:00
|
|
|
#include "llvm/IR/CFG.h"
|
2017-10-18 05:27:42 +08:00
|
|
|
#include "llvm/IR/CallSite.h"
|
|
|
|
#include "llvm/IR/Constant.h"
|
2017-06-26 11:31:31 +08:00
|
|
|
#include "llvm/IR/ConstantRange.h"
|
2013-01-02 19:36:10 +08:00
|
|
|
#include "llvm/IR/Constants.h"
|
2014-03-06 08:22:06 +08:00
|
|
|
#include "llvm/IR/DIBuilder.h"
|
2013-01-02 19:36:10 +08:00
|
|
|
#include "llvm/IR/DataLayout.h"
|
2017-10-18 05:27:42 +08:00
|
|
|
#include "llvm/IR/DebugInfoMetadata.h"
|
|
|
|
#include "llvm/IR/DebugLoc.h"
|
2013-01-02 19:36:10 +08:00
|
|
|
#include "llvm/IR/DerivedTypes.h"
|
2018-08-03 13:08:17 +08:00
|
|
|
#include "llvm/IR/DomTreeUpdater.h"
|
2014-01-13 17:26:24 +08:00
|
|
|
#include "llvm/IR/Dominators.h"
|
2017-10-18 05:27:42 +08:00
|
|
|
#include "llvm/IR/Function.h"
|
2014-03-04 18:40:04 +08:00
|
|
|
#include "llvm/IR/GetElementPtrTypeIterator.h"
|
2017-10-18 05:27:42 +08:00
|
|
|
#include "llvm/IR/GlobalObject.h"
|
2013-01-02 19:36:10 +08:00
|
|
|
#include "llvm/IR/IRBuilder.h"
|
2017-10-18 05:27:42 +08:00
|
|
|
#include "llvm/IR/InstrTypes.h"
|
|
|
|
#include "llvm/IR/Instruction.h"
|
2013-01-02 19:36:10 +08:00
|
|
|
#include "llvm/IR/Instructions.h"
|
|
|
|
#include "llvm/IR/IntrinsicInst.h"
|
|
|
|
#include "llvm/IR/Intrinsics.h"
|
2017-10-18 05:27:42 +08:00
|
|
|
#include "llvm/IR/LLVMContext.h"
|
2013-01-02 19:36:10 +08:00
|
|
|
#include "llvm/IR/MDBuilder.h"
|
|
|
|
#include "llvm/IR/Metadata.h"
|
2017-10-18 05:27:42 +08:00
|
|
|
#include "llvm/IR/Module.h"
|
2013-01-02 19:36:10 +08:00
|
|
|
#include "llvm/IR/Operator.h"
|
2016-06-25 16:34:38 +08:00
|
|
|
#include "llvm/IR/PatternMatch.h"
|
2017-10-18 05:27:42 +08:00
|
|
|
#include "llvm/IR/Type.h"
|
|
|
|
#include "llvm/IR/Use.h"
|
|
|
|
#include "llvm/IR/User.h"
|
|
|
|
#include "llvm/IR/Value.h"
|
2014-03-04 19:17:44 +08:00
|
|
|
#include "llvm/IR/ValueHandle.h"
|
2017-10-18 05:27:42 +08:00
|
|
|
#include "llvm/Support/Casting.h"
|
2009-11-10 13:59:26 +08:00
|
|
|
#include "llvm/Support/Debug.h"
|
2017-10-18 05:27:42 +08:00
|
|
|
#include "llvm/Support/ErrorHandling.h"
|
2017-04-27 00:39:58 +08:00
|
|
|
#include "llvm/Support/KnownBits.h"
|
2009-11-10 13:59:26 +08:00
|
|
|
#include "llvm/Support/raw_ostream.h"
|
2018-01-26 05:37:05 +08:00
|
|
|
#include "llvm/Transforms/Utils/ValueMapper.h"
|
2017-10-18 05:27:42 +08:00
|
|
|
#include <algorithm>
|
|
|
|
#include <cassert>
|
|
|
|
#include <climits>
|
|
|
|
#include <cstdint>
|
|
|
|
#include <iterator>
|
|
|
|
#include <map>
|
|
|
|
#include <utility>
|
|
|
|
|
2003-12-19 13:56:28 +08:00
|
|
|
using namespace llvm;
|
2016-06-25 16:34:38 +08:00
|
|
|
using namespace llvm::PatternMatch;
|
2003-11-12 06:41:34 +08:00
|
|
|
|
2014-04-22 06:55:11 +08:00
|
|
|
#define DEBUG_TYPE "local"
|
|
|
|
|
2013-08-13 06:38:43 +08:00
|
|
|
STATISTIC(NumRemoved, "Number of unreachable basic blocks removed");
|
|
|
|
|
2002-05-08 02:07:59 +08:00
|
|
|
//===----------------------------------------------------------------------===//
|
2008-11-28 06:57:53 +08:00
|
|
|
// Local constant propagation.
|
2002-05-08 02:07:59 +08:00
|
|
|
//
|
|
|
|
|
2011-05-23 00:24:18 +08:00
|
|
|
/// ConstantFoldTerminator - If a terminator instruction is predicated on a
|
|
|
|
/// constant value, convert it into an unconditional branch to the constant
|
|
|
|
/// destination. This is a nontrivial operation because the successors of this
|
|
|
|
/// basic block must have their PHI nodes updated.
|
|
|
|
/// Also calls RecursivelyDeleteTriviallyDeadInstructions() on any branch/switch
|
|
|
|
/// conditions and indirectbr addresses this might make dead if
|
|
|
|
/// DeleteDeadConditions is true.
|
2012-08-29 23:32:21 +08:00
|
|
|
bool llvm::ConstantFoldTerminator(BasicBlock *BB, bool DeleteDeadConditions,
|
2018-01-13 05:06:48 +08:00
|
|
|
const TargetLibraryInfo *TLI,
|
2018-08-03 13:08:17 +08:00
|
|
|
DomTreeUpdater *DTU) {
|
2018-10-15 18:04:59 +08:00
|
|
|
Instruction *T = BB->getTerminator();
|
2011-05-19 01:26:46 +08:00
|
|
|
IRBuilder<> Builder(T);
|
2005-04-22 07:48:37 +08:00
|
|
|
|
2002-05-08 02:07:59 +08:00
|
|
|
// Branch - See if we are conditional jumping on constant
|
2018-01-01 00:51:50 +08:00
|
|
|
if (auto *BI = dyn_cast<BranchInst>(T)) {
|
2002-05-08 02:07:59 +08:00
|
|
|
if (BI->isUnconditional()) return false; // Can't optimize uncond branch
|
2009-01-31 02:21:13 +08:00
|
|
|
BasicBlock *Dest1 = BI->getSuccessor(0);
|
|
|
|
BasicBlock *Dest2 = BI->getSuccessor(1);
|
2002-05-08 02:07:59 +08:00
|
|
|
|
2018-01-01 00:51:50 +08:00
|
|
|
if (auto *Cond = dyn_cast<ConstantInt>(BI->getCondition())) {
|
2002-05-08 02:07:59 +08:00
|
|
|
// Are we branching on constant?
|
|
|
|
// YES. Change to unconditional branch...
|
2007-01-12 12:24:46 +08:00
|
|
|
BasicBlock *Destination = Cond->getZExtValue() ? Dest1 : Dest2;
|
|
|
|
BasicBlock *OldDest = Cond->getZExtValue() ? Dest2 : Dest1;
|
2002-05-08 02:07:59 +08:00
|
|
|
|
|
|
|
// Let the basic block know that we are letting go of it. Based on this,
|
|
|
|
// it will adjust it's PHI nodes.
|
2011-04-19 23:23:29 +08:00
|
|
|
OldDest->removePredecessor(BB);
|
2002-05-08 02:07:59 +08:00
|
|
|
|
2011-01-08 04:25:56 +08:00
|
|
|
// Replace the conditional branch with an unconditional one.
|
2011-05-19 01:26:46 +08:00
|
|
|
Builder.CreateBr(Destination);
|
2011-01-08 04:25:56 +08:00
|
|
|
BI->eraseFromParent();
|
2018-08-03 13:08:17 +08:00
|
|
|
if (DTU)
|
|
|
|
DTU->deleteEdgeRelaxed(BB, OldDest);
|
2002-05-08 02:07:59 +08:00
|
|
|
return true;
|
2009-11-01 11:40:38 +08:00
|
|
|
}
|
2013-07-23 07:16:36 +08:00
|
|
|
|
2009-11-01 11:40:38 +08:00
|
|
|
if (Dest2 == Dest1) { // Conditional branch to same location?
|
2005-04-22 07:48:37 +08:00
|
|
|
// This branch matches something like this:
|
2002-05-08 02:07:59 +08:00
|
|
|
// br bool %cond, label %Dest, label %Dest
|
|
|
|
// and changes it into: br label %Dest
|
|
|
|
|
|
|
|
// Let the basic block know that we are letting go of one copy of it.
|
|
|
|
assert(BI->getParent() && "Terminator not inserted in block!");
|
|
|
|
Dest1->removePredecessor(BI->getParent());
|
|
|
|
|
2011-01-08 04:25:56 +08:00
|
|
|
// Replace the conditional branch with an unconditional one.
|
2011-05-19 01:26:46 +08:00
|
|
|
Builder.CreateBr(Dest1);
|
2011-05-23 00:24:18 +08:00
|
|
|
Value *Cond = BI->getCondition();
|
2011-01-08 04:25:56 +08:00
|
|
|
BI->eraseFromParent();
|
2011-05-23 00:24:18 +08:00
|
|
|
if (DeleteDeadConditions)
|
2012-08-29 23:32:21 +08:00
|
|
|
RecursivelyDeleteTriviallyDeadInstructions(Cond, TLI);
|
2002-05-08 02:07:59 +08:00
|
|
|
return true;
|
|
|
|
}
|
2009-11-01 11:40:38 +08:00
|
|
|
return false;
|
|
|
|
}
|
2013-07-23 07:16:36 +08:00
|
|
|
|
2018-01-01 00:51:50 +08:00
|
|
|
if (auto *SI = dyn_cast<SwitchInst>(T)) {
|
2015-01-27 03:52:24 +08:00
|
|
|
// If we are switching on a constant, we can convert the switch to an
|
|
|
|
// unconditional branch.
|
2018-01-01 00:51:50 +08:00
|
|
|
auto *CI = dyn_cast<ConstantInt>(SI->getCondition());
|
2015-01-27 03:52:24 +08:00
|
|
|
BasicBlock *DefaultDest = SI->getDefaultDest();
|
|
|
|
BasicBlock *TheOnlyDest = DefaultDest;
|
|
|
|
|
|
|
|
// If the default is unreachable, ignore it when searching for TheOnlyDest.
|
|
|
|
if (isa<UnreachableInst>(DefaultDest->getFirstNonPHIOrDbg()) &&
|
|
|
|
SI->getNumCases() > 0) {
|
2017-04-12 15:27:28 +08:00
|
|
|
TheOnlyDest = SI->case_begin()->getCaseSuccessor();
|
2015-01-27 03:52:24 +08:00
|
|
|
}
|
2003-08-18 04:21:14 +08:00
|
|
|
|
2009-11-01 11:40:38 +08:00
|
|
|
// Figure out which case it goes to.
|
2017-03-26 10:49:23 +08:00
|
|
|
for (auto i = SI->case_begin(), e = SI->case_end(); i != e;) {
|
2003-08-18 04:21:14 +08:00
|
|
|
// Found case matching a constant operand?
|
2017-04-12 15:27:28 +08:00
|
|
|
if (i->getCaseValue() == CI) {
|
|
|
|
TheOnlyDest = i->getCaseSuccessor();
|
2003-08-18 04:21:14 +08:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
2003-08-24 07:18:19 +08:00
|
|
|
// Check to see if this branch is going to the same place as the default
|
|
|
|
// dest. If so, eliminate it as an explicit compare.
|
2017-04-12 15:27:28 +08:00
|
|
|
if (i->getCaseSuccessor() == DefaultDest) {
|
2014-11-12 05:30:22 +08:00
|
|
|
MDNode *MD = SI->getMetadata(LLVMContext::MD_prof);
|
2013-12-10 08:13:41 +08:00
|
|
|
unsigned NCases = SI->getNumCases();
|
|
|
|
// Fold the case metadata into the default if there will be any branches
|
|
|
|
// left, unless the metadata doesn't match the switch.
|
|
|
|
if (NCases > 1 && MD && MD->getNumOperands() == 2 + NCases) {
|
2012-09-13 01:04:11 +08:00
|
|
|
// Collect branch weights into a vector.
|
|
|
|
SmallVector<uint32_t, 8> Weights;
|
|
|
|
for (unsigned MD_i = 1, MD_e = MD->getNumOperands(); MD_i < MD_e;
|
|
|
|
++MD_i) {
|
2016-06-25 16:34:38 +08:00
|
|
|
auto *CI = mdconst::extract<ConstantInt>(MD->getOperand(MD_i));
|
2012-09-13 01:04:11 +08:00
|
|
|
Weights.push_back(CI->getValue().getZExtValue());
|
|
|
|
}
|
|
|
|
// Merge weight of this case to the default weight.
|
2017-04-12 15:27:28 +08:00
|
|
|
unsigned idx = i->getCaseIndex();
|
2012-09-13 01:04:11 +08:00
|
|
|
Weights[0] += Weights[idx+1];
|
|
|
|
// Remove weight for this case.
|
|
|
|
std::swap(Weights[idx+1], Weights.back());
|
|
|
|
Weights.pop_back();
|
|
|
|
SI->setMetadata(LLVMContext::MD_prof,
|
|
|
|
MDBuilder(BB->getContext()).
|
|
|
|
createBranchWeights(Weights));
|
|
|
|
}
|
2009-11-01 11:40:38 +08:00
|
|
|
// Remove this entry.
|
2018-01-13 05:06:48 +08:00
|
|
|
BasicBlock *ParentBB = SI->getParent();
|
|
|
|
DefaultDest->removePredecessor(ParentBB);
|
2017-03-26 10:49:23 +08:00
|
|
|
i = SI->removeCase(i);
|
|
|
|
e = SI->case_end();
|
2018-08-03 13:08:17 +08:00
|
|
|
if (DTU)
|
|
|
|
DTU->deleteEdgeRelaxed(ParentBB, DefaultDest);
|
2003-08-24 07:18:19 +08:00
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
2003-08-18 04:21:14 +08:00
|
|
|
// Otherwise, check to see if the switch only branches to one destination.
|
|
|
|
// We do this by reseting "TheOnlyDest" to null when we find two non-equal
|
|
|
|
// destinations.
|
2017-04-12 15:27:28 +08:00
|
|
|
if (i->getCaseSuccessor() != TheOnlyDest)
|
|
|
|
TheOnlyDest = nullptr;
|
2017-03-26 10:49:23 +08:00
|
|
|
|
|
|
|
// Increment this iterator as we haven't removed the case.
|
|
|
|
++i;
|
2003-08-18 04:21:14 +08:00
|
|
|
}
|
2003-08-18 03:41:53 +08:00
|
|
|
|
2003-08-18 04:21:14 +08:00
|
|
|
if (CI && !TheOnlyDest) {
|
|
|
|
// Branching on a constant, but not any of the cases, go to the default
|
|
|
|
// successor.
|
|
|
|
TheOnlyDest = SI->getDefaultDest();
|
2003-08-18 03:41:53 +08:00
|
|
|
}
|
|
|
|
|
2003-08-18 04:21:14 +08:00
|
|
|
// If we found a single destination that we can fold the switch into, do so
|
|
|
|
// now.
|
|
|
|
if (TheOnlyDest) {
|
2009-11-01 11:40:38 +08:00
|
|
|
// Insert the new branch.
|
2011-05-19 01:26:46 +08:00
|
|
|
Builder.CreateBr(TheOnlyDest);
|
2003-08-18 04:21:14 +08:00
|
|
|
BasicBlock *BB = SI->getParent();
|
2018-01-13 05:06:48 +08:00
|
|
|
std::vector <DominatorTree::UpdateType> Updates;
|
2018-08-03 13:08:17 +08:00
|
|
|
if (DTU)
|
2018-01-13 05:06:48 +08:00
|
|
|
Updates.reserve(SI->getNumSuccessors() - 1);
|
2003-08-18 04:21:14 +08:00
|
|
|
|
|
|
|
// Remove entries from PHI nodes which we no longer branch to...
|
2018-08-26 16:41:15 +08:00
|
|
|
for (BasicBlock *Succ : successors(SI)) {
|
2003-08-18 04:21:14 +08:00
|
|
|
// Found case matching a constant operand?
|
2018-01-13 05:06:48 +08:00
|
|
|
if (Succ == TheOnlyDest) {
|
2014-04-25 13:29:35 +08:00
|
|
|
TheOnlyDest = nullptr; // Don't modify the first branch to TheOnlyDest
|
2018-01-13 05:06:48 +08:00
|
|
|
} else {
|
2003-08-18 04:21:14 +08:00
|
|
|
Succ->removePredecessor(BB);
|
2018-08-03 13:08:17 +08:00
|
|
|
if (DTU)
|
2018-01-13 05:06:48 +08:00
|
|
|
Updates.push_back({DominatorTree::Delete, BB, Succ});
|
|
|
|
}
|
2003-08-18 04:21:14 +08:00
|
|
|
}
|
|
|
|
|
2009-11-01 11:40:38 +08:00
|
|
|
// Delete the old switch.
|
2011-05-23 00:24:18 +08:00
|
|
|
Value *Cond = SI->getCondition();
|
|
|
|
SI->eraseFromParent();
|
|
|
|
if (DeleteDeadConditions)
|
2012-08-29 23:32:21 +08:00
|
|
|
RecursivelyDeleteTriviallyDeadInstructions(Cond, TLI);
|
2018-08-03 13:08:17 +08:00
|
|
|
if (DTU)
|
|
|
|
DTU->applyUpdates(Updates, /*ForceRemoveDuplicates*/ true);
|
2003-08-18 04:21:14 +08:00
|
|
|
return true;
|
2009-11-01 11:40:38 +08:00
|
|
|
}
|
2013-07-23 07:16:36 +08:00
|
|
|
|
SwitchInst refactoring.
The purpose of refactoring is to hide operand roles from SwitchInst user (programmer). If you want to play with operands directly, probably you will need lower level methods than SwitchInst ones (TerminatorInst or may be User). After this patch we can reorganize SwitchInst operands and successors as we want.
What was done:
1. Changed semantics of index inside the getCaseValue method:
getCaseValue(0) means "get first case", not a condition. Use getCondition() if you want to resolve the condition. I propose don't mix SwitchInst case indexing with low level indexing (TI successors indexing, User's operands indexing), since it may be dangerous.
2. By the same reason findCaseValue(ConstantInt*) returns actual number of case value. 0 means first case, not default. If there is no case with given value, ErrorIndex will returned.
3. Added getCaseSuccessor method. I propose to avoid usage of TerminatorInst::getSuccessor if you want to resolve case successor BB. Use getCaseSuccessor instead, since internal SwitchInst organization of operands/successors is hidden and may be changed in any moment.
4. Added resolveSuccessorIndex and resolveCaseIndex. The main purpose of these methods is to see how case successors are really mapped in TerminatorInst.
4.1 "resolveSuccessorIndex" was created if you need to level down from SwitchInst to TerminatorInst. It returns TerminatorInst's successor index for given case successor.
4.2 "resolveCaseIndex" converts low level successors index to case index that curresponds to the given successor.
Note: There are also related compatability fix patches for dragonegg, klee, llvm-gcc-4.0, llvm-gcc-4.2, safecode, clang.
llvm-svn: 149481
2012-02-01 15:49:51 +08:00
|
|
|
if (SI->getNumCases() == 1) {
|
2003-08-18 04:21:14 +08:00
|
|
|
// Otherwise, we can fold this switch into a conditional branch
|
|
|
|
// instruction if it has only one non-default destination.
|
2017-04-12 15:27:28 +08:00
|
|
|
auto FirstCase = *SI->case_begin();
|
Revert patches to add case-range support for PR1255.
The work on this project was left in an unfinished and inconsistent state.
Hopefully someone will eventually get a chance to implement this feature, but
in the meantime, it is better to put things back the way the were. I have
left support in the bitcode reader to handle the case-range bitcode format,
so that we do not lose bitcode compatibility with the llvm 3.3 release.
This reverts the following commits: 155464, 156374, 156377, 156613, 156704,
156757, 156804 156808, 156985, 157046, 157112, 157183, 157315, 157384, 157575,
157576, 157586, 157612, 157810, 157814, 157815, 157880, 157881, 157882, 157884,
157887, 157901, 158979, 157987, 157989, 158986, 158997, 159076, 159101, 159100,
159200, 159201, 159207, 159527, 159532, 159540, 159583, 159618, 159658, 159659,
159660, 159661, 159703, 159704, 160076, 167356, 172025, 186736
llvm-svn: 190328
2013-09-10 03:14:35 +08:00
|
|
|
Value *Cond = Builder.CreateICmpEQ(SI->getCondition(),
|
|
|
|
FirstCase.getCaseValue(), "cond");
|
2012-05-23 16:18:26 +08:00
|
|
|
|
Revert patches to add case-range support for PR1255.
The work on this project was left in an unfinished and inconsistent state.
Hopefully someone will eventually get a chance to implement this feature, but
in the meantime, it is better to put things back the way the were. I have
left support in the bitcode reader to handle the case-range bitcode format,
so that we do not lose bitcode compatibility with the llvm 3.3 release.
This reverts the following commits: 155464, 156374, 156377, 156613, 156704,
156757, 156804 156808, 156985, 157046, 157112, 157183, 157315, 157384, 157575,
157576, 157586, 157612, 157810, 157814, 157815, 157880, 157881, 157882, 157884,
157887, 157901, 158979, 157987, 157989, 158986, 158997, 159076, 159101, 159100,
159200, 159201, 159207, 159527, 159532, 159540, 159583, 159618, 159658, 159659,
159660, 159661, 159703, 159704, 160076, 167356, 172025, 186736
llvm-svn: 190328
2013-09-10 03:14:35 +08:00
|
|
|
// Insert the new branch.
|
|
|
|
BranchInst *NewBr = Builder.CreateCondBr(Cond,
|
|
|
|
FirstCase.getCaseSuccessor(),
|
|
|
|
SI->getDefaultDest());
|
2014-11-12 05:30:22 +08:00
|
|
|
MDNode *MD = SI->getMetadata(LLVMContext::MD_prof);
|
Revert patches to add case-range support for PR1255.
The work on this project was left in an unfinished and inconsistent state.
Hopefully someone will eventually get a chance to implement this feature, but
in the meantime, it is better to put things back the way the were. I have
left support in the bitcode reader to handle the case-range bitcode format,
so that we do not lose bitcode compatibility with the llvm 3.3 release.
This reverts the following commits: 155464, 156374, 156377, 156613, 156704,
156757, 156804 156808, 156985, 157046, 157112, 157183, 157315, 157384, 157575,
157576, 157586, 157612, 157810, 157814, 157815, 157880, 157881, 157882, 157884,
157887, 157901, 158979, 157987, 157989, 158986, 158997, 159076, 159101, 159100,
159200, 159201, 159207, 159527, 159532, 159540, 159583, 159618, 159658, 159659,
159660, 159661, 159703, 159704, 160076, 167356, 172025, 186736
llvm-svn: 190328
2013-09-10 03:14:35 +08:00
|
|
|
if (MD && MD->getNumOperands() == 3) {
|
IR: Split Metadata from Value
Split `Metadata` away from the `Value` class hierarchy, as part of
PR21532. Assembly and bitcode changes are in the wings, but this is the
bulk of the change for the IR C++ API.
I have a follow-up patch prepared for `clang`. If this breaks other
sub-projects, I apologize in advance :(. Help me compile it on Darwin
I'll try to fix it. FWIW, the errors should be easy to fix, so it may
be simpler to just fix it yourself.
This breaks the build for all metadata-related code that's out-of-tree.
Rest assured the transition is mechanical and the compiler should catch
almost all of the problems.
Here's a quick guide for updating your code:
- `Metadata` is the root of a class hierarchy with three main classes:
`MDNode`, `MDString`, and `ValueAsMetadata`. It is distinct from
the `Value` class hierarchy. It is typeless -- i.e., instances do
*not* have a `Type`.
- `MDNode`'s operands are all `Metadata *` (instead of `Value *`).
- `TrackingVH<MDNode>` and `WeakVH` referring to metadata can be
replaced with `TrackingMDNodeRef` and `TrackingMDRef`, respectively.
If you're referring solely to resolved `MDNode`s -- post graph
construction -- just use `MDNode*`.
- `MDNode` (and the rest of `Metadata`) have only limited support for
`replaceAllUsesWith()`.
As long as an `MDNode` is pointing at a forward declaration -- the
result of `MDNode::getTemporary()` -- it maintains a side map of its
uses and can RAUW itself. Once the forward declarations are fully
resolved RAUW support is dropped on the ground. This means that
uniquing collisions on changing operands cause nodes to become
"distinct". (This already happened fairly commonly, whenever an
operand went to null.)
If you're constructing complex (non self-reference) `MDNode` cycles,
you need to call `MDNode::resolveCycles()` on each node (or on a
top-level node that somehow references all of the nodes). Also,
don't do that. Metadata cycles (and the RAUW machinery needed to
construct them) are expensive.
- An `MDNode` can only refer to a `Constant` through a bridge called
`ConstantAsMetadata` (one of the subclasses of `ValueAsMetadata`).
As a side effect, accessing an operand of an `MDNode` that is known
to be, e.g., `ConstantInt`, takes three steps: first, cast from
`Metadata` to `ConstantAsMetadata`; second, extract the `Constant`;
third, cast down to `ConstantInt`.
The eventual goal is to introduce `MDInt`/`MDFloat`/etc. and have
metadata schema owners transition away from using `Constant`s when
the type isn't important (and they don't care about referring to
`GlobalValue`s).
In the meantime, I've added transitional API to the `mdconst`
namespace that matches semantics with the old code, in order to
avoid adding the error-prone three-step equivalent to every call
site. If your old code was:
MDNode *N = foo();
bar(isa <ConstantInt>(N->getOperand(0)));
baz(cast <ConstantInt>(N->getOperand(1)));
bak(cast_or_null <ConstantInt>(N->getOperand(2)));
bat(dyn_cast <ConstantInt>(N->getOperand(3)));
bay(dyn_cast_or_null<ConstantInt>(N->getOperand(4)));
you can trivially match its semantics with:
MDNode *N = foo();
bar(mdconst::hasa <ConstantInt>(N->getOperand(0)));
baz(mdconst::extract <ConstantInt>(N->getOperand(1)));
bak(mdconst::extract_or_null <ConstantInt>(N->getOperand(2)));
bat(mdconst::dyn_extract <ConstantInt>(N->getOperand(3)));
bay(mdconst::dyn_extract_or_null<ConstantInt>(N->getOperand(4)));
and when you transition your metadata schema to `MDInt`:
MDNode *N = foo();
bar(isa <MDInt>(N->getOperand(0)));
baz(cast <MDInt>(N->getOperand(1)));
bak(cast_or_null <MDInt>(N->getOperand(2)));
bat(dyn_cast <MDInt>(N->getOperand(3)));
bay(dyn_cast_or_null<MDInt>(N->getOperand(4)));
- A `CallInst` -- specifically, intrinsic instructions -- can refer to
metadata through a bridge called `MetadataAsValue`. This is a
subclass of `Value` where `getType()->isMetadataTy()`.
`MetadataAsValue` is the *only* class that can legally refer to a
`LocalAsMetadata`, which is a bridged form of non-`Constant` values
like `Argument` and `Instruction`. It can also refer to any other
`Metadata` subclass.
(I'll break all your testcases in a follow-up commit, when I propagate
this change to assembly.)
llvm-svn: 223802
2014-12-10 02:38:53 +08:00
|
|
|
ConstantInt *SICase =
|
|
|
|
mdconst::dyn_extract<ConstantInt>(MD->getOperand(2));
|
|
|
|
ConstantInt *SIDef =
|
|
|
|
mdconst::dyn_extract<ConstantInt>(MD->getOperand(1));
|
Revert patches to add case-range support for PR1255.
The work on this project was left in an unfinished and inconsistent state.
Hopefully someone will eventually get a chance to implement this feature, but
in the meantime, it is better to put things back the way the were. I have
left support in the bitcode reader to handle the case-range bitcode format,
so that we do not lose bitcode compatibility with the llvm 3.3 release.
This reverts the following commits: 155464, 156374, 156377, 156613, 156704,
156757, 156804 156808, 156985, 157046, 157112, 157183, 157315, 157384, 157575,
157576, 157586, 157612, 157810, 157814, 157815, 157880, 157881, 157882, 157884,
157887, 157901, 158979, 157987, 157989, 158986, 158997, 159076, 159101, 159100,
159200, 159201, 159207, 159527, 159532, 159540, 159583, 159618, 159658, 159659,
159660, 159661, 159703, 159704, 160076, 167356, 172025, 186736
llvm-svn: 190328
2013-09-10 03:14:35 +08:00
|
|
|
assert(SICase && SIDef);
|
|
|
|
// The TrueWeight should be the weight for the single case of SI.
|
|
|
|
NewBr->setMetadata(LLVMContext::MD_prof,
|
|
|
|
MDBuilder(BB->getContext()).
|
|
|
|
createBranchWeights(SICase->getValue().getZExtValue(),
|
|
|
|
SIDef->getValue().getZExtValue()));
|
2012-05-23 16:18:26 +08:00
|
|
|
}
|
Revert patches to add case-range support for PR1255.
The work on this project was left in an unfinished and inconsistent state.
Hopefully someone will eventually get a chance to implement this feature, but
in the meantime, it is better to put things back the way the were. I have
left support in the bitcode reader to handle the case-range bitcode format,
so that we do not lose bitcode compatibility with the llvm 3.3 release.
This reverts the following commits: 155464, 156374, 156377, 156613, 156704,
156757, 156804 156808, 156985, 157046, 157112, 157183, 157315, 157384, 157575,
157576, 157586, 157612, 157810, 157814, 157815, 157880, 157881, 157882, 157884,
157887, 157901, 158979, 157987, 157989, 158986, 158997, 159076, 159101, 159100,
159200, 159201, 159207, 159527, 159532, 159540, 159583, 159618, 159658, 159659,
159660, 159661, 159703, 159704, 160076, 167356, 172025, 186736
llvm-svn: 190328
2013-09-10 03:14:35 +08:00
|
|
|
|
2015-08-08 03:30:12 +08:00
|
|
|
// Update make.implicit metadata to the newly-created conditional branch.
|
|
|
|
MDNode *MakeImplicitMD = SI->getMetadata(LLVMContext::MD_make_implicit);
|
|
|
|
if (MakeImplicitMD)
|
|
|
|
NewBr->setMetadata(LLVMContext::MD_make_implicit, MakeImplicitMD);
|
|
|
|
|
Revert patches to add case-range support for PR1255.
The work on this project was left in an unfinished and inconsistent state.
Hopefully someone will eventually get a chance to implement this feature, but
in the meantime, it is better to put things back the way the were. I have
left support in the bitcode reader to handle the case-range bitcode format,
so that we do not lose bitcode compatibility with the llvm 3.3 release.
This reverts the following commits: 155464, 156374, 156377, 156613, 156704,
156757, 156804 156808, 156985, 157046, 157112, 157183, 157315, 157384, 157575,
157576, 157586, 157612, 157810, 157814, 157815, 157880, 157881, 157882, 157884,
157887, 157901, 158979, 157987, 157989, 158986, 158997, 159076, 159101, 159100,
159200, 159201, 159207, 159527, 159532, 159540, 159583, 159618, 159658, 159659,
159660, 159661, 159703, 159704, 160076, 167356, 172025, 186736
llvm-svn: 190328
2013-09-10 03:14:35 +08:00
|
|
|
// Delete the old switch.
|
|
|
|
SI->eraseFromParent();
|
|
|
|
return true;
|
2003-08-18 04:21:14 +08:00
|
|
|
}
|
2009-11-01 11:40:38 +08:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2018-01-01 00:51:50 +08:00
|
|
|
if (auto *IBI = dyn_cast<IndirectBrInst>(T)) {
|
2009-11-01 11:40:38 +08:00
|
|
|
// indirectbr blockaddress(@F, @BB) -> br label @BB
|
2018-01-01 00:51:50 +08:00
|
|
|
if (auto *BA =
|
2009-11-01 11:40:38 +08:00
|
|
|
dyn_cast<BlockAddress>(IBI->getAddress()->stripPointerCasts())) {
|
|
|
|
BasicBlock *TheOnlyDest = BA->getBasicBlock();
|
2018-01-13 05:06:48 +08:00
|
|
|
std::vector <DominatorTree::UpdateType> Updates;
|
2018-08-03 13:08:17 +08:00
|
|
|
if (DTU)
|
2018-01-13 05:06:48 +08:00
|
|
|
Updates.reserve(IBI->getNumDestinations() - 1);
|
|
|
|
|
2009-11-01 11:40:38 +08:00
|
|
|
// Insert the new branch.
|
2011-05-19 01:26:46 +08:00
|
|
|
Builder.CreateBr(TheOnlyDest);
|
2013-07-23 07:16:36 +08:00
|
|
|
|
2009-11-01 11:40:38 +08:00
|
|
|
for (unsigned i = 0, e = IBI->getNumDestinations(); i != e; ++i) {
|
2018-01-13 05:06:48 +08:00
|
|
|
if (IBI->getDestination(i) == TheOnlyDest) {
|
2014-04-25 13:29:35 +08:00
|
|
|
TheOnlyDest = nullptr;
|
2018-01-13 05:06:48 +08:00
|
|
|
} else {
|
|
|
|
BasicBlock *ParentBB = IBI->getParent();
|
|
|
|
BasicBlock *DestBB = IBI->getDestination(i);
|
|
|
|
DestBB->removePredecessor(ParentBB);
|
2018-08-03 13:08:17 +08:00
|
|
|
if (DTU)
|
2018-01-13 05:06:48 +08:00
|
|
|
Updates.push_back({DominatorTree::Delete, ParentBB, DestBB});
|
|
|
|
}
|
2009-11-01 11:40:38 +08:00
|
|
|
}
|
2011-05-23 00:24:18 +08:00
|
|
|
Value *Address = IBI->getAddress();
|
2009-11-01 11:40:38 +08:00
|
|
|
IBI->eraseFromParent();
|
2011-05-23 00:24:18 +08:00
|
|
|
if (DeleteDeadConditions)
|
2012-08-29 23:32:21 +08:00
|
|
|
RecursivelyDeleteTriviallyDeadInstructions(Address, TLI);
|
2013-07-23 07:16:36 +08:00
|
|
|
|
2009-11-01 11:40:38 +08:00
|
|
|
// If we didn't find our destination in the IBI successor list, then we
|
|
|
|
// have undefined behavior. Replace the unconditional branch with an
|
|
|
|
// 'unreachable' instruction.
|
|
|
|
if (TheOnlyDest) {
|
|
|
|
BB->getTerminator()->eraseFromParent();
|
|
|
|
new UnreachableInst(BB->getContext(), BB);
|
|
|
|
}
|
2013-07-23 07:16:36 +08:00
|
|
|
|
2018-08-03 13:08:17 +08:00
|
|
|
if (DTU)
|
|
|
|
DTU->applyUpdates(Updates, /*ForceRemoveDuplicates*/ true);
|
2009-11-01 11:40:38 +08:00
|
|
|
return true;
|
|
|
|
}
|
2002-05-08 02:07:59 +08:00
|
|
|
}
|
2013-07-23 07:16:36 +08:00
|
|
|
|
2002-05-08 02:07:59 +08:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
//===----------------------------------------------------------------------===//
|
2009-11-11 06:26:15 +08:00
|
|
|
// Local dead code elimination.
|
2002-05-08 02:07:59 +08:00
|
|
|
//
|
|
|
|
|
2008-11-28 06:57:53 +08:00
|
|
|
/// isInstructionTriviallyDead - Return true if the result produced by the
|
|
|
|
/// instruction is not used, and the instruction has no side effects.
|
|
|
|
///
|
2012-08-29 23:32:21 +08:00
|
|
|
bool llvm::isInstructionTriviallyDead(Instruction *I,
|
|
|
|
const TargetLibraryInfo *TLI) {
|
2017-03-10 08:32:33 +08:00
|
|
|
if (!I->use_empty())
|
|
|
|
return false;
|
|
|
|
return wouldInstructionBeTriviallyDead(I, TLI);
|
|
|
|
}
|
|
|
|
|
|
|
|
bool llvm::wouldInstructionBeTriviallyDead(Instruction *I,
|
|
|
|
const TargetLibraryInfo *TLI) {
|
2018-08-26 17:51:22 +08:00
|
|
|
if (I->isTerminator())
|
2017-03-10 08:32:33 +08:00
|
|
|
return false;
|
2005-07-27 14:12:32 +08:00
|
|
|
|
2015-08-01 01:58:14 +08:00
|
|
|
// We don't want the landingpad-like instructions removed by anything this
|
|
|
|
// general.
|
|
|
|
if (I->isEHPad())
|
2011-08-16 04:10:51 +08:00
|
|
|
return false;
|
|
|
|
|
2011-03-19 07:28:02 +08:00
|
|
|
// We don't want debug info removed by anything this general, unless
|
|
|
|
// debug info is empty.
|
|
|
|
if (DbgDeclareInst *DDI = dyn_cast<DbgDeclareInst>(I)) {
|
2011-08-03 05:19:27 +08:00
|
|
|
if (DDI->getAddress())
|
2011-03-19 07:28:02 +08:00
|
|
|
return false;
|
2011-03-22 06:04:45 +08:00
|
|
|
return true;
|
2011-08-03 05:19:27 +08:00
|
|
|
}
|
2011-03-22 06:04:45 +08:00
|
|
|
if (DbgValueInst *DVI = dyn_cast<DbgValueInst>(I)) {
|
2011-03-19 07:28:02 +08:00
|
|
|
if (DVI->getValue())
|
|
|
|
return false;
|
2011-03-22 06:04:45 +08:00
|
|
|
return true;
|
2011-03-19 07:28:02 +08:00
|
|
|
}
|
[DebugInfo] Add DILabel metadata and intrinsic llvm.dbg.label.
In order to set breakpoints on labels and list source code around
labels, we need collect debug information for labels, i.e., label
name, the function label belong, line number in the file, and the
address label located. In order to keep these information in LLVM
IR and to allow backend to generate debug information correctly.
We create a new kind of metadata for labels, DILabel. The format
of DILabel is
!DILabel(scope: !1, name: "foo", file: !2, line: 3)
We hope to keep debug information as much as possible even the
code is optimized. So, we create a new kind of intrinsic for label
metadata to avoid the metadata is eliminated with basic block.
The intrinsic will keep existing if we keep it from optimized out.
The format of the intrinsic is
llvm.dbg.label(metadata !1)
It has only one argument, that is the DILabel metadata. The
intrinsic will follow the label immediately. Backend could get the
label metadata through the intrinsic's parameter.
We also create DIBuilder API for labels to be used by Frontend.
Frontend could use createLabel() to allocate DILabel objects, and use
insertLabel() to insert llvm.dbg.label intrinsic in LLVM IR.
Differential Revision: https://reviews.llvm.org/D45024
Patch by Hsiangkai Wang.
llvm-svn: 331841
2018-05-09 10:40:45 +08:00
|
|
|
if (DbgLabelInst *DLI = dyn_cast<DbgLabelInst>(I)) {
|
|
|
|
if (DLI->getLabel())
|
|
|
|
return false;
|
|
|
|
return true;
|
|
|
|
}
|
2011-03-19 07:28:02 +08:00
|
|
|
|
2017-03-10 08:32:33 +08:00
|
|
|
if (!I->mayHaveSideEffects())
|
|
|
|
return true;
|
2009-05-06 14:49:50 +08:00
|
|
|
|
|
|
|
// Special case intrinsics that "may have side effects" but can be deleted
|
|
|
|
// when dead.
|
2011-08-03 05:19:27 +08:00
|
|
|
if (IntrinsicInst *II = dyn_cast<IntrinsicInst>(I)) {
|
2018-05-19 07:52:57 +08:00
|
|
|
// Safe to delete llvm.stacksave and launder.invariant.group if dead.
|
|
|
|
if (II->getIntrinsicID() == Intrinsic::stacksave ||
|
|
|
|
II->getIntrinsicID() == Intrinsic::launder_invariant_group)
|
2007-12-29 08:59:12 +08:00
|
|
|
return true;
|
2011-08-03 05:19:27 +08:00
|
|
|
|
|
|
|
// Lifetime intrinsics are dead when their right-hand is undef.
|
|
|
|
if (II->getIntrinsicID() == Intrinsic::lifetime_start ||
|
|
|
|
II->getIntrinsicID() == Intrinsic::lifetime_end)
|
|
|
|
return isa<UndefValue>(II->getArgOperand(1));
|
2014-07-26 05:13:35 +08:00
|
|
|
|
2016-04-30 06:23:16 +08:00
|
|
|
// Assumptions are dead if their condition is trivially true. Guards on
|
|
|
|
// true are operationally no-ops. In the future we can consider more
|
|
|
|
// sophisticated tradeoffs for guards considering potential for check
|
|
|
|
// widening, but for now we keep things simple.
|
|
|
|
if (II->getIntrinsicID() == Intrinsic::assume ||
|
|
|
|
II->getIntrinsicID() == Intrinsic::experimental_guard) {
|
2014-07-26 05:13:35 +08:00
|
|
|
if (ConstantInt *Cond = dyn_cast<ConstantInt>(II->getArgOperand(0)))
|
|
|
|
return !Cond->isZero();
|
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|
2011-08-03 05:19:27 +08:00
|
|
|
}
|
2011-10-24 12:35:36 +08:00
|
|
|
|
2017-03-10 08:32:33 +08:00
|
|
|
if (isAllocLikeFn(I, TLI))
|
|
|
|
return true;
|
2011-10-24 12:35:36 +08:00
|
|
|
|
2012-08-29 23:32:21 +08:00
|
|
|
if (CallInst *CI = isFreeCall(I, TLI))
|
2011-10-24 12:35:36 +08:00
|
|
|
if (Constant *C = dyn_cast<Constant>(CI->getArgOperand(0)))
|
|
|
|
return C->isNullValue() || isa<UndefValue>(C);
|
|
|
|
|
2016-11-03 04:48:11 +08:00
|
|
|
if (CallSite CS = CallSite(I))
|
|
|
|
if (isMathLibCallNoop(CS, TLI))
|
|
|
|
return true;
|
|
|
|
|
2005-05-06 13:27:34 +08:00
|
|
|
return false;
|
2002-05-08 02:07:59 +08:00
|
|
|
}
|
|
|
|
|
2008-11-28 06:57:53 +08:00
|
|
|
/// RecursivelyDeleteTriviallyDeadInstructions - If the specified value is a
|
|
|
|
/// trivially dead instruction, delete it. If that makes any of its operands
|
2010-01-05 23:45:31 +08:00
|
|
|
/// trivially dead, delete them too, recursively. Return true if any
|
|
|
|
/// instructions were deleted.
|
2018-08-17 05:58:44 +08:00
|
|
|
bool llvm::RecursivelyDeleteTriviallyDeadInstructions(
|
|
|
|
Value *V, const TargetLibraryInfo *TLI, MemorySSAUpdater *MSSAU) {
|
2008-11-28 06:57:53 +08:00
|
|
|
Instruction *I = dyn_cast<Instruction>(V);
|
2012-08-29 23:32:21 +08:00
|
|
|
if (!I || !I->use_empty() || !isInstructionTriviallyDead(I, TLI))
|
2010-01-05 23:45:31 +08:00
|
|
|
return false;
|
2013-07-23 07:16:36 +08:00
|
|
|
|
2008-11-28 09:20:46 +08:00
|
|
|
SmallVector<Instruction*, 16> DeadInsts;
|
|
|
|
DeadInsts.push_back(I);
|
2018-08-17 05:58:44 +08:00
|
|
|
RecursivelyDeleteTriviallyDeadInstructions(DeadInsts, TLI, MSSAU);
|
2013-07-23 07:16:36 +08:00
|
|
|
|
[LoopInstSimplify] Re-implement the core logic of loop-instsimplify to
be both simpler and substantially more efficient.
Rather than use a hand-rolled iteration technique that isn't quite the
same as RPO, use the pre-built RPO loop body traversal utility.
Once visiting the loop body in RPO, we can assert that we visit defs
before uses reliably. When this is the case, the only need to iterate is
when simplifying a def that is used by a PHI node along a back-edge.
With this patch, the first pass over the loop body is just a complete
simplification of every instruction across the loop body. When we
encounter a use of a simplified instruction that stems from a PHI node
in the loop body that has already been visited (due to some cyclic CFG,
potentially the loop itself, or a nested loop, or unstructured control
flow), we recall that specific PHI node for the second iteration.
Nothing else needs to be preserved from iteration to iteration.
On the second and later iterations, only instructions known to have
simplified inputs are considered, each time starting from a set of PHIs
that had simplified inputs along the backedges.
Dead instructions are collected along the way, but deleted in a batch at
the end of each iteration making the iterations themselves substantially
simpler. This uses a new batch API for recursively deleting dead
instructions.
This alsa changes the routine to visit subloops. Because simplification
is fundamentally transitive, we may need to visit the entire loop body,
including subloops, to handle knock-on simplification.
I've added a basic test file that helps demonstrate that all of these
changes work. It includes both straight-forward loops with
simplifications as well as interesting PHI-structures, CFG-structures,
and a nested loop case.
Differential Revision: https://reviews.llvm.org/D47407
llvm-svn: 333461
2018-05-30 04:15:38 +08:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
void llvm::RecursivelyDeleteTriviallyDeadInstructions(
|
2018-08-17 05:58:44 +08:00
|
|
|
SmallVectorImpl<Instruction *> &DeadInsts, const TargetLibraryInfo *TLI,
|
|
|
|
MemorySSAUpdater *MSSAU) {
|
[LoopInstSimplify] Re-implement the core logic of loop-instsimplify to
be both simpler and substantially more efficient.
Rather than use a hand-rolled iteration technique that isn't quite the
same as RPO, use the pre-built RPO loop body traversal utility.
Once visiting the loop body in RPO, we can assert that we visit defs
before uses reliably. When this is the case, the only need to iterate is
when simplifying a def that is used by a PHI node along a back-edge.
With this patch, the first pass over the loop body is just a complete
simplification of every instruction across the loop body. When we
encounter a use of a simplified instruction that stems from a PHI node
in the loop body that has already been visited (due to some cyclic CFG,
potentially the loop itself, or a nested loop, or unstructured control
flow), we recall that specific PHI node for the second iteration.
Nothing else needs to be preserved from iteration to iteration.
On the second and later iterations, only instructions known to have
simplified inputs are considered, each time starting from a set of PHIs
that had simplified inputs along the backedges.
Dead instructions are collected along the way, but deleted in a batch at
the end of each iteration making the iterations themselves substantially
simpler. This uses a new batch API for recursively deleting dead
instructions.
This alsa changes the routine to visit subloops. Because simplification
is fundamentally transitive, we may need to visit the entire loop body,
including subloops, to handle knock-on simplification.
I've added a basic test file that helps demonstrate that all of these
changes work. It includes both straight-forward loops with
simplifications as well as interesting PHI-structures, CFG-structures,
and a nested loop case.
Differential Revision: https://reviews.llvm.org/D47407
llvm-svn: 333461
2018-05-30 04:15:38 +08:00
|
|
|
// Process the dead instruction list until empty.
|
|
|
|
while (!DeadInsts.empty()) {
|
|
|
|
Instruction &I = *DeadInsts.pop_back_val();
|
|
|
|
assert(I.use_empty() && "Instructions with uses are not dead.");
|
|
|
|
assert(isInstructionTriviallyDead(&I, TLI) &&
|
|
|
|
"Live instruction found in dead worklist!");
|
|
|
|
|
|
|
|
// Don't lose the debug info while deleting the instructions.
|
|
|
|
salvageDebugInfo(I);
|
2008-11-28 08:58:15 +08:00
|
|
|
|
2008-11-28 09:20:46 +08:00
|
|
|
// Null out all of the instruction's operands to see if any operand becomes
|
|
|
|
// dead as we go.
|
[LoopInstSimplify] Re-implement the core logic of loop-instsimplify to
be both simpler and substantially more efficient.
Rather than use a hand-rolled iteration technique that isn't quite the
same as RPO, use the pre-built RPO loop body traversal utility.
Once visiting the loop body in RPO, we can assert that we visit defs
before uses reliably. When this is the case, the only need to iterate is
when simplifying a def that is used by a PHI node along a back-edge.
With this patch, the first pass over the loop body is just a complete
simplification of every instruction across the loop body. When we
encounter a use of a simplified instruction that stems from a PHI node
in the loop body that has already been visited (due to some cyclic CFG,
potentially the loop itself, or a nested loop, or unstructured control
flow), we recall that specific PHI node for the second iteration.
Nothing else needs to be preserved from iteration to iteration.
On the second and later iterations, only instructions known to have
simplified inputs are considered, each time starting from a set of PHIs
that had simplified inputs along the backedges.
Dead instructions are collected along the way, but deleted in a batch at
the end of each iteration making the iterations themselves substantially
simpler. This uses a new batch API for recursively deleting dead
instructions.
This alsa changes the routine to visit subloops. Because simplification
is fundamentally transitive, we may need to visit the entire loop body,
including subloops, to handle knock-on simplification.
I've added a basic test file that helps demonstrate that all of these
changes work. It includes both straight-forward loops with
simplifications as well as interesting PHI-structures, CFG-structures,
and a nested loop case.
Differential Revision: https://reviews.llvm.org/D47407
llvm-svn: 333461
2018-05-30 04:15:38 +08:00
|
|
|
for (Use &OpU : I.operands()) {
|
|
|
|
Value *OpV = OpU.get();
|
|
|
|
OpU.set(nullptr);
|
2013-07-23 07:16:36 +08:00
|
|
|
|
[LoopInstSimplify] Re-implement the core logic of loop-instsimplify to
be both simpler and substantially more efficient.
Rather than use a hand-rolled iteration technique that isn't quite the
same as RPO, use the pre-built RPO loop body traversal utility.
Once visiting the loop body in RPO, we can assert that we visit defs
before uses reliably. When this is the case, the only need to iterate is
when simplifying a def that is used by a PHI node along a back-edge.
With this patch, the first pass over the loop body is just a complete
simplification of every instruction across the loop body. When we
encounter a use of a simplified instruction that stems from a PHI node
in the loop body that has already been visited (due to some cyclic CFG,
potentially the loop itself, or a nested loop, or unstructured control
flow), we recall that specific PHI node for the second iteration.
Nothing else needs to be preserved from iteration to iteration.
On the second and later iterations, only instructions known to have
simplified inputs are considered, each time starting from a set of PHIs
that had simplified inputs along the backedges.
Dead instructions are collected along the way, but deleted in a batch at
the end of each iteration making the iterations themselves substantially
simpler. This uses a new batch API for recursively deleting dead
instructions.
This alsa changes the routine to visit subloops. Because simplification
is fundamentally transitive, we may need to visit the entire loop body,
including subloops, to handle knock-on simplification.
I've added a basic test file that helps demonstrate that all of these
changes work. It includes both straight-forward loops with
simplifications as well as interesting PHI-structures, CFG-structures,
and a nested loop case.
Differential Revision: https://reviews.llvm.org/D47407
llvm-svn: 333461
2018-05-30 04:15:38 +08:00
|
|
|
if (!OpV->use_empty())
|
|
|
|
continue;
|
2013-07-23 07:16:36 +08:00
|
|
|
|
2008-11-28 09:20:46 +08:00
|
|
|
// If the operand is an instruction that became dead as we nulled out the
|
|
|
|
// operand, and if it is 'trivially' dead, delete it in a future loop
|
|
|
|
// iteration.
|
|
|
|
if (Instruction *OpI = dyn_cast<Instruction>(OpV))
|
2012-08-29 23:32:21 +08:00
|
|
|
if (isInstructionTriviallyDead(OpI, TLI))
|
2008-11-28 09:20:46 +08:00
|
|
|
DeadInsts.push_back(OpI);
|
|
|
|
}
|
2018-08-17 05:58:44 +08:00
|
|
|
if (MSSAU)
|
|
|
|
MSSAU->removeMemoryAccess(&I);
|
2013-07-23 07:16:36 +08:00
|
|
|
|
[LoopInstSimplify] Re-implement the core logic of loop-instsimplify to
be both simpler and substantially more efficient.
Rather than use a hand-rolled iteration technique that isn't quite the
same as RPO, use the pre-built RPO loop body traversal utility.
Once visiting the loop body in RPO, we can assert that we visit defs
before uses reliably. When this is the case, the only need to iterate is
when simplifying a def that is used by a PHI node along a back-edge.
With this patch, the first pass over the loop body is just a complete
simplification of every instruction across the loop body. When we
encounter a use of a simplified instruction that stems from a PHI node
in the loop body that has already been visited (due to some cyclic CFG,
potentially the loop itself, or a nested loop, or unstructured control
flow), we recall that specific PHI node for the second iteration.
Nothing else needs to be preserved from iteration to iteration.
On the second and later iterations, only instructions known to have
simplified inputs are considered, each time starting from a set of PHIs
that had simplified inputs along the backedges.
Dead instructions are collected along the way, but deleted in a batch at
the end of each iteration making the iterations themselves substantially
simpler. This uses a new batch API for recursively deleting dead
instructions.
This alsa changes the routine to visit subloops. Because simplification
is fundamentally transitive, we may need to visit the entire loop body,
including subloops, to handle knock-on simplification.
I've added a basic test file that helps demonstrate that all of these
changes work. It includes both straight-forward loops with
simplifications as well as interesting PHI-structures, CFG-structures,
and a nested loop case.
Differential Revision: https://reviews.llvm.org/D47407
llvm-svn: 333461
2018-05-30 04:15:38 +08:00
|
|
|
I.eraseFromParent();
|
|
|
|
}
|
2002-05-08 02:07:59 +08:00
|
|
|
}
|
2008-11-27 15:43:12 +08:00
|
|
|
|
2011-02-20 16:38:20 +08:00
|
|
|
/// areAllUsesEqual - Check whether the uses of a value are all the same.
|
|
|
|
/// This is similar to Instruction::hasOneUse() except this will also return
|
2011-02-22 00:27:36 +08:00
|
|
|
/// true when there are no uses or multiple uses that all refer to the same
|
|
|
|
/// value.
|
2011-02-20 16:38:20 +08:00
|
|
|
static bool areAllUsesEqual(Instruction *I) {
|
2014-03-09 11:16:01 +08:00
|
|
|
Value::user_iterator UI = I->user_begin();
|
|
|
|
Value::user_iterator UE = I->user_end();
|
2011-02-20 16:38:20 +08:00
|
|
|
if (UI == UE)
|
2011-02-22 00:27:36 +08:00
|
|
|
return true;
|
2011-02-20 16:38:20 +08:00
|
|
|
|
|
|
|
User *TheUse = *UI;
|
|
|
|
for (++UI; UI != UE; ++UI) {
|
|
|
|
if (*UI != TheUse)
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2009-05-03 02:29:22 +08:00
|
|
|
/// RecursivelyDeleteDeadPHINode - If the specified value is an effectively
|
|
|
|
/// dead PHI node, due to being a def-use chain of single-use nodes that
|
|
|
|
/// either forms a cycle or is terminated by a trivially dead instruction,
|
|
|
|
/// delete it. If that makes any of its operands trivially dead, delete them
|
2011-02-22 01:32:05 +08:00
|
|
|
/// too, recursively. Return true if a change was made.
|
2012-08-29 23:32:21 +08:00
|
|
|
bool llvm::RecursivelyDeleteDeadPHINode(PHINode *PN,
|
|
|
|
const TargetLibraryInfo *TLI) {
|
2011-02-22 00:27:36 +08:00
|
|
|
SmallPtrSet<Instruction*, 4> Visited;
|
|
|
|
for (Instruction *I = PN; areAllUsesEqual(I) && !I->mayHaveSideEffects();
|
2014-03-09 11:16:01 +08:00
|
|
|
I = cast<Instruction>(*I->user_begin())) {
|
2011-02-22 00:27:36 +08:00
|
|
|
if (I->use_empty())
|
2012-08-29 23:32:21 +08:00
|
|
|
return RecursivelyDeleteTriviallyDeadInstructions(I, TLI);
|
2009-05-03 02:29:22 +08:00
|
|
|
|
2011-02-22 00:27:36 +08:00
|
|
|
// If we find an instruction more than once, we're on a cycle that
|
2009-05-03 02:29:22 +08:00
|
|
|
// won't prove fruitful.
|
2014-11-19 15:49:26 +08:00
|
|
|
if (!Visited.insert(I).second) {
|
2011-02-22 00:27:36 +08:00
|
|
|
// Break the cycle and delete the instruction and its operands.
|
|
|
|
I->replaceAllUsesWith(UndefValue::get(I->getType()));
|
2012-08-29 23:32:21 +08:00
|
|
|
(void)RecursivelyDeleteTriviallyDeadInstructions(I, TLI);
|
2011-02-22 01:32:05 +08:00
|
|
|
return true;
|
2011-02-22 00:27:36 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
return false;
|
2009-05-03 02:29:22 +08:00
|
|
|
}
|
2008-11-28 06:57:53 +08:00
|
|
|
|
2015-09-29 02:56:07 +08:00
|
|
|
static bool
|
|
|
|
simplifyAndDCEInstruction(Instruction *I,
|
|
|
|
SmallSetVector<Instruction *, 16> &WorkList,
|
|
|
|
const DataLayout &DL,
|
|
|
|
const TargetLibraryInfo *TLI) {
|
|
|
|
if (isInstructionTriviallyDead(I, TLI)) {
|
2018-03-03 06:46:48 +08:00
|
|
|
salvageDebugInfo(*I);
|
|
|
|
|
2015-09-29 02:56:07 +08:00
|
|
|
// Null out all of the instruction's operands to see if any operand becomes
|
|
|
|
// dead as we go.
|
|
|
|
for (unsigned i = 0, e = I->getNumOperands(); i != e; ++i) {
|
|
|
|
Value *OpV = I->getOperand(i);
|
|
|
|
I->setOperand(i, nullptr);
|
|
|
|
|
|
|
|
if (!OpV->use_empty() || I == OpV)
|
|
|
|
continue;
|
|
|
|
|
|
|
|
// If the operand is an instruction that became dead as we nulled out the
|
|
|
|
// operand, and if it is 'trivially' dead, delete it in a future loop
|
|
|
|
// iteration.
|
|
|
|
if (Instruction *OpI = dyn_cast<Instruction>(OpV))
|
|
|
|
if (isInstructionTriviallyDead(OpI, TLI))
|
|
|
|
WorkList.insert(OpI);
|
|
|
|
}
|
|
|
|
|
|
|
|
I->eraseFromParent();
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (Value *SimpleV = SimplifyInstruction(I, DL)) {
|
|
|
|
// Add the users to the worklist. CAREFUL: an instruction can use itself,
|
|
|
|
// in the case of a phi node.
|
2016-06-25 08:04:10 +08:00
|
|
|
for (User *U : I->users()) {
|
|
|
|
if (U != I) {
|
2015-09-29 02:56:07 +08:00
|
|
|
WorkList.insert(cast<Instruction>(U));
|
2016-06-25 08:04:10 +08:00
|
|
|
}
|
|
|
|
}
|
2015-09-29 02:56:07 +08:00
|
|
|
|
|
|
|
// Replace the instruction with its simplified value.
|
2016-06-25 08:04:10 +08:00
|
|
|
bool Changed = false;
|
|
|
|
if (!I->use_empty()) {
|
|
|
|
I->replaceAllUsesWith(SimpleV);
|
|
|
|
Changed = true;
|
|
|
|
}
|
|
|
|
if (isInstructionTriviallyDead(I, TLI)) {
|
|
|
|
I->eraseFromParent();
|
|
|
|
Changed = true;
|
|
|
|
}
|
|
|
|
return Changed;
|
2015-09-29 02:56:07 +08:00
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2010-01-13 03:40:54 +08:00
|
|
|
/// SimplifyInstructionsInBlock - Scan the specified basic block and try to
|
|
|
|
/// simplify any instructions in it and recursively delete dead instructions.
|
|
|
|
///
|
|
|
|
/// This returns true if it changed the code, note that it can delete
|
|
|
|
/// instructions in other blocks as well in this block.
|
2015-03-10 10:37:25 +08:00
|
|
|
bool llvm::SimplifyInstructionsInBlock(BasicBlock *BB,
|
2012-08-29 23:32:21 +08:00
|
|
|
const TargetLibraryInfo *TLI) {
|
2010-01-13 03:40:54 +08:00
|
|
|
bool MadeChange = false;
|
2015-09-29 02:56:07 +08:00
|
|
|
const DataLayout &DL = BB->getModule()->getDataLayout();
|
2012-03-25 11:29:25 +08:00
|
|
|
|
|
|
|
#ifndef NDEBUG
|
|
|
|
// In debug builds, ensure that the terminator of the block is never replaced
|
|
|
|
// or deleted by these simplifications. The idea of simplification is that it
|
|
|
|
// cannot introduce new instructions, and there is no way to replace the
|
|
|
|
// terminator of a block without introducing a new instruction.
|
2015-10-13 10:39:05 +08:00
|
|
|
AssertingVH<Instruction> TerminatorVH(&BB->back());
|
2012-03-25 11:29:25 +08:00
|
|
|
#endif
|
|
|
|
|
2015-09-29 02:56:07 +08:00
|
|
|
SmallSetVector<Instruction *, 16> WorkList;
|
|
|
|
// Iterate over the original function, only adding insts to the worklist
|
|
|
|
// if they actually need to be revisited. This avoids having to pre-init
|
|
|
|
// the worklist with the entire function's worth of instructions.
|
2016-05-22 05:12:06 +08:00
|
|
|
for (BasicBlock::iterator BI = BB->begin(), E = std::prev(BB->end());
|
|
|
|
BI != E;) {
|
2012-03-25 07:03:27 +08:00
|
|
|
assert(!BI->isTerminator());
|
2015-09-29 02:56:07 +08:00
|
|
|
Instruction *I = &*BI;
|
|
|
|
++BI;
|
|
|
|
|
|
|
|
// We're visiting this instruction now, so make sure it's not in the
|
|
|
|
// worklist from an earlier visit.
|
|
|
|
if (!WorkList.count(I))
|
|
|
|
MadeChange |= simplifyAndDCEInstruction(I, WorkList, DL, TLI);
|
|
|
|
}
|
2011-04-03 06:45:17 +08:00
|
|
|
|
2015-09-29 02:56:07 +08:00
|
|
|
while (!WorkList.empty()) {
|
|
|
|
Instruction *I = WorkList.pop_back_val();
|
|
|
|
MadeChange |= simplifyAndDCEInstruction(I, WorkList, DL, TLI);
|
2010-01-13 03:40:54 +08:00
|
|
|
}
|
|
|
|
return MadeChange;
|
|
|
|
}
|
|
|
|
|
2008-11-27 15:43:12 +08:00
|
|
|
//===----------------------------------------------------------------------===//
|
2009-11-11 06:26:15 +08:00
|
|
|
// Control Flow Graph Restructuring.
|
2008-11-27 15:43:12 +08:00
|
|
|
//
|
|
|
|
|
2009-11-11 06:26:15 +08:00
|
|
|
/// RemovePredecessorAndSimplify - Like BasicBlock::removePredecessor, this
|
|
|
|
/// method is called when we're about to delete Pred as a predecessor of BB. If
|
|
|
|
/// BB contains any PHI nodes, this drops the entries in the PHI nodes for Pred.
|
|
|
|
///
|
|
|
|
/// Unlike the removePredecessor method, this attempts to simplify uses of PHI
|
|
|
|
/// nodes that collapse into identity values. For example, if we have:
|
|
|
|
/// x = phi(1, 0, 0, 0)
|
|
|
|
/// y = and x, z
|
|
|
|
///
|
|
|
|
/// .. and delete the predecessor corresponding to the '1', this will attempt to
|
|
|
|
/// recursively fold the and to 0.
|
2018-01-13 05:06:48 +08:00
|
|
|
void llvm::RemovePredecessorAndSimplify(BasicBlock *BB, BasicBlock *Pred,
|
2018-08-03 13:08:17 +08:00
|
|
|
DomTreeUpdater *DTU) {
|
2009-11-11 06:26:15 +08:00
|
|
|
// This only adjusts blocks with PHI nodes.
|
|
|
|
if (!isa<PHINode>(BB->begin()))
|
|
|
|
return;
|
2013-07-23 07:16:36 +08:00
|
|
|
|
2009-11-11 06:26:15 +08:00
|
|
|
// Remove the entries for Pred from the PHI nodes in BB, but do not simplify
|
|
|
|
// them down. This will leave us with single entry phi nodes and other phis
|
|
|
|
// that can be removed.
|
|
|
|
BB->removePredecessor(Pred, true);
|
2013-07-23 07:16:36 +08:00
|
|
|
|
2017-05-02 01:07:49 +08:00
|
|
|
WeakTrackingVH PhiIt = &BB->front();
|
2009-11-11 06:26:15 +08:00
|
|
|
while (PHINode *PN = dyn_cast<PHINode>(PhiIt)) {
|
|
|
|
PhiIt = &*++BasicBlock::iterator(cast<Instruction>(PhiIt));
|
2012-03-25 05:11:24 +08:00
|
|
|
Value *OldPhiIt = PhiIt;
|
2010-11-17 12:12:05 +08:00
|
|
|
|
2015-03-10 10:37:25 +08:00
|
|
|
if (!recursivelySimplifyInstruction(PN))
|
2012-03-25 05:11:24 +08:00
|
|
|
continue;
|
2010-11-17 12:12:05 +08:00
|
|
|
|
2009-11-11 06:26:15 +08:00
|
|
|
// If recursive simplification ended up deleting the next PHI node we would
|
|
|
|
// iterate to, then our iterator is invalid, restart scanning from the top
|
|
|
|
// of the block.
|
2010-07-15 14:06:04 +08:00
|
|
|
if (PhiIt != OldPhiIt) PhiIt = &BB->front();
|
2009-11-11 06:26:15 +08:00
|
|
|
}
|
2018-08-03 13:08:17 +08:00
|
|
|
if (DTU)
|
|
|
|
DTU->deleteEdgeRelaxed(Pred, BB);
|
2009-11-11 06:26:15 +08:00
|
|
|
}
|
|
|
|
|
2008-11-27 15:43:12 +08:00
|
|
|
/// MergeBasicBlockIntoOnlyPred - DestBB is a block with one predecessor and its
|
2018-08-17 05:58:44 +08:00
|
|
|
/// predecessor is known to have one successor (DestBB!). Eliminate the edge
|
2008-11-27 15:43:12 +08:00
|
|
|
/// between them, moving the instructions in the predecessor into DestBB and
|
|
|
|
/// deleting the predecessor block.
|
2018-08-03 13:08:17 +08:00
|
|
|
void llvm::MergeBasicBlockIntoOnlyPred(BasicBlock *DestBB,
|
|
|
|
DomTreeUpdater *DTU) {
|
2018-01-13 05:06:48 +08:00
|
|
|
|
2008-11-27 15:43:12 +08:00
|
|
|
// If BB has single-entry PHI nodes, fold them.
|
|
|
|
while (PHINode *PN = dyn_cast<PHINode>(DestBB->begin())) {
|
|
|
|
Value *NewVal = PN->getIncomingValue(0);
|
|
|
|
// Replace self referencing PHI with undef, it must be dead.
|
2009-07-31 07:03:37 +08:00
|
|
|
if (NewVal == PN) NewVal = UndefValue::get(PN->getType());
|
2008-11-27 15:43:12 +08:00
|
|
|
PN->replaceAllUsesWith(NewVal);
|
|
|
|
PN->eraseFromParent();
|
|
|
|
}
|
2013-07-23 07:16:36 +08:00
|
|
|
|
2008-11-27 15:43:12 +08:00
|
|
|
BasicBlock *PredBB = DestBB->getSinglePredecessor();
|
|
|
|
assert(PredBB && "Block doesn't have a single predecessor!");
|
2013-07-23 07:16:36 +08:00
|
|
|
|
2018-01-13 05:06:48 +08:00
|
|
|
bool ReplaceEntryBB = false;
|
|
|
|
if (PredBB == &DestBB->getParent()->getEntryBlock())
|
|
|
|
ReplaceEntryBB = true;
|
|
|
|
|
2018-08-03 13:08:17 +08:00
|
|
|
// DTU updates: Collect all the edges that enter
|
|
|
|
// PredBB. These dominator edges will be redirected to DestBB.
|
2018-01-13 05:06:48 +08:00
|
|
|
std::vector <DominatorTree::UpdateType> Updates;
|
2018-08-03 13:08:17 +08:00
|
|
|
|
|
|
|
if (DTU) {
|
2018-05-11 07:01:54 +08:00
|
|
|
Updates.reserve(1 + (2 * pred_size(PredBB)));
|
2018-01-13 05:06:48 +08:00
|
|
|
Updates.push_back({DominatorTree::Delete, PredBB, DestBB});
|
|
|
|
for (auto I = pred_begin(PredBB), E = pred_end(PredBB); I != E; ++I) {
|
|
|
|
Updates.push_back({DominatorTree::Delete, *I, PredBB});
|
|
|
|
// This predecessor of PredBB may already have DestBB as a successor.
|
|
|
|
if (llvm::find(successors(*I), DestBB) == succ_end(*I))
|
|
|
|
Updates.push_back({DominatorTree::Insert, *I, DestBB});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2010-02-16 04:47:49 +08:00
|
|
|
// Zap anything that took the address of DestBB. Not doing this will give the
|
|
|
|
// address an invalid value.
|
|
|
|
if (DestBB->hasAddressTaken()) {
|
|
|
|
BlockAddress *BA = BlockAddress::get(DestBB);
|
|
|
|
Constant *Replacement =
|
2017-10-18 05:27:42 +08:00
|
|
|
ConstantInt::get(Type::getInt32Ty(BA->getContext()), 1);
|
2010-02-16 04:47:49 +08:00
|
|
|
BA->replaceAllUsesWith(ConstantExpr::getIntToPtr(Replacement,
|
|
|
|
BA->getType()));
|
|
|
|
BA->destroyConstant();
|
|
|
|
}
|
2013-07-23 07:16:36 +08:00
|
|
|
|
2008-11-27 15:43:12 +08:00
|
|
|
// Anything that branched to PredBB now branches to DestBB.
|
|
|
|
PredBB->replaceAllUsesWith(DestBB);
|
2013-07-23 07:16:36 +08:00
|
|
|
|
2011-06-23 17:09:15 +08:00
|
|
|
// Splice all the instructions from PredBB to DestBB.
|
|
|
|
PredBB->getTerminator()->eraseFromParent();
|
2013-10-21 12:09:17 +08:00
|
|
|
DestBB->getInstList().splice(DestBB->begin(), PredBB->getInstList());
|
2018-08-03 13:08:17 +08:00
|
|
|
new UnreachableInst(PredBB->getContext(), PredBB);
|
2011-06-23 17:09:15 +08:00
|
|
|
|
2014-07-12 15:12:47 +08:00
|
|
|
// If the PredBB is the entry block of the function, move DestBB up to
|
|
|
|
// become the entry block after we erase PredBB.
|
2018-01-13 05:06:48 +08:00
|
|
|
if (ReplaceEntryBB)
|
2014-07-12 15:12:47 +08:00
|
|
|
DestBB->moveAfter(PredBB);
|
|
|
|
|
2018-08-03 13:08:17 +08:00
|
|
|
if (DTU) {
|
|
|
|
assert(PredBB->getInstList().size() == 1 &&
|
|
|
|
isa<UnreachableInst>(PredBB->getTerminator()) &&
|
|
|
|
"The successor list of PredBB isn't empty before "
|
|
|
|
"applying corresponding DTU updates.");
|
|
|
|
DTU->applyUpdates(Updates, /*ForceRemoveDuplicates*/ true);
|
|
|
|
DTU->deleteBB(PredBB);
|
|
|
|
// Recalculation of DomTree is needed when updating a forward DomTree and
|
|
|
|
// the Entry BB is replaced.
|
|
|
|
if (ReplaceEntryBB && DTU->hasDomTree()) {
|
|
|
|
// The entry block was removed and there is no external interface for
|
|
|
|
// the dominator tree to be notified of this change. In this corner-case
|
|
|
|
// we recalculate the entire tree.
|
|
|
|
DTU->recalculate(*(DestBB->getParent()));
|
2017-10-26 23:04:53 +08:00
|
|
|
}
|
2009-09-16 17:26:52 +08:00
|
|
|
}
|
2018-01-13 05:06:48 +08:00
|
|
|
|
2018-08-03 13:08:17 +08:00
|
|
|
else {
|
|
|
|
PredBB->eraseFromParent(); // Nuke BB if DTU is nullptr.
|
2018-01-13 05:06:48 +08:00
|
|
|
}
|
2008-11-27 15:43:12 +08:00
|
|
|
}
|
2009-02-10 15:00:59 +08:00
|
|
|
|
2013-07-11 16:28:20 +08:00
|
|
|
/// CanMergeValues - Return true if we can choose one of these values to use
|
|
|
|
/// in place of the other. Note that we will always choose the non-undef
|
|
|
|
/// value to keep.
|
|
|
|
static bool CanMergeValues(Value *First, Value *Second) {
|
|
|
|
return First == Second || isa<UndefValue>(First) || isa<UndefValue>(Second);
|
|
|
|
}
|
|
|
|
|
2009-11-10 13:59:26 +08:00
|
|
|
/// CanPropagatePredecessorsForPHIs - Return true if we can fold BB, an
|
2013-08-15 06:11:42 +08:00
|
|
|
/// almost-empty BB ending in an unconditional branch to Succ, into Succ.
|
2009-11-10 13:59:26 +08:00
|
|
|
///
|
|
|
|
/// Assumption: Succ is the single successor for BB.
|
|
|
|
static bool CanPropagatePredecessorsForPHIs(BasicBlock *BB, BasicBlock *Succ) {
|
|
|
|
assert(*succ_begin(BB) == Succ && "Succ is not successor of BB!");
|
|
|
|
|
2018-05-14 20:53:11 +08:00
|
|
|
LLVM_DEBUG(dbgs() << "Looking to fold " << BB->getName() << " into "
|
|
|
|
<< Succ->getName() << "\n");
|
2009-11-10 13:59:26 +08:00
|
|
|
// Shortcut, if there is only a single predecessor it must be BB and merging
|
|
|
|
// is always safe
|
|
|
|
if (Succ->getSinglePredecessor()) return true;
|
|
|
|
|
|
|
|
// Make a list of the predecessors of BB
|
2011-12-07 00:14:29 +08:00
|
|
|
SmallPtrSet<BasicBlock*, 16> BBPreds(pred_begin(BB), pred_end(BB));
|
2009-11-10 13:59:26 +08:00
|
|
|
|
|
|
|
// Look at all the phi nodes in Succ, to see if they present a conflict when
|
|
|
|
// merging these blocks
|
|
|
|
for (BasicBlock::iterator I = Succ->begin(); isa<PHINode>(I); ++I) {
|
|
|
|
PHINode *PN = cast<PHINode>(I);
|
|
|
|
|
|
|
|
// If the incoming value from BB is again a PHINode in
|
|
|
|
// BB which has the same incoming value for *PI as PN does, we can
|
|
|
|
// merge the phi nodes and then the blocks can still be merged
|
|
|
|
PHINode *BBPN = dyn_cast<PHINode>(PN->getIncomingValueForBlock(BB));
|
|
|
|
if (BBPN && BBPN->getParent() == BB) {
|
2011-12-07 00:14:29 +08:00
|
|
|
for (unsigned PI = 0, PE = PN->getNumIncomingValues(); PI != PE; ++PI) {
|
|
|
|
BasicBlock *IBB = PN->getIncomingBlock(PI);
|
|
|
|
if (BBPreds.count(IBB) &&
|
2013-07-11 16:28:20 +08:00
|
|
|
!CanMergeValues(BBPN->getIncomingValueForBlock(IBB),
|
|
|
|
PN->getIncomingValue(PI))) {
|
2018-05-14 20:53:11 +08:00
|
|
|
LLVM_DEBUG(dbgs()
|
|
|
|
<< "Can't fold, phi node " << PN->getName() << " in "
|
|
|
|
<< Succ->getName() << " is conflicting with "
|
|
|
|
<< BBPN->getName() << " with regard to common predecessor "
|
|
|
|
<< IBB->getName() << "\n");
|
2009-11-10 13:59:26 +08:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
Value* Val = PN->getIncomingValueForBlock(BB);
|
2011-12-07 00:14:29 +08:00
|
|
|
for (unsigned PI = 0, PE = PN->getNumIncomingValues(); PI != PE; ++PI) {
|
2009-11-10 13:59:26 +08:00
|
|
|
// See if the incoming value for the common predecessor is equal to the
|
|
|
|
// one for BB, in which case this phi node will not prevent the merging
|
|
|
|
// of the block.
|
2011-12-07 00:14:29 +08:00
|
|
|
BasicBlock *IBB = PN->getIncomingBlock(PI);
|
2013-07-11 16:28:20 +08:00
|
|
|
if (BBPreds.count(IBB) &&
|
|
|
|
!CanMergeValues(Val, PN->getIncomingValue(PI))) {
|
2018-05-14 20:53:11 +08:00
|
|
|
LLVM_DEBUG(dbgs() << "Can't fold, phi node " << PN->getName()
|
|
|
|
<< " in " << Succ->getName()
|
|
|
|
<< " is conflicting with regard to common "
|
|
|
|
<< "predecessor " << IBB->getName() << "\n");
|
2009-11-10 13:59:26 +08:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2017-10-18 05:27:42 +08:00
|
|
|
using PredBlockVector = SmallVector<BasicBlock *, 16>;
|
|
|
|
using IncomingValueMap = DenseMap<BasicBlock *, Value *>;
|
2013-07-11 16:28:20 +08:00
|
|
|
|
2018-05-01 23:54:18 +08:00
|
|
|
/// Determines the value to use as the phi node input for a block.
|
2013-07-11 16:28:20 +08:00
|
|
|
///
|
|
|
|
/// Select between \p OldVal any value that we know flows from \p BB
|
|
|
|
/// to a particular phi on the basis of which one (if either) is not
|
|
|
|
/// undef. Update IncomingValues based on the selected value.
|
|
|
|
///
|
|
|
|
/// \param OldVal The value we are considering selecting.
|
|
|
|
/// \param BB The block that the value flows in from.
|
|
|
|
/// \param IncomingValues A map from block-to-value for other phi inputs
|
|
|
|
/// that we have examined.
|
|
|
|
///
|
|
|
|
/// \returns the selected value.
|
|
|
|
static Value *selectIncomingValueForBlock(Value *OldVal, BasicBlock *BB,
|
|
|
|
IncomingValueMap &IncomingValues) {
|
|
|
|
if (!isa<UndefValue>(OldVal)) {
|
|
|
|
assert((!IncomingValues.count(BB) ||
|
|
|
|
IncomingValues.find(BB)->second == OldVal) &&
|
|
|
|
"Expected OldVal to match incoming value from BB!");
|
|
|
|
|
|
|
|
IncomingValues.insert(std::make_pair(BB, OldVal));
|
|
|
|
return OldVal;
|
|
|
|
}
|
|
|
|
|
|
|
|
IncomingValueMap::const_iterator It = IncomingValues.find(BB);
|
|
|
|
if (It != IncomingValues.end()) return It->second;
|
|
|
|
|
|
|
|
return OldVal;
|
|
|
|
}
|
|
|
|
|
2018-05-01 23:54:18 +08:00
|
|
|
/// Create a map from block to value for the operands of a
|
2013-07-11 16:28:20 +08:00
|
|
|
/// given phi.
|
|
|
|
///
|
|
|
|
/// Create a map from block to value for each non-undef value flowing
|
|
|
|
/// into \p PN.
|
|
|
|
///
|
|
|
|
/// \param PN The phi we are collecting the map for.
|
|
|
|
/// \param IncomingValues [out] The map from block to value for this phi.
|
|
|
|
static void gatherIncomingValuesToPhi(PHINode *PN,
|
|
|
|
IncomingValueMap &IncomingValues) {
|
|
|
|
for (unsigned i = 0, e = PN->getNumIncomingValues(); i != e; ++i) {
|
|
|
|
BasicBlock *BB = PN->getIncomingBlock(i);
|
|
|
|
Value *V = PN->getIncomingValue(i);
|
|
|
|
|
|
|
|
if (!isa<UndefValue>(V))
|
|
|
|
IncomingValues.insert(std::make_pair(BB, V));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-05-01 23:54:18 +08:00
|
|
|
/// Replace the incoming undef values to a phi with the values
|
2013-07-11 16:28:20 +08:00
|
|
|
/// from a block-to-value map.
|
|
|
|
///
|
|
|
|
/// \param PN The phi we are replacing the undefs in.
|
|
|
|
/// \param IncomingValues A map from block to value.
|
|
|
|
static void replaceUndefValuesInPhi(PHINode *PN,
|
|
|
|
const IncomingValueMap &IncomingValues) {
|
|
|
|
for (unsigned i = 0, e = PN->getNumIncomingValues(); i != e; ++i) {
|
|
|
|
Value *V = PN->getIncomingValue(i);
|
|
|
|
|
|
|
|
if (!isa<UndefValue>(V)) continue;
|
|
|
|
|
|
|
|
BasicBlock *BB = PN->getIncomingBlock(i);
|
|
|
|
IncomingValueMap::const_iterator It = IncomingValues.find(BB);
|
|
|
|
if (It == IncomingValues.end()) continue;
|
|
|
|
|
|
|
|
PN->setIncomingValue(i, It->second);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-05-01 23:54:18 +08:00
|
|
|
/// Replace a value flowing from a block to a phi with
|
2013-07-11 16:28:20 +08:00
|
|
|
/// potentially multiple instances of that value flowing from the
|
|
|
|
/// block's predecessors to the phi.
|
|
|
|
///
|
|
|
|
/// \param BB The block with the value flowing into the phi.
|
|
|
|
/// \param BBPreds The predecessors of BB.
|
|
|
|
/// \param PN The phi that we are updating.
|
|
|
|
static void redirectValuesFromPredecessorsToPhi(BasicBlock *BB,
|
|
|
|
const PredBlockVector &BBPreds,
|
|
|
|
PHINode *PN) {
|
|
|
|
Value *OldVal = PN->removeIncomingValue(BB, false);
|
|
|
|
assert(OldVal && "No entry in PHI for Pred BB!");
|
|
|
|
|
|
|
|
IncomingValueMap IncomingValues;
|
|
|
|
|
|
|
|
// We are merging two blocks - BB, and the block containing PN - and
|
|
|
|
// as a result we need to redirect edges from the predecessors of BB
|
|
|
|
// to go to the block containing PN, and update PN
|
|
|
|
// accordingly. Since we allow merging blocks in the case where the
|
|
|
|
// predecessor and successor blocks both share some predecessors,
|
|
|
|
// and where some of those common predecessors might have undef
|
|
|
|
// values flowing into PN, we want to rewrite those values to be
|
|
|
|
// consistent with the non-undef values.
|
|
|
|
|
|
|
|
gatherIncomingValuesToPhi(PN, IncomingValues);
|
|
|
|
|
|
|
|
// If this incoming value is one of the PHI nodes in BB, the new entries
|
|
|
|
// in the PHI node are the entries from the old PHI.
|
|
|
|
if (isa<PHINode>(OldVal) && cast<PHINode>(OldVal)->getParent() == BB) {
|
|
|
|
PHINode *OldValPN = cast<PHINode>(OldVal);
|
|
|
|
for (unsigned i = 0, e = OldValPN->getNumIncomingValues(); i != e; ++i) {
|
|
|
|
// Note that, since we are merging phi nodes and BB and Succ might
|
|
|
|
// have common predecessors, we could end up with a phi node with
|
|
|
|
// identical incoming branches. This will be cleaned up later (and
|
|
|
|
// will trigger asserts if we try to clean it up now, without also
|
|
|
|
// simplifying the corresponding conditional branch).
|
|
|
|
BasicBlock *PredBB = OldValPN->getIncomingBlock(i);
|
|
|
|
Value *PredVal = OldValPN->getIncomingValue(i);
|
|
|
|
Value *Selected = selectIncomingValueForBlock(PredVal, PredBB,
|
|
|
|
IncomingValues);
|
|
|
|
|
|
|
|
// And add a new incoming value for this predecessor for the
|
|
|
|
// newly retargeted branch.
|
|
|
|
PN->addIncoming(Selected, PredBB);
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
for (unsigned i = 0, e = BBPreds.size(); i != e; ++i) {
|
|
|
|
// Update existing incoming values in PN for this
|
|
|
|
// predecessor of BB.
|
|
|
|
BasicBlock *PredBB = BBPreds[i];
|
|
|
|
Value *Selected = selectIncomingValueForBlock(OldVal, PredBB,
|
|
|
|
IncomingValues);
|
|
|
|
|
|
|
|
// And add a new incoming value for this predecessor for the
|
|
|
|
// newly retargeted branch.
|
|
|
|
PN->addIncoming(Selected, PredBB);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
replaceUndefValuesInPhi(PN, IncomingValues);
|
|
|
|
}
|
|
|
|
|
2009-11-10 13:59:26 +08:00
|
|
|
/// TryToSimplifyUncondBranchFromEmptyBlock - BB is known to contain an
|
|
|
|
/// unconditional branch, and contains no instructions other than PHI nodes,
|
2011-07-01 04:14:24 +08:00
|
|
|
/// potential side-effect free intrinsics and the branch. If possible,
|
|
|
|
/// eliminate BB by rewriting all the predecessors to branch to the successor
|
|
|
|
/// block and return true. If we can't transform, return false.
|
2018-01-13 05:06:48 +08:00
|
|
|
bool llvm::TryToSimplifyUncondBranchFromEmptyBlock(BasicBlock *BB,
|
2018-08-03 13:08:17 +08:00
|
|
|
DomTreeUpdater *DTU) {
|
2010-08-14 08:29:42 +08:00
|
|
|
assert(BB != &BB->getParent()->getEntryBlock() &&
|
|
|
|
"TryToSimplifyUncondBranchFromEmptyBlock called on entry block!");
|
|
|
|
|
2009-11-10 13:59:26 +08:00
|
|
|
// We can't eliminate infinite loops.
|
|
|
|
BasicBlock *Succ = cast<BranchInst>(BB->getTerminator())->getSuccessor(0);
|
|
|
|
if (BB == Succ) return false;
|
2013-07-23 07:16:36 +08:00
|
|
|
|
2016-05-03 03:43:22 +08:00
|
|
|
// Check to see if merging these blocks would cause conflicts for any of the
|
|
|
|
// phi nodes in BB or Succ. If not, we can safely merge.
|
|
|
|
if (!CanPropagatePredecessorsForPHIs(BB, Succ)) return false;
|
|
|
|
|
|
|
|
// Check for cases where Succ has multiple predecessors and a PHI node in BB
|
|
|
|
// has uses which will not disappear when the PHI nodes are merged. It is
|
|
|
|
// possible to handle such cases, but difficult: it requires checking whether
|
|
|
|
// BB dominates Succ, which is non-trivial to calculate in the case where
|
|
|
|
// Succ has multiple predecessors. Also, it requires checking whether
|
|
|
|
// constructing the necessary self-referential PHI node doesn't introduce any
|
|
|
|
// conflicts; this isn't too difficult, but the previous code for doing this
|
|
|
|
// was incorrect.
|
|
|
|
//
|
|
|
|
// Note that if this check finds a live use, BB dominates Succ, so BB is
|
|
|
|
// something like a loop pre-header (or rarely, a part of an irreducible CFG);
|
|
|
|
// folding the branch isn't profitable in that case anyway.
|
|
|
|
if (!Succ->getSinglePredecessor()) {
|
|
|
|
BasicBlock::iterator BBI = BB->begin();
|
|
|
|
while (isa<PHINode>(*BBI)) {
|
|
|
|
for (Use &U : BBI->uses()) {
|
|
|
|
if (PHINode* PN = dyn_cast<PHINode>(U.getUser())) {
|
|
|
|
if (PN->getIncomingBlock(U) != BB)
|
2009-11-10 13:59:26 +08:00
|
|
|
return false;
|
2016-05-03 03:43:22 +08:00
|
|
|
} else {
|
|
|
|
return false;
|
2009-11-10 13:59:26 +08:00
|
|
|
}
|
|
|
|
}
|
2016-05-03 03:43:22 +08:00
|
|
|
++BBI;
|
2009-11-10 13:59:26 +08:00
|
|
|
}
|
2016-05-03 03:43:22 +08:00
|
|
|
}
|
2009-11-10 13:59:26 +08:00
|
|
|
|
2018-05-14 20:53:11 +08:00
|
|
|
LLVM_DEBUG(dbgs() << "Killing Trivial BB: \n" << *BB);
|
2013-07-23 07:16:36 +08:00
|
|
|
|
2018-01-13 05:06:48 +08:00
|
|
|
std::vector<DominatorTree::UpdateType> Updates;
|
2018-08-03 13:08:17 +08:00
|
|
|
if (DTU) {
|
2018-05-11 07:01:54 +08:00
|
|
|
Updates.reserve(1 + (2 * pred_size(BB)));
|
2018-01-13 05:06:48 +08:00
|
|
|
Updates.push_back({DominatorTree::Delete, BB, Succ});
|
|
|
|
// All predecessors of BB will be moved to Succ.
|
|
|
|
for (auto I = pred_begin(BB), E = pred_end(BB); I != E; ++I) {
|
|
|
|
Updates.push_back({DominatorTree::Delete, *I, BB});
|
|
|
|
// This predecessor of BB may already have Succ as a successor.
|
|
|
|
if (llvm::find(successors(*I), Succ) == succ_end(*I))
|
|
|
|
Updates.push_back({DominatorTree::Insert, *I, Succ});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-05-03 03:43:22 +08:00
|
|
|
if (isa<PHINode>(Succ->begin())) {
|
|
|
|
// If there is more than one pred of succ, and there are PHI nodes in
|
|
|
|
// the successor, then we need to add incoming edges for the PHI nodes
|
|
|
|
//
|
|
|
|
const PredBlockVector BBPreds(pred_begin(BB), pred_end(BB));
|
2013-07-23 07:16:36 +08:00
|
|
|
|
2016-05-03 03:43:22 +08:00
|
|
|
// Loop over all of the PHI nodes in the successor of BB.
|
|
|
|
for (BasicBlock::iterator I = Succ->begin(); isa<PHINode>(I); ++I) {
|
|
|
|
PHINode *PN = cast<PHINode>(I);
|
2013-07-11 16:28:20 +08:00
|
|
|
|
2016-05-03 03:43:22 +08:00
|
|
|
redirectValuesFromPredecessorsToPhi(BB, BBPreds, PN);
|
2009-11-10 13:59:26 +08:00
|
|
|
}
|
2016-05-03 03:43:22 +08:00
|
|
|
}
|
2013-07-23 07:16:36 +08:00
|
|
|
|
2016-05-03 03:43:22 +08:00
|
|
|
if (Succ->getSinglePredecessor()) {
|
|
|
|
// BB is the only predecessor of Succ, so Succ will end up with exactly
|
|
|
|
// the same predecessors BB had.
|
2011-07-01 04:14:24 +08:00
|
|
|
|
2016-05-03 03:43:22 +08:00
|
|
|
// Copy over any phi, debug or lifetime instruction.
|
|
|
|
BB->getTerminator()->eraseFromParent();
|
|
|
|
Succ->getInstList().splice(Succ->getFirstNonPHI()->getIterator(),
|
|
|
|
BB->getInstList());
|
|
|
|
} else {
|
|
|
|
while (PHINode *PN = dyn_cast<PHINode>(&BB->front())) {
|
|
|
|
// We explicitly check for such uses in CanPropagatePredecessorsForPHIs.
|
|
|
|
assert(PN->use_empty() && "There shouldn't be any uses here!");
|
|
|
|
PN->eraseFromParent();
|
2009-11-10 13:59:26 +08:00
|
|
|
}
|
2016-05-03 01:22:54 +08:00
|
|
|
}
|
2016-05-03 03:43:22 +08:00
|
|
|
|
2016-11-18 21:12:07 +08:00
|
|
|
// If the unconditional branch we replaced contains llvm.loop metadata, we
|
|
|
|
// add the metadata to the branch instructions in the predecessors.
|
|
|
|
unsigned LoopMDKind = BB->getContext().getMDKindID("llvm.loop");
|
|
|
|
Instruction *TI = BB->getTerminator();
|
2017-09-30 19:57:19 +08:00
|
|
|
if (TI)
|
2016-11-18 21:12:07 +08:00
|
|
|
if (MDNode *LoopMD = TI->getMetadata(LoopMDKind))
|
|
|
|
for (pred_iterator PI = pred_begin(BB), E = pred_end(BB); PI != E; ++PI) {
|
|
|
|
BasicBlock *Pred = *PI;
|
|
|
|
Pred->getTerminator()->setMetadata(LoopMDKind, LoopMD);
|
|
|
|
}
|
|
|
|
|
2016-05-03 03:43:22 +08:00
|
|
|
// Everything that jumped to BB now goes to Succ.
|
|
|
|
BB->replaceAllUsesWith(Succ);
|
|
|
|
if (!Succ->hasName()) Succ->takeName(BB);
|
2018-01-13 05:06:48 +08:00
|
|
|
|
2018-08-03 13:08:17 +08:00
|
|
|
// Clear the successor list of BB to match updates applying to DTU later.
|
|
|
|
if (BB->getTerminator())
|
|
|
|
BB->getInstList().pop_back();
|
|
|
|
new UnreachableInst(BB->getContext(), BB);
|
|
|
|
assert(succ_empty(BB) && "The successor list of BB isn't empty before "
|
|
|
|
"applying corresponding DTU updates.");
|
|
|
|
|
|
|
|
if (DTU) {
|
|
|
|
DTU->applyUpdates(Updates, /*ForceRemoveDuplicates*/ true);
|
|
|
|
DTU->deleteBB(BB);
|
2018-01-13 05:06:48 +08:00
|
|
|
} else {
|
|
|
|
BB->eraseFromParent(); // Delete the old basic block.
|
|
|
|
}
|
2016-05-03 03:43:22 +08:00
|
|
|
return true;
|
2009-11-10 13:59:26 +08:00
|
|
|
}
|
|
|
|
|
2009-12-03 01:06:45 +08:00
|
|
|
/// EliminateDuplicatePHINodes - Check for and eliminate duplicate PHI
|
|
|
|
/// nodes in this block. This doesn't try to be clever about PHI nodes
|
|
|
|
/// which differ only in the order of the incoming values, but instcombine
|
|
|
|
/// orders them so it usually won't matter.
|
|
|
|
bool llvm::EliminateDuplicatePHINodes(BasicBlock *BB) {
|
|
|
|
// This implementation doesn't currently consider undef operands
|
2011-06-28 11:57:31 +08:00
|
|
|
// specially. Theoretically, two phis which are identical except for
|
2009-12-03 01:06:45 +08:00
|
|
|
// one having an undef where the other doesn't could be collapsed.
|
|
|
|
|
2015-06-19 00:01:00 +08:00
|
|
|
struct PHIDenseMapInfo {
|
|
|
|
static PHINode *getEmptyKey() {
|
|
|
|
return DenseMapInfo<PHINode *>::getEmptyKey();
|
|
|
|
}
|
2017-10-18 05:27:42 +08:00
|
|
|
|
2015-06-19 00:01:00 +08:00
|
|
|
static PHINode *getTombstoneKey() {
|
|
|
|
return DenseMapInfo<PHINode *>::getTombstoneKey();
|
|
|
|
}
|
2017-10-18 05:27:42 +08:00
|
|
|
|
2015-06-19 00:01:00 +08:00
|
|
|
static unsigned getHashValue(PHINode *PN) {
|
|
|
|
// Compute a hash value on the operands. Instcombine will likely have
|
|
|
|
// sorted them, which helps expose duplicates, but we have to check all
|
|
|
|
// the operands to be safe in case instcombine hasn't run.
|
|
|
|
return static_cast<unsigned>(hash_combine(
|
|
|
|
hash_combine_range(PN->value_op_begin(), PN->value_op_end()),
|
|
|
|
hash_combine_range(PN->block_begin(), PN->block_end())));
|
|
|
|
}
|
2017-10-18 05:27:42 +08:00
|
|
|
|
2015-06-19 00:01:00 +08:00
|
|
|
static bool isEqual(PHINode *LHS, PHINode *RHS) {
|
|
|
|
if (LHS == getEmptyKey() || LHS == getTombstoneKey() ||
|
|
|
|
RHS == getEmptyKey() || RHS == getTombstoneKey())
|
|
|
|
return LHS == RHS;
|
|
|
|
return LHS->isIdenticalTo(RHS);
|
|
|
|
}
|
|
|
|
};
|
2009-12-03 01:06:45 +08:00
|
|
|
|
2015-06-19 00:01:00 +08:00
|
|
|
// Set of unique PHINodes.
|
|
|
|
DenseSet<PHINode *, PHIDenseMapInfo> PHISet;
|
2009-12-03 01:06:45 +08:00
|
|
|
|
|
|
|
// Examine each PHI.
|
2015-06-19 00:01:00 +08:00
|
|
|
bool Changed = false;
|
|
|
|
for (auto I = BB->begin(); PHINode *PN = dyn_cast<PHINode>(I++);) {
|
|
|
|
auto Inserted = PHISet.insert(PN);
|
|
|
|
if (!Inserted.second) {
|
|
|
|
// A duplicate. Replace this PHI with its duplicate.
|
|
|
|
PN->replaceAllUsesWith(*Inserted.first);
|
|
|
|
PN->eraseFromParent();
|
|
|
|
Changed = true;
|
[RemoveDuplicatePHINodes] Start over after removing a PHI.
This makes RemoveDuplicatePHINodes more effective and fixes an assertion
failure. Triggering the assertions requires a DenseSet reallocation
so this change only contains a constructive test.
I'll explain the issue with a small example. In the following function
there's a duplicate PHI, %4 and %5 are identical. When this is found
the DenseSet in RemoveDuplicatePHINodes contains %2, %3 and %4.
define void @F() {
br label %1
; <label>:1 ; preds = %1, %0
%2 = phi i32 [ 42, %0 ], [ %4, %1 ]
%3 = phi i32 [ 42, %0 ], [ %5, %1 ]
%4 = phi i32 [ 42, %0 ], [ 23, %1 ]
%5 = phi i32 [ 42, %0 ], [ 23, %1 ]
br label %1
}
after RemoveDuplicatePHINodes runs the function looks like this. %3 has
changed and is now identical to %2, but RemoveDuplicatePHINodes never
saw this.
define void @F() {
br label %1
; <label>:1 ; preds = %1, %0
%2 = phi i32 [ 42, %0 ], [ %4, %1 ]
%3 = phi i32 [ 42, %0 ], [ %4, %1 ]
%4 = phi i32 [ 42, %0 ], [ 23, %1 ]
br label %1
}
If the DenseSet does a reallocation now it will reinsert all
keys and stumble over %3 now having a different hash value than it had
when inserted into the map for the first time. This change clears the
set whenever a PHI is deleted and starts the progress from the
beginning, allowing %3 to be deleted and avoiding inconsistent DenseSet
state. This potentially has a negative performance impact because
it rescans all PHIs, but I don't think that this ever makes a difference
in practice.
llvm-svn: 246694
2015-09-03 03:52:23 +08:00
|
|
|
|
|
|
|
// The RAUW can change PHIs that we already visited. Start over from the
|
|
|
|
// beginning.
|
|
|
|
PHISet.clear();
|
|
|
|
I = BB->begin();
|
2009-12-03 01:06:45 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return Changed;
|
|
|
|
}
|
2010-12-26 04:37:57 +08:00
|
|
|
|
|
|
|
/// enforceKnownAlignment - If the specified pointer points to an object that
|
|
|
|
/// we control, modify the object's alignment to PrefAlign. This isn't
|
|
|
|
/// often possible though. If alignment is important, a more reliable approach
|
|
|
|
/// is to simply align all global variables and allocation instructions to
|
|
|
|
/// their preferred alignment from the beginning.
|
2010-12-31 06:34:44 +08:00
|
|
|
static unsigned enforceKnownAlignment(Value *V, unsigned Align,
|
2015-03-10 10:37:25 +08:00
|
|
|
unsigned PrefAlign,
|
|
|
|
const DataLayout &DL) {
|
2016-01-16 00:33:06 +08:00
|
|
|
assert(PrefAlign > Align);
|
|
|
|
|
2011-06-16 05:08:25 +08:00
|
|
|
V = V->stripPointerCasts();
|
2010-12-26 04:37:57 +08:00
|
|
|
|
2011-06-16 05:08:25 +08:00
|
|
|
if (AllocaInst *AI = dyn_cast<AllocaInst>(V)) {
|
2016-01-16 00:33:06 +08:00
|
|
|
// TODO: ideally, computeKnownBits ought to have used
|
|
|
|
// AllocaInst::getAlignment() in its computation already, making
|
|
|
|
// the below max redundant. But, as it turns out,
|
|
|
|
// stripPointerCasts recurses through infinite layers of bitcasts,
|
|
|
|
// while computeKnownBits is not allowed to traverse more than 6
|
|
|
|
// levels.
|
|
|
|
Align = std::max(AI->getAlignment(), Align);
|
|
|
|
if (PrefAlign <= Align)
|
|
|
|
return Align;
|
|
|
|
|
2011-10-11 07:42:08 +08:00
|
|
|
// If the preferred alignment is greater than the natural stack alignment
|
|
|
|
// then don't round up. This avoids dynamic stack realignment.
|
2015-03-10 10:37:25 +08:00
|
|
|
if (DL.exceedsNaturalStackAlignment(PrefAlign))
|
2011-10-11 07:42:08 +08:00
|
|
|
return Align;
|
2010-12-26 04:37:57 +08:00
|
|
|
AI->setAlignment(PrefAlign);
|
|
|
|
return PrefAlign;
|
|
|
|
}
|
|
|
|
|
2014-05-14 02:45:48 +08:00
|
|
|
if (auto *GO = dyn_cast<GlobalObject>(V)) {
|
2016-01-16 00:33:06 +08:00
|
|
|
// TODO: as above, this shouldn't be necessary.
|
|
|
|
Align = std::max(GO->getAlignment(), Align);
|
|
|
|
if (PrefAlign <= Align)
|
|
|
|
return Align;
|
|
|
|
|
2010-12-26 04:37:57 +08:00
|
|
|
// If there is a large requested alignment and we can, bump up the alignment
|
2015-07-14 08:11:08 +08:00
|
|
|
// of the global. If the memory we set aside for the global may not be the
|
|
|
|
// memory used by the final program then it is impossible for us to reliably
|
|
|
|
// enforce the preferred alignment.
|
2016-01-16 00:33:06 +08:00
|
|
|
if (!GO->canIncreaseAlignment())
|
2014-05-10 00:01:06 +08:00
|
|
|
return Align;
|
2013-07-23 07:16:36 +08:00
|
|
|
|
2016-01-16 00:33:06 +08:00
|
|
|
GO->setAlignment(PrefAlign);
|
|
|
|
return PrefAlign;
|
2010-12-26 04:37:57 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
return Align;
|
|
|
|
}
|
|
|
|
|
|
|
|
unsigned llvm::getOrEnforceKnownAlignment(Value *V, unsigned PrefAlign,
|
2015-03-10 10:37:25 +08:00
|
|
|
const DataLayout &DL,
|
Make use of @llvm.assume in ValueTracking (computeKnownBits, etc.)
This change, which allows @llvm.assume to be used from within computeKnownBits
(and other associated functions in ValueTracking), adds some (optional)
parameters to computeKnownBits and friends. These functions now (optionally)
take a "context" instruction pointer, an AssumptionTracker pointer, and also a
DomTree pointer, and most of the changes are just to pass this new information
when it is easily available from InstSimplify, InstCombine, etc.
As explained below, the significant conceptual change is that known properties
of a value might depend on the control-flow location of the use (because we
care that the @llvm.assume dominates the use because assumptions have
control-flow dependencies). This means that, when we ask if bits are known in a
value, we might get different answers for different uses.
The significant changes are all in ValueTracking. Two main changes: First, as
with the rest of the code, new parameters need to be passed around. To make
this easier, I grouped them into a structure, and I made internal static
versions of the relevant functions that take this structure as a parameter. The
new code does as you might expect, it looks for @llvm.assume calls that make
use of the value we're trying to learn something about (often indirectly),
attempts to pattern match that expression, and uses the result if successful.
By making use of the AssumptionTracker, the process of finding @llvm.assume
calls is not expensive.
Part of the structure being passed around inside ValueTracking is a set of
already-considered @llvm.assume calls. This is to prevent a query using, for
example, the assume(a == b), to recurse on itself. The context and DT params
are used to find applicable assumptions. An assumption needs to dominate the
context instruction, or come after it deterministically. In this latter case we
only handle the specific case where both the assumption and the context
instruction are in the same block, and we need to exclude assumptions from
being used to simplify their own ephemeral values (those which contribute only
to the assumption) because otherwise the assumption would prove its feeding
comparison trivial and would be removed.
This commit adds the plumbing and the logic for a simple masked-bit propagation
(just enough to write a regression test). Future commits add more patterns
(and, correspondingly, more regression tests).
llvm-svn: 217342
2014-09-08 02:57:58 +08:00
|
|
|
const Instruction *CxtI,
|
2016-12-19 16:22:17 +08:00
|
|
|
AssumptionCache *AC,
|
Make use of @llvm.assume in ValueTracking (computeKnownBits, etc.)
This change, which allows @llvm.assume to be used from within computeKnownBits
(and other associated functions in ValueTracking), adds some (optional)
parameters to computeKnownBits and friends. These functions now (optionally)
take a "context" instruction pointer, an AssumptionTracker pointer, and also a
DomTree pointer, and most of the changes are just to pass this new information
when it is easily available from InstSimplify, InstCombine, etc.
As explained below, the significant conceptual change is that known properties
of a value might depend on the control-flow location of the use (because we
care that the @llvm.assume dominates the use because assumptions have
control-flow dependencies). This means that, when we ask if bits are known in a
value, we might get different answers for different uses.
The significant changes are all in ValueTracking. Two main changes: First, as
with the rest of the code, new parameters need to be passed around. To make
this easier, I grouped them into a structure, and I made internal static
versions of the relevant functions that take this structure as a parameter. The
new code does as you might expect, it looks for @llvm.assume calls that make
use of the value we're trying to learn something about (often indirectly),
attempts to pattern match that expression, and uses the result if successful.
By making use of the AssumptionTracker, the process of finding @llvm.assume
calls is not expensive.
Part of the structure being passed around inside ValueTracking is a set of
already-considered @llvm.assume calls. This is to prevent a query using, for
example, the assume(a == b), to recurse on itself. The context and DT params
are used to find applicable assumptions. An assumption needs to dominate the
context instruction, or come after it deterministically. In this latter case we
only handle the specific case where both the assumption and the context
instruction are in the same block, and we need to exclude assumptions from
being used to simplify their own ephemeral values (those which contribute only
to the assumption) because otherwise the assumption would prove its feeding
comparison trivial and would be removed.
This commit adds the plumbing and the logic for a simple masked-bit propagation
(just enough to write a regression test). Future commits add more patterns
(and, correspondingly, more regression tests).
llvm-svn: 217342
2014-09-08 02:57:58 +08:00
|
|
|
const DominatorTree *DT) {
|
2010-12-26 04:37:57 +08:00
|
|
|
assert(V->getType()->isPointerTy() &&
|
|
|
|
"getOrEnforceKnownAlignment expects a pointer!");
|
2013-08-02 06:42:18 +08:00
|
|
|
|
2017-05-25 00:53:07 +08:00
|
|
|
KnownBits Known = computeKnownBits(V, DL, 0, AC, CxtI, DT);
|
2017-05-13 01:20:30 +08:00
|
|
|
unsigned TrailZ = Known.countMinTrailingZeros();
|
2013-07-23 07:16:36 +08:00
|
|
|
|
2013-07-24 06:20:57 +08:00
|
|
|
// Avoid trouble with ridiculously large TrailZ values, such as
|
2010-12-26 04:37:57 +08:00
|
|
|
// those computed from a null pointer.
|
|
|
|
TrailZ = std::min(TrailZ, unsigned(sizeof(unsigned) * CHAR_BIT - 1));
|
2013-07-23 07:16:36 +08:00
|
|
|
|
2017-05-25 00:53:07 +08:00
|
|
|
unsigned Align = 1u << std::min(Known.getBitWidth() - 1, TrailZ);
|
2013-07-23 07:16:36 +08:00
|
|
|
|
2010-12-26 04:37:57 +08:00
|
|
|
// LLVM doesn't support alignments larger than this currently.
|
|
|
|
Align = std::min(Align, +Value::MaximumAlignment);
|
2013-07-23 07:16:36 +08:00
|
|
|
|
2010-12-26 04:37:57 +08:00
|
|
|
if (PrefAlign > Align)
|
2013-08-02 06:42:18 +08:00
|
|
|
Align = enforceKnownAlignment(V, Align, PrefAlign, DL);
|
2013-07-23 07:16:36 +08:00
|
|
|
|
2010-12-26 04:37:57 +08:00
|
|
|
// We don't need to make any adjustment.
|
|
|
|
return Align;
|
|
|
|
}
|
|
|
|
|
2011-03-18 05:58:19 +08:00
|
|
|
///===---------------------------------------------------------------------===//
|
|
|
|
/// Dbg Intrinsic utilities
|
|
|
|
///
|
|
|
|
|
2013-04-27 01:48:33 +08:00
|
|
|
/// See if there is a dbg.value intrinsic for DIVar before I.
|
2016-02-18 04:02:25 +08:00
|
|
|
static bool LdStHasDebugValue(DILocalVariable *DIVar, DIExpression *DIExpr,
|
|
|
|
Instruction *I) {
|
2013-04-27 01:48:33 +08:00
|
|
|
// Since we can't guarantee that the original dbg.declare instrinsic
|
|
|
|
// is removed by LowerDbgDeclare(), we need to make sure that we are
|
|
|
|
// not inserting the same dbg.value intrinsic over and over.
|
2017-10-18 05:27:42 +08:00
|
|
|
BasicBlock::InstListType::iterator PrevI(I);
|
2013-04-27 01:48:33 +08:00
|
|
|
if (PrevI != I->getParent()->getInstList().begin()) {
|
|
|
|
--PrevI;
|
|
|
|
if (DbgValueInst *DVI = dyn_cast<DbgValueInst>(PrevI))
|
|
|
|
if (DVI->getValue() == I->getOperand(0) &&
|
2016-02-18 04:02:25 +08:00
|
|
|
DVI->getVariable() == DIVar &&
|
|
|
|
DVI->getExpression() == DIExpr)
|
2013-04-27 01:48:33 +08:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2016-09-22 22:13:25 +08:00
|
|
|
/// See if there is a dbg.value intrinsic for DIVar for the PHI node.
|
2017-06-26 11:31:31 +08:00
|
|
|
static bool PhiHasDebugValue(DILocalVariable *DIVar,
|
2016-09-22 22:13:25 +08:00
|
|
|
DIExpression *DIExpr,
|
|
|
|
PHINode *APN) {
|
|
|
|
// Since we can't guarantee that the original dbg.declare instrinsic
|
|
|
|
// is removed by LowerDbgDeclare(), we need to make sure that we are
|
|
|
|
// not inserting the same dbg.value intrinsic over and over.
|
2017-03-17 04:11:54 +08:00
|
|
|
SmallVector<DbgValueInst *, 1> DbgValues;
|
|
|
|
findDbgValues(DbgValues, APN);
|
|
|
|
for (auto *DVI : DbgValues) {
|
|
|
|
assert(DVI->getValue() == APN);
|
|
|
|
if ((DVI->getVariable() == DIVar) && (DVI->getExpression() == DIExpr))
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
return false;
|
2016-09-22 22:13:25 +08:00
|
|
|
}
|
|
|
|
|
2018-06-15 21:48:55 +08:00
|
|
|
/// Check if the alloc size of \p ValTy is large enough to cover the variable
|
|
|
|
/// (or fragment of the variable) described by \p DII.
|
|
|
|
///
|
|
|
|
/// This is primarily intended as a helper for the different
|
|
|
|
/// ConvertDebugDeclareToDebugValue functions. The dbg.declare/dbg.addr that is
|
|
|
|
/// converted describes an alloca'd variable, so we need to use the
|
|
|
|
/// alloc size of the value when doing the comparison. E.g. an i1 value will be
|
|
|
|
/// identified as covering an n-bit fragment, if the store size of i1 is at
|
|
|
|
/// least n bits.
|
2018-08-06 11:59:47 +08:00
|
|
|
static bool valueCoversEntireFragment(Type *ValTy, DbgVariableIntrinsic *DII) {
|
2018-06-15 21:48:55 +08:00
|
|
|
const DataLayout &DL = DII->getModule()->getDataLayout();
|
|
|
|
uint64_t ValueSize = DL.getTypeAllocSizeInBits(ValTy);
|
|
|
|
if (auto FragmentSize = DII->getFragmentSizeInBits())
|
|
|
|
return ValueSize >= *FragmentSize;
|
2018-06-26 14:17:00 +08:00
|
|
|
// We can't always calculate the size of the DI variable (e.g. if it is a
|
|
|
|
// VLA). Try to use the size of the alloca that the dbg intrinsic describes
|
|
|
|
// intead.
|
|
|
|
if (DII->isAddressOfVariable())
|
|
|
|
if (auto *AI = dyn_cast_or_null<AllocaInst>(DII->getVariableLocation()))
|
|
|
|
if (auto FragmentSize = AI->getAllocationSizeInBits(DL))
|
|
|
|
return ValueSize >= *FragmentSize;
|
|
|
|
// Could not determine size of variable. Conservatively return false.
|
2018-06-15 21:48:55 +08:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2013-04-27 02:10:50 +08:00
|
|
|
/// Inserts a llvm.dbg.value intrinsic before a store to an alloca'd value
|
2017-09-22 03:52:03 +08:00
|
|
|
/// that has an associated llvm.dbg.declare or llvm.dbg.addr intrinsic.
|
2018-08-06 11:59:47 +08:00
|
|
|
void llvm::ConvertDebugDeclareToDebugValue(DbgVariableIntrinsic *DII,
|
2011-03-18 05:58:19 +08:00
|
|
|
StoreInst *SI, DIBuilder &Builder) {
|
2017-09-22 03:52:03 +08:00
|
|
|
assert(DII->isAddressOfVariable());
|
|
|
|
auto *DIVar = DII->getVariable();
|
2015-04-22 02:24:23 +08:00
|
|
|
assert(DIVar && "Missing variable");
|
2017-09-22 03:52:03 +08:00
|
|
|
auto *DIExpr = DII->getExpression();
|
2017-05-16 05:34:01 +08:00
|
|
|
Value *DV = SI->getOperand(0);
|
2011-03-18 05:58:19 +08:00
|
|
|
|
2018-06-15 21:48:55 +08:00
|
|
|
if (!valueCoversEntireFragment(SI->getValueOperand()->getType(), DII)) {
|
|
|
|
// FIXME: If storing to a part of the variable described by the dbg.declare,
|
|
|
|
// then we want to insert a dbg.value for the corresponding fragment.
|
|
|
|
LLVM_DEBUG(dbgs() << "Failed to convert dbg.declare to dbg.value: "
|
|
|
|
<< *DII << '\n');
|
|
|
|
// For now, when there is a store to parts of the variable (but we do not
|
|
|
|
// know which part) we insert an dbg.value instrinsic to indicate that we
|
|
|
|
// know nothing about the variable's content.
|
|
|
|
DV = UndefValue::get(DV->getType());
|
|
|
|
if (!LdStHasDebugValue(DIVar, DIExpr, SI))
|
|
|
|
Builder.insertDbgValueIntrinsic(DV, DIVar, DIExpr, DII->getDebugLoc(),
|
|
|
|
SI);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2011-05-17 05:24:05 +08:00
|
|
|
// If an argument is zero extended then use argument directly. The ZExt
|
|
|
|
// may be zapped by an optimization pass in future.
|
2014-04-25 13:29:35 +08:00
|
|
|
Argument *ExtendedArg = nullptr;
|
2011-05-17 05:24:05 +08:00
|
|
|
if (ZExtInst *ZExt = dyn_cast<ZExtInst>(SI->getOperand(0)))
|
|
|
|
ExtendedArg = dyn_cast<Argument>(ZExt->getOperand(0));
|
|
|
|
if (SExtInst *SExt = dyn_cast<SExtInst>(SI->getOperand(0)))
|
|
|
|
ExtendedArg = dyn_cast<Argument>(SExt->getOperand(0));
|
2016-01-13 06:46:09 +08:00
|
|
|
if (ExtendedArg) {
|
2017-09-22 03:52:03 +08:00
|
|
|
// If this DII was already describing only a fragment of a variable, ensure
|
2017-05-16 05:34:01 +08:00
|
|
|
// that fragment is appropriately narrowed here.
|
|
|
|
// But if a fragment wasn't used, describe the value as the original
|
|
|
|
// argument (rather than the zext or sext) so that it remains described even
|
|
|
|
// if the sext/zext is optimized away. This widens the variable description,
|
|
|
|
// leaving it up to the consumer to know how the smaller value may be
|
|
|
|
// represented in a larger register.
|
|
|
|
if (auto Fragment = DIExpr->getFragmentInfo()) {
|
|
|
|
unsigned FragmentOffset = Fragment->OffsetInBits;
|
|
|
|
SmallVector<uint64_t, 3> Ops(DIExpr->elements_begin(),
|
|
|
|
DIExpr->elements_end() - 3);
|
|
|
|
Ops.push_back(dwarf::DW_OP_LLVM_fragment);
|
|
|
|
Ops.push_back(FragmentOffset);
|
2017-09-22 03:52:03 +08:00
|
|
|
const DataLayout &DL = DII->getModule()->getDataLayout();
|
2017-05-16 05:34:01 +08:00
|
|
|
Ops.push_back(DL.getTypeSizeInBits(ExtendedArg->getType()));
|
|
|
|
DIExpr = Builder.createExpression(Ops);
|
2016-01-13 06:46:09 +08:00
|
|
|
}
|
2017-05-16 05:34:01 +08:00
|
|
|
DV = ExtendedArg;
|
|
|
|
}
|
|
|
|
if (!LdStHasDebugValue(DIVar, DIExpr, SI))
|
2017-09-22 03:52:03 +08:00
|
|
|
Builder.insertDbgValueIntrinsic(DV, DIVar, DIExpr, DII->getDebugLoc(),
|
2017-05-16 05:34:01 +08:00
|
|
|
SI);
|
2011-03-18 05:58:19 +08:00
|
|
|
}
|
|
|
|
|
2013-04-27 02:10:50 +08:00
|
|
|
/// Inserts a llvm.dbg.value intrinsic before a load of an alloca'd value
|
2017-09-22 03:52:03 +08:00
|
|
|
/// that has an associated llvm.dbg.declare or llvm.dbg.addr intrinsic.
|
2018-08-06 11:59:47 +08:00
|
|
|
void llvm::ConvertDebugDeclareToDebugValue(DbgVariableIntrinsic *DII,
|
2011-03-19 07:45:43 +08:00
|
|
|
LoadInst *LI, DIBuilder &Builder) {
|
2017-09-22 03:52:03 +08:00
|
|
|
auto *DIVar = DII->getVariable();
|
|
|
|
auto *DIExpr = DII->getExpression();
|
2015-04-22 02:24:23 +08:00
|
|
|
assert(DIVar && "Missing variable");
|
2011-03-19 07:45:43 +08:00
|
|
|
|
2016-02-18 04:02:25 +08:00
|
|
|
if (LdStHasDebugValue(DIVar, DIExpr, LI))
|
2016-09-22 22:13:25 +08:00
|
|
|
return;
|
2013-04-27 01:48:33 +08:00
|
|
|
|
2018-06-26 14:17:00 +08:00
|
|
|
if (!valueCoversEntireFragment(LI->getType(), DII)) {
|
|
|
|
// FIXME: If only referring to a part of the variable described by the
|
|
|
|
// dbg.declare, then we want to insert a dbg.value for the corresponding
|
|
|
|
// fragment.
|
|
|
|
LLVM_DEBUG(dbgs() << "Failed to convert dbg.declare to dbg.value: "
|
|
|
|
<< *DII << '\n');
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
Clean up the processing of dbg.value in various places
Summary:
First up is instcombine, where in the dbg.declare -> dbg.value conversion,
the llvm.dbg.value needs to be called on the actual loaded value, rather
than the address (since the whole point of this transformation is to be
able to get rid of the alloca). Further, now that that's cleaned up, we
can remove a hack in the backend, that would add an implicit OP_deref if
the argument to dbg.value was an alloca. This stems from before the
existence of DIExpression and is no longer necessary since the deref can
be expressed explicitly.
Now, in order to make sure that the tests pass with this change, we need to
correct the printing of DEBUG_VALUE comments to take into account the
expression, which wasn't taken into account before.
Unfortunately, for both these changes, there were a number of incorrect
test cases (mostly the wrong number of DW_OP_derefs, but also a couple
where the test itself was broken more badly). aprantl and I have gone
through and adjusted these test case in order to make them pass with
these fixes and in some cases to make sure they're actually testing
what they are meant to test.
Reviewers: aprantl
Subscribers: dsanders
Differential Revision: http://reviews.llvm.org/D14186
llvm-svn: 256077
2015-12-19 10:02:44 +08:00
|
|
|
// We are now tracking the loaded value instead of the address. In the
|
|
|
|
// future if multi-location support is added to the IR, it might be
|
|
|
|
// preferable to keep tracking both the loaded value and the original
|
|
|
|
// address in case the alloca can not be elided.
|
|
|
|
Instruction *DbgValue = Builder.insertDbgValueIntrinsic(
|
2017-09-22 03:52:03 +08:00
|
|
|
LI, DIVar, DIExpr, DII->getDebugLoc(), (Instruction *)nullptr);
|
Clean up the processing of dbg.value in various places
Summary:
First up is instcombine, where in the dbg.declare -> dbg.value conversion,
the llvm.dbg.value needs to be called on the actual loaded value, rather
than the address (since the whole point of this transformation is to be
able to get rid of the alloca). Further, now that that's cleaned up, we
can remove a hack in the backend, that would add an implicit OP_deref if
the argument to dbg.value was an alloca. This stems from before the
existence of DIExpression and is no longer necessary since the deref can
be expressed explicitly.
Now, in order to make sure that the tests pass with this change, we need to
correct the printing of DEBUG_VALUE comments to take into account the
expression, which wasn't taken into account before.
Unfortunately, for both these changes, there were a number of incorrect
test cases (mostly the wrong number of DW_OP_derefs, but also a couple
where the test itself was broken more badly). aprantl and I have gone
through and adjusted these test case in order to make them pass with
these fixes and in some cases to make sure they're actually testing
what they are meant to test.
Reviewers: aprantl
Subscribers: dsanders
Differential Revision: http://reviews.llvm.org/D14186
llvm-svn: 256077
2015-12-19 10:02:44 +08:00
|
|
|
DbgValue->insertAfter(LI);
|
2016-09-22 22:13:25 +08:00
|
|
|
}
|
|
|
|
|
2017-09-22 03:52:03 +08:00
|
|
|
/// Inserts a llvm.dbg.value intrinsic after a phi that has an associated
|
|
|
|
/// llvm.dbg.declare or llvm.dbg.addr intrinsic.
|
2018-08-06 11:59:47 +08:00
|
|
|
void llvm::ConvertDebugDeclareToDebugValue(DbgVariableIntrinsic *DII,
|
2016-09-22 22:13:25 +08:00
|
|
|
PHINode *APN, DIBuilder &Builder) {
|
2017-09-22 03:52:03 +08:00
|
|
|
auto *DIVar = DII->getVariable();
|
|
|
|
auto *DIExpr = DII->getExpression();
|
2016-09-22 22:13:25 +08:00
|
|
|
assert(DIVar && "Missing variable");
|
|
|
|
|
|
|
|
if (PhiHasDebugValue(DIVar, DIExpr, APN))
|
|
|
|
return;
|
|
|
|
|
2018-06-26 14:17:00 +08:00
|
|
|
if (!valueCoversEntireFragment(APN->getType(), DII)) {
|
|
|
|
// FIXME: If only referring to a part of the variable described by the
|
|
|
|
// dbg.declare, then we want to insert a dbg.value for the corresponding
|
|
|
|
// fragment.
|
|
|
|
LLVM_DEBUG(dbgs() << "Failed to convert dbg.declare to dbg.value: "
|
|
|
|
<< *DII << '\n');
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2016-09-28 02:45:31 +08:00
|
|
|
BasicBlock *BB = APN->getParent();
|
2016-09-22 22:13:25 +08:00
|
|
|
auto InsertionPt = BB->getFirstInsertionPt();
|
2016-09-28 02:45:31 +08:00
|
|
|
|
|
|
|
// The block may be a catchswitch block, which does not have a valid
|
|
|
|
// insertion point.
|
|
|
|
// FIXME: Insert dbg.value markers in the successors when appropriate.
|
|
|
|
if (InsertionPt != BB->end())
|
2017-09-22 03:52:03 +08:00
|
|
|
Builder.insertDbgValueIntrinsic(APN, DIVar, DIExpr, DII->getDebugLoc(),
|
2016-09-28 02:45:31 +08:00
|
|
|
&*InsertionPt);
|
2016-09-19 17:49:30 +08:00
|
|
|
}
|
|
|
|
|
2014-04-26 07:00:25 +08:00
|
|
|
/// Determine whether this alloca is either a VLA or an array.
|
|
|
|
static bool isArray(AllocaInst *AI) {
|
|
|
|
return AI->isArrayAllocation() ||
|
|
|
|
AI->getType()->getElementType()->isArrayTy();
|
|
|
|
}
|
|
|
|
|
2011-03-18 06:18:16 +08:00
|
|
|
/// LowerDbgDeclare - Lowers llvm.dbg.declare intrinsics into appropriate set
|
|
|
|
/// of llvm.dbg.value intrinsics.
|
|
|
|
bool llvm::LowerDbgDeclare(Function &F) {
|
IR: Split Metadata from Value
Split `Metadata` away from the `Value` class hierarchy, as part of
PR21532. Assembly and bitcode changes are in the wings, but this is the
bulk of the change for the IR C++ API.
I have a follow-up patch prepared for `clang`. If this breaks other
sub-projects, I apologize in advance :(. Help me compile it on Darwin
I'll try to fix it. FWIW, the errors should be easy to fix, so it may
be simpler to just fix it yourself.
This breaks the build for all metadata-related code that's out-of-tree.
Rest assured the transition is mechanical and the compiler should catch
almost all of the problems.
Here's a quick guide for updating your code:
- `Metadata` is the root of a class hierarchy with three main classes:
`MDNode`, `MDString`, and `ValueAsMetadata`. It is distinct from
the `Value` class hierarchy. It is typeless -- i.e., instances do
*not* have a `Type`.
- `MDNode`'s operands are all `Metadata *` (instead of `Value *`).
- `TrackingVH<MDNode>` and `WeakVH` referring to metadata can be
replaced with `TrackingMDNodeRef` and `TrackingMDRef`, respectively.
If you're referring solely to resolved `MDNode`s -- post graph
construction -- just use `MDNode*`.
- `MDNode` (and the rest of `Metadata`) have only limited support for
`replaceAllUsesWith()`.
As long as an `MDNode` is pointing at a forward declaration -- the
result of `MDNode::getTemporary()` -- it maintains a side map of its
uses and can RAUW itself. Once the forward declarations are fully
resolved RAUW support is dropped on the ground. This means that
uniquing collisions on changing operands cause nodes to become
"distinct". (This already happened fairly commonly, whenever an
operand went to null.)
If you're constructing complex (non self-reference) `MDNode` cycles,
you need to call `MDNode::resolveCycles()` on each node (or on a
top-level node that somehow references all of the nodes). Also,
don't do that. Metadata cycles (and the RAUW machinery needed to
construct them) are expensive.
- An `MDNode` can only refer to a `Constant` through a bridge called
`ConstantAsMetadata` (one of the subclasses of `ValueAsMetadata`).
As a side effect, accessing an operand of an `MDNode` that is known
to be, e.g., `ConstantInt`, takes three steps: first, cast from
`Metadata` to `ConstantAsMetadata`; second, extract the `Constant`;
third, cast down to `ConstantInt`.
The eventual goal is to introduce `MDInt`/`MDFloat`/etc. and have
metadata schema owners transition away from using `Constant`s when
the type isn't important (and they don't care about referring to
`GlobalValue`s).
In the meantime, I've added transitional API to the `mdconst`
namespace that matches semantics with the old code, in order to
avoid adding the error-prone three-step equivalent to every call
site. If your old code was:
MDNode *N = foo();
bar(isa <ConstantInt>(N->getOperand(0)));
baz(cast <ConstantInt>(N->getOperand(1)));
bak(cast_or_null <ConstantInt>(N->getOperand(2)));
bat(dyn_cast <ConstantInt>(N->getOperand(3)));
bay(dyn_cast_or_null<ConstantInt>(N->getOperand(4)));
you can trivially match its semantics with:
MDNode *N = foo();
bar(mdconst::hasa <ConstantInt>(N->getOperand(0)));
baz(mdconst::extract <ConstantInt>(N->getOperand(1)));
bak(mdconst::extract_or_null <ConstantInt>(N->getOperand(2)));
bat(mdconst::dyn_extract <ConstantInt>(N->getOperand(3)));
bay(mdconst::dyn_extract_or_null<ConstantInt>(N->getOperand(4)));
and when you transition your metadata schema to `MDInt`:
MDNode *N = foo();
bar(isa <MDInt>(N->getOperand(0)));
baz(cast <MDInt>(N->getOperand(1)));
bak(cast_or_null <MDInt>(N->getOperand(2)));
bat(dyn_cast <MDInt>(N->getOperand(3)));
bay(dyn_cast_or_null<MDInt>(N->getOperand(4)));
- A `CallInst` -- specifically, intrinsic instructions -- can refer to
metadata through a bridge called `MetadataAsValue`. This is a
subclass of `Value` where `getType()->isMetadataTy()`.
`MetadataAsValue` is the *only* class that can legally refer to a
`LocalAsMetadata`, which is a bridged form of non-`Constant` values
like `Argument` and `Instruction`. It can also refer to any other
`Metadata` subclass.
(I'll break all your testcases in a follow-up commit, when I propagate
this change to assembly.)
llvm-svn: 223802
2014-12-10 02:38:53 +08:00
|
|
|
DIBuilder DIB(*F.getParent(), /*AllowUnresolved*/ false);
|
2011-03-18 06:18:16 +08:00
|
|
|
SmallVector<DbgDeclareInst *, 4> Dbgs;
|
2014-03-28 07:30:04 +08:00
|
|
|
for (auto &FI : F)
|
2015-10-13 10:39:05 +08:00
|
|
|
for (Instruction &BI : FI)
|
|
|
|
if (auto DDI = dyn_cast<DbgDeclareInst>(&BI))
|
2011-03-18 06:18:16 +08:00
|
|
|
Dbgs.push_back(DDI);
|
2014-03-28 07:30:04 +08:00
|
|
|
|
2011-03-18 06:18:16 +08:00
|
|
|
if (Dbgs.empty())
|
|
|
|
return false;
|
|
|
|
|
2014-03-28 07:30:04 +08:00
|
|
|
for (auto &I : Dbgs) {
|
|
|
|
DbgDeclareInst *DDI = I;
|
2013-11-19 07:04:38 +08:00
|
|
|
AllocaInst *AI = dyn_cast_or_null<AllocaInst>(DDI->getAddress());
|
|
|
|
// If this is an alloca for a scalar variable, insert a dbg.value
|
|
|
|
// at each load and store to the alloca and erase the dbg.declare.
|
2014-04-26 04:49:25 +08:00
|
|
|
// The dbg.values allow tracking a variable even if it is not
|
|
|
|
// stored on the stack, while the dbg.declare can only describe
|
|
|
|
// the stack slot (and at a lexical-scope granularity). Later
|
|
|
|
// passes will attempt to elide the stack slot.
|
2018-03-09 08:45:04 +08:00
|
|
|
if (!AI || isArray(AI))
|
|
|
|
continue;
|
|
|
|
|
|
|
|
// A volatile load/store means that the alloca can't be elided anyway.
|
|
|
|
if (llvm::any_of(AI->users(), [](User *U) -> bool {
|
|
|
|
if (LoadInst *LI = dyn_cast<LoadInst>(U))
|
|
|
|
return LI->isVolatile();
|
|
|
|
if (StoreInst *SI = dyn_cast<StoreInst>(U))
|
|
|
|
return SI->isVolatile();
|
|
|
|
return false;
|
|
|
|
}))
|
|
|
|
continue;
|
|
|
|
|
|
|
|
for (auto &AIUse : AI->uses()) {
|
|
|
|
User *U = AIUse.getUser();
|
|
|
|
if (StoreInst *SI = dyn_cast<StoreInst>(U)) {
|
|
|
|
if (AIUse.getOperandNo() == 1)
|
|
|
|
ConvertDebugDeclareToDebugValue(DDI, SI, DIB);
|
|
|
|
} else if (LoadInst *LI = dyn_cast<LoadInst>(U)) {
|
|
|
|
ConvertDebugDeclareToDebugValue(DDI, LI, DIB);
|
|
|
|
} else if (CallInst *CI = dyn_cast<CallInst>(U)) {
|
2018-07-27 04:56:53 +08:00
|
|
|
// This is a call by-value or some other instruction that takes a
|
|
|
|
// pointer to the variable. Insert a *value* intrinsic that describes
|
|
|
|
// the variable by dereferencing the alloca.
|
|
|
|
auto *DerefExpr =
|
|
|
|
DIExpression::append(DDI->getExpression(), dwarf::DW_OP_deref);
|
|
|
|
DIB.insertDbgValueIntrinsic(AI, DDI->getVariable(), DerefExpr,
|
|
|
|
DDI->getDebugLoc(), CI);
|
2016-01-15 03:12:27 +08:00
|
|
|
}
|
2011-03-18 06:18:16 +08:00
|
|
|
}
|
2018-03-09 08:45:04 +08:00
|
|
|
DDI->eraseFromParent();
|
2011-03-18 06:18:16 +08:00
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
2011-05-24 11:10:43 +08:00
|
|
|
|
2018-01-26 05:37:05 +08:00
|
|
|
/// Propagate dbg.value intrinsics through the newly inserted PHIs.
|
|
|
|
void llvm::insertDebugValuesForPHIs(BasicBlock *BB,
|
|
|
|
SmallVectorImpl<PHINode *> &InsertedPHIs) {
|
|
|
|
assert(BB && "No BasicBlock to clone dbg.value(s) from.");
|
|
|
|
if (InsertedPHIs.size() == 0)
|
|
|
|
return;
|
|
|
|
|
|
|
|
// Map existing PHI nodes to their dbg.values.
|
|
|
|
ValueToValueMapTy DbgValueMap;
|
|
|
|
for (auto &I : *BB) {
|
2018-08-06 11:59:47 +08:00
|
|
|
if (auto DbgII = dyn_cast<DbgVariableIntrinsic>(&I)) {
|
2018-01-26 05:37:05 +08:00
|
|
|
if (auto *Loc = dyn_cast_or_null<PHINode>(DbgII->getVariableLocation()))
|
|
|
|
DbgValueMap.insert({Loc, DbgII});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (DbgValueMap.size() == 0)
|
|
|
|
return;
|
|
|
|
|
|
|
|
// Then iterate through the new PHIs and look to see if they use one of the
|
|
|
|
// previously mapped PHIs. If so, insert a new dbg.value intrinsic that will
|
|
|
|
// propagate the info through the new PHI.
|
|
|
|
LLVMContext &C = BB->getContext();
|
|
|
|
for (auto PHI : InsertedPHIs) {
|
2018-02-24 01:38:27 +08:00
|
|
|
BasicBlock *Parent = PHI->getParent();
|
|
|
|
// Avoid inserting an intrinsic into an EH block.
|
|
|
|
if (Parent->getFirstNonPHI()->isEHPad())
|
|
|
|
continue;
|
|
|
|
auto PhiMAV = MetadataAsValue::get(C, ValueAsMetadata::get(PHI));
|
2018-01-26 05:37:05 +08:00
|
|
|
for (auto VI : PHI->operand_values()) {
|
|
|
|
auto V = DbgValueMap.find(VI);
|
|
|
|
if (V != DbgValueMap.end()) {
|
2018-08-06 11:59:47 +08:00
|
|
|
auto *DbgII = cast<DbgVariableIntrinsic>(V->second);
|
2018-01-26 05:37:05 +08:00
|
|
|
Instruction *NewDbgII = DbgII->clone();
|
|
|
|
NewDbgII->setOperand(0, PhiMAV);
|
2018-01-26 07:48:29 +08:00
|
|
|
auto InsertionPt = Parent->getFirstInsertionPt();
|
|
|
|
assert(InsertionPt != Parent->end() && "Ill-formed basic block");
|
|
|
|
NewDbgII->insertBefore(&*InsertionPt);
|
2018-01-26 05:37:05 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-09-22 03:52:03 +08:00
|
|
|
/// Finds all intrinsics declaring local variables as living in the memory that
|
|
|
|
/// 'V' points to. This may include a mix of dbg.declare and
|
|
|
|
/// dbg.addr intrinsics.
|
2018-08-06 11:59:47 +08:00
|
|
|
TinyPtrVector<DbgVariableIntrinsic *> llvm::FindDbgAddrUses(Value *V) {
|
2018-06-27 02:44:52 +08:00
|
|
|
// This function is hot. Check whether the value has any metadata to avoid a
|
|
|
|
// DenseMap lookup.
|
|
|
|
if (!V->isUsedByMetadata())
|
|
|
|
return {};
|
2017-09-22 03:52:03 +08:00
|
|
|
auto *L = LocalAsMetadata::getIfExists(V);
|
|
|
|
if (!L)
|
|
|
|
return {};
|
|
|
|
auto *MDV = MetadataAsValue::getIfExists(V->getContext(), L);
|
|
|
|
if (!MDV)
|
|
|
|
return {};
|
|
|
|
|
2018-08-06 11:59:47 +08:00
|
|
|
TinyPtrVector<DbgVariableIntrinsic *> Declares;
|
2017-09-22 03:52:03 +08:00
|
|
|
for (User *U : MDV->users()) {
|
2018-08-06 11:59:47 +08:00
|
|
|
if (auto *DII = dyn_cast<DbgVariableIntrinsic>(U))
|
2017-09-22 03:52:03 +08:00
|
|
|
if (DII->isAddressOfVariable())
|
|
|
|
Declares.push_back(DII);
|
|
|
|
}
|
2011-05-24 11:10:43 +08:00
|
|
|
|
2017-09-22 03:52:03 +08:00
|
|
|
return Declares;
|
2011-05-24 11:10:43 +08:00
|
|
|
}
|
2012-12-12 22:31:53 +08:00
|
|
|
|
2017-03-17 04:11:54 +08:00
|
|
|
void llvm::findDbgValues(SmallVectorImpl<DbgValueInst *> &DbgValues, Value *V) {
|
2018-06-27 02:44:52 +08:00
|
|
|
// This function is hot. Check whether the value has any metadata to avoid a
|
|
|
|
// DenseMap lookup.
|
|
|
|
if (!V->isUsedByMetadata())
|
|
|
|
return;
|
2016-09-22 22:13:25 +08:00
|
|
|
if (auto *L = LocalAsMetadata::getIfExists(V))
|
|
|
|
if (auto *MDV = MetadataAsValue::getIfExists(V->getContext(), L))
|
|
|
|
for (User *U : MDV->users())
|
|
|
|
if (DbgValueInst *DVI = dyn_cast<DbgValueInst>(U))
|
2017-03-17 04:11:54 +08:00
|
|
|
DbgValues.push_back(DVI);
|
|
|
|
}
|
|
|
|
|
2018-08-06 11:59:47 +08:00
|
|
|
void llvm::findDbgUsers(SmallVectorImpl<DbgVariableIntrinsic *> &DbgUsers,
|
2018-01-06 07:27:02 +08:00
|
|
|
Value *V) {
|
2018-06-27 02:44:52 +08:00
|
|
|
// This function is hot. Check whether the value has any metadata to avoid a
|
|
|
|
// DenseMap lookup.
|
|
|
|
if (!V->isUsedByMetadata())
|
|
|
|
return;
|
2017-11-15 05:49:06 +08:00
|
|
|
if (auto *L = LocalAsMetadata::getIfExists(V))
|
|
|
|
if (auto *MDV = MetadataAsValue::getIfExists(V->getContext(), L))
|
|
|
|
for (User *U : MDV->users())
|
2018-08-06 11:59:47 +08:00
|
|
|
if (DbgVariableIntrinsic *DII = dyn_cast<DbgVariableIntrinsic>(U))
|
2017-11-15 05:49:06 +08:00
|
|
|
DbgUsers.push_back(DII);
|
|
|
|
}
|
|
|
|
|
2015-12-01 08:40:05 +08:00
|
|
|
bool llvm::replaceDbgDeclare(Value *Address, Value *NewAddress,
|
|
|
|
Instruction *InsertBefore, DIBuilder &Builder,
|
2017-12-09 05:58:18 +08:00
|
|
|
bool DerefBefore, int Offset, bool DerefAfter) {
|
2017-09-22 03:52:03 +08:00
|
|
|
auto DbgAddrs = FindDbgAddrUses(Address);
|
2018-08-06 11:59:47 +08:00
|
|
|
for (DbgVariableIntrinsic *DII : DbgAddrs) {
|
2017-09-22 03:52:03 +08:00
|
|
|
DebugLoc Loc = DII->getDebugLoc();
|
|
|
|
auto *DIVar = DII->getVariable();
|
|
|
|
auto *DIExpr = DII->getExpression();
|
|
|
|
assert(DIVar && "Missing variable");
|
2017-12-09 05:58:18 +08:00
|
|
|
DIExpr = DIExpression::prepend(DIExpr, DerefBefore, Offset, DerefAfter);
|
2018-07-14 06:39:31 +08:00
|
|
|
// Insert llvm.dbg.declare immediately before InsertBefore, and remove old
|
2017-09-22 03:52:03 +08:00
|
|
|
// llvm.dbg.declare.
|
|
|
|
Builder.insertDeclare(NewAddress, DIVar, DIExpr, Loc, InsertBefore);
|
|
|
|
if (DII == InsertBefore)
|
2018-07-14 06:39:31 +08:00
|
|
|
InsertBefore = InsertBefore->getNextNode();
|
2017-09-22 03:52:03 +08:00
|
|
|
DII->eraseFromParent();
|
|
|
|
}
|
|
|
|
return !DbgAddrs.empty();
|
2012-12-12 22:31:53 +08:00
|
|
|
}
|
2012-12-21 19:18:49 +08:00
|
|
|
|
2015-12-01 08:40:05 +08:00
|
|
|
bool llvm::replaceDbgDeclareForAlloca(AllocaInst *AI, Value *NewAllocaAddress,
|
2017-12-09 05:58:18 +08:00
|
|
|
DIBuilder &Builder, bool DerefBefore,
|
|
|
|
int Offset, bool DerefAfter) {
|
2015-12-01 08:40:05 +08:00
|
|
|
return replaceDbgDeclare(AI, NewAllocaAddress, AI->getNextNode(), Builder,
|
2017-12-09 05:58:18 +08:00
|
|
|
DerefBefore, Offset, DerefAfter);
|
2015-12-01 08:40:05 +08:00
|
|
|
}
|
|
|
|
|
2016-06-17 06:34:00 +08:00
|
|
|
static void replaceOneDbgValueForAlloca(DbgValueInst *DVI, Value *NewAddress,
|
|
|
|
DIBuilder &Builder, int Offset) {
|
|
|
|
DebugLoc Loc = DVI->getDebugLoc();
|
|
|
|
auto *DIVar = DVI->getVariable();
|
|
|
|
auto *DIExpr = DVI->getExpression();
|
|
|
|
assert(DIVar && "Missing variable");
|
|
|
|
|
|
|
|
// This is an alloca-based llvm.dbg.value. The first thing it should do with
|
|
|
|
// the alloca pointer is dereference it. Otherwise we don't know how to handle
|
|
|
|
// it and give up.
|
|
|
|
if (!DIExpr || DIExpr->getNumElements() < 1 ||
|
|
|
|
DIExpr->getElement(0) != dwarf::DW_OP_deref)
|
|
|
|
return;
|
|
|
|
|
|
|
|
// Insert the offset immediately after the first deref.
|
|
|
|
// We could just change the offset argument of dbg.value, but it's unsigned...
|
|
|
|
if (Offset) {
|
Salvage debug info from instructions about to be deleted
[Reapplies r297971 and punting on finding a better API for findDbgValues()]
This patch improves debug info quality in InstCombine by looking at
values that are about to be deleted, checking whether there are any
dbg.value instrinsics referring to them, and potentially encoding the
semantics of the deleted instruction into the dbg.value's
DIExpression.
In the example in the testcase (which was extracted from XNU) there is a sequence of
%4 = load %struct.entry*, %struct.entry** %next2, align 8, !dbg !41
%5 = bitcast %struct.entry* %4 to i8*, !dbg !42
%add.ptr4 = getelementptr inbounds i8, i8* %5, i64 -8, !dbg !43
%6 = bitcast i8* %add.ptr4 to %struct.entry*, !dbg !44
call void @llvm.dbg.value(metadata %struct.entry* %6, i64 0, metadata !20, metadata !21), !dbg 34
When these instructions are eliminated by instcombine one after
another, we can still salvage the otherwise dead debug info:
- Bitcasts have no effect, so have the dbg.value point to operand(0)
- Loads can be expressed via a DW_OP_deref
- Constant gep instructions can be replaced by DWARF expression arithmetic
The API introduced by this patch is not specific to instcombine and
can be useful in other places, too.
rdar://problem/30725338
Differential Revision: https://reviews.llvm.org/D30919
llvm-svn: 297994
2017-03-17 05:14:09 +08:00
|
|
|
SmallVector<uint64_t, 4> Ops;
|
|
|
|
Ops.push_back(dwarf::DW_OP_deref);
|
2017-04-28 16:44:30 +08:00
|
|
|
DIExpression::appendOffset(Ops, Offset);
|
Salvage debug info from instructions about to be deleted
[Reapplies r297971 and punting on finding a better API for findDbgValues()]
This patch improves debug info quality in InstCombine by looking at
values that are about to be deleted, checking whether there are any
dbg.value instrinsics referring to them, and potentially encoding the
semantics of the deleted instruction into the dbg.value's
DIExpression.
In the example in the testcase (which was extracted from XNU) there is a sequence of
%4 = load %struct.entry*, %struct.entry** %next2, align 8, !dbg !41
%5 = bitcast %struct.entry* %4 to i8*, !dbg !42
%add.ptr4 = getelementptr inbounds i8, i8* %5, i64 -8, !dbg !43
%6 = bitcast i8* %add.ptr4 to %struct.entry*, !dbg !44
call void @llvm.dbg.value(metadata %struct.entry* %6, i64 0, metadata !20, metadata !21), !dbg 34
When these instructions are eliminated by instcombine one after
another, we can still salvage the otherwise dead debug info:
- Bitcasts have no effect, so have the dbg.value point to operand(0)
- Loads can be expressed via a DW_OP_deref
- Constant gep instructions can be replaced by DWARF expression arithmetic
The API introduced by this patch is not specific to instcombine and
can be useful in other places, too.
rdar://problem/30725338
Differential Revision: https://reviews.llvm.org/D30919
llvm-svn: 297994
2017-03-17 05:14:09 +08:00
|
|
|
Ops.append(DIExpr->elements_begin() + 1, DIExpr->elements_end());
|
|
|
|
DIExpr = Builder.createExpression(Ops);
|
2016-06-17 06:34:00 +08:00
|
|
|
}
|
|
|
|
|
2017-07-29 04:21:02 +08:00
|
|
|
Builder.insertDbgValueIntrinsic(NewAddress, DIVar, DIExpr, Loc, DVI);
|
2016-06-17 06:34:00 +08:00
|
|
|
DVI->eraseFromParent();
|
|
|
|
}
|
|
|
|
|
|
|
|
void llvm::replaceDbgValueForAlloca(AllocaInst *AI, Value *NewAllocaAddress,
|
|
|
|
DIBuilder &Builder, int Offset) {
|
|
|
|
if (auto *L = LocalAsMetadata::getIfExists(AI))
|
|
|
|
if (auto *MDV = MetadataAsValue::getIfExists(AI->getContext(), L))
|
|
|
|
for (auto UI = MDV->use_begin(), UE = MDV->use_end(); UI != UE;) {
|
|
|
|
Use &U = *UI++;
|
|
|
|
if (auto *DVI = dyn_cast<DbgValueInst>(U.getUser()))
|
|
|
|
replaceOneDbgValueForAlloca(DVI, NewAllocaAddress, Builder, Offset);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-07-07 01:32:39 +08:00
|
|
|
/// Wrap \p V in a ValueAsMetadata instance.
|
|
|
|
static MetadataAsValue *wrapValueInMetadata(LLVMContext &C, Value *V) {
|
|
|
|
return MetadataAsValue::get(C, ValueAsMetadata::get(V));
|
|
|
|
}
|
|
|
|
|
|
|
|
bool llvm::salvageDebugInfo(Instruction &I) {
|
2018-08-06 11:59:47 +08:00
|
|
|
SmallVector<DbgVariableIntrinsic *, 1> DbgUsers;
|
2018-01-06 07:27:02 +08:00
|
|
|
findDbgUsers(DbgUsers, &I);
|
|
|
|
if (DbgUsers.empty())
|
2018-07-07 01:32:39 +08:00
|
|
|
return false;
|
2018-01-06 07:27:02 +08:00
|
|
|
|
Salvage debug info from instructions about to be deleted
[Reapplies r297971 and punting on finding a better API for findDbgValues()]
This patch improves debug info quality in InstCombine by looking at
values that are about to be deleted, checking whether there are any
dbg.value instrinsics referring to them, and potentially encoding the
semantics of the deleted instruction into the dbg.value's
DIExpression.
In the example in the testcase (which was extracted from XNU) there is a sequence of
%4 = load %struct.entry*, %struct.entry** %next2, align 8, !dbg !41
%5 = bitcast %struct.entry* %4 to i8*, !dbg !42
%add.ptr4 = getelementptr inbounds i8, i8* %5, i64 -8, !dbg !43
%6 = bitcast i8* %add.ptr4 to %struct.entry*, !dbg !44
call void @llvm.dbg.value(metadata %struct.entry* %6, i64 0, metadata !20, metadata !21), !dbg 34
When these instructions are eliminated by instcombine one after
another, we can still salvage the otherwise dead debug info:
- Bitcasts have no effect, so have the dbg.value point to operand(0)
- Loads can be expressed via a DW_OP_deref
- Constant gep instructions can be replaced by DWARF expression arithmetic
The API introduced by this patch is not specific to instcombine and
can be useful in other places, too.
rdar://problem/30725338
Differential Revision: https://reviews.llvm.org/D30919
llvm-svn: 297994
2017-03-17 05:14:09 +08:00
|
|
|
auto &M = *I.getModule();
|
2018-02-16 03:13:03 +08:00
|
|
|
auto &DL = M.getDataLayout();
|
2018-07-07 01:32:39 +08:00
|
|
|
auto &Ctx = I.getContext();
|
|
|
|
auto wrapMD = [&](Value *V) { return wrapValueInMetadata(Ctx, V); };
|
Salvage debug info from instructions about to be deleted
[Reapplies r297971 and punting on finding a better API for findDbgValues()]
This patch improves debug info quality in InstCombine by looking at
values that are about to be deleted, checking whether there are any
dbg.value instrinsics referring to them, and potentially encoding the
semantics of the deleted instruction into the dbg.value's
DIExpression.
In the example in the testcase (which was extracted from XNU) there is a sequence of
%4 = load %struct.entry*, %struct.entry** %next2, align 8, !dbg !41
%5 = bitcast %struct.entry* %4 to i8*, !dbg !42
%add.ptr4 = getelementptr inbounds i8, i8* %5, i64 -8, !dbg !43
%6 = bitcast i8* %add.ptr4 to %struct.entry*, !dbg !44
call void @llvm.dbg.value(metadata %struct.entry* %6, i64 0, metadata !20, metadata !21), !dbg 34
When these instructions are eliminated by instcombine one after
another, we can still salvage the otherwise dead debug info:
- Bitcasts have no effect, so have the dbg.value point to operand(0)
- Loads can be expressed via a DW_OP_deref
- Constant gep instructions can be replaced by DWARF expression arithmetic
The API introduced by this patch is not specific to instcombine and
can be useful in other places, too.
rdar://problem/30725338
Differential Revision: https://reviews.llvm.org/D30919
llvm-svn: 297994
2017-03-17 05:14:09 +08:00
|
|
|
|
2018-08-06 11:59:47 +08:00
|
|
|
auto doSalvage = [&](DbgVariableIntrinsic *DII, SmallVectorImpl<uint64_t> &Ops) {
|
2018-01-06 07:27:02 +08:00
|
|
|
auto *DIExpr = DII->getExpression();
|
[DebugInfo] Corrections for salvageDebugInfo
Summary:
When salvaging a dbg.declare/dbg.addr we should not add
DW_OP_stack_value to the DIExpression
(see test/Transforms/InstCombine/salvage-dbg-declare.ll).
Consider this example
%vla = alloca i32, i64 2
call void @llvm.dbg.declare(metadata i32* %vla, metadata !1, metadata !DIExpression())
Instcombine will turn it into
%vla1 = alloca [2 x i32]
%vla1.sub = getelementptr inbounds [2 x i32], [2 x i32]* %vla, i64 0, i64 0
call void @llvm.dbg.declare(metadata [2 x i32]* %vla1.sub, metadata !19, metadata !DIExpression())
If the GEP can be eliminated, then the dbg.declare will be salvaged
and we should get
%vla1 = alloca [2 x i32]
call void @llvm.dbg.declare(metadata [2 x i32]* %vla1, metadata !19, metadata !DIExpression())
The problem was that salvageDebugInfo did not recognize dbg.declare
as being indirect (%vla1 points to the value, it does not hold the
value), so we incorrectly got
call void @llvm.dbg.declare(metadata [2 x i32]* %vla1, metadata !19, metadata !DIExpression(DW_OP_stack_value))
I also made sure that llvm::salvageDebugInfo and
DIExpression::prependOpcodes do not add DW_OP_stack_value to
the DIExpression in case no new operands are added to the
DIExpression. That way we avoid to, unneccessarily, turn a
register location expression into an implicit location expression
in some situations (see test11 in test/Transforms/LICM/sinking.ll).
Reviewers: aprantl, vsk
Reviewed By: aprantl, vsk
Subscribers: JDevlieghere, llvm-commits
Differential Revision: https://reviews.llvm.org/D48837
llvm-svn: 336191
2018-07-03 19:29:00 +08:00
|
|
|
if (!Ops.empty()) {
|
|
|
|
// Do not add DW_OP_stack_value for DbgDeclare and DbgAddr, because they
|
|
|
|
// are implicitly pointing out the value as a DWARF memory location
|
|
|
|
// description.
|
|
|
|
bool WithStackValue = isa<DbgValueInst>(DII);
|
|
|
|
DIExpr = DIExpression::prependOpcodes(DIExpr, Ops, WithStackValue);
|
|
|
|
}
|
2018-01-06 07:27:02 +08:00
|
|
|
DII->setOperand(0, wrapMD(I.getOperand(0)));
|
2018-07-07 01:32:39 +08:00
|
|
|
DII->setOperand(2, MetadataAsValue::get(Ctx, DIExpr));
|
2018-05-14 20:53:11 +08:00
|
|
|
LLVM_DEBUG(dbgs() << "SALVAGE: " << *DII << '\n');
|
2017-11-07 06:49:39 +08:00
|
|
|
};
|
|
|
|
|
2018-08-06 11:59:47 +08:00
|
|
|
auto applyOffset = [&](DbgVariableIntrinsic *DII, uint64_t Offset) {
|
2018-02-10 03:19:55 +08:00
|
|
|
SmallVector<uint64_t, 8> Ops;
|
|
|
|
DIExpression::appendOffset(Ops, Offset);
|
|
|
|
doSalvage(DII, Ops);
|
|
|
|
};
|
|
|
|
|
2018-08-06 11:59:47 +08:00
|
|
|
auto applyOps = [&](DbgVariableIntrinsic *DII,
|
2018-02-10 03:19:55 +08:00
|
|
|
std::initializer_list<uint64_t> Opcodes) {
|
|
|
|
SmallVector<uint64_t, 8> Ops(Opcodes);
|
|
|
|
doSalvage(DII, Ops);
|
|
|
|
};
|
|
|
|
|
2018-02-13 11:34:23 +08:00
|
|
|
if (auto *CI = dyn_cast<CastInst>(&I)) {
|
2018-02-16 03:13:03 +08:00
|
|
|
if (!CI->isNoopCast(DL))
|
2018-07-07 01:32:39 +08:00
|
|
|
return false;
|
2018-02-13 11:34:23 +08:00
|
|
|
|
|
|
|
// No-op casts are irrelevant for debug info.
|
|
|
|
MetadataAsValue *CastSrc = wrapMD(I.getOperand(0));
|
2017-11-15 05:49:06 +08:00
|
|
|
for (auto *DII : DbgUsers) {
|
2018-02-13 11:34:23 +08:00
|
|
|
DII->setOperand(0, CastSrc);
|
2018-05-14 20:53:11 +08:00
|
|
|
LLVM_DEBUG(dbgs() << "SALVAGE: " << *DII << '\n');
|
Salvage debug info from instructions about to be deleted
[Reapplies r297971 and punting on finding a better API for findDbgValues()]
This patch improves debug info quality in InstCombine by looking at
values that are about to be deleted, checking whether there are any
dbg.value instrinsics referring to them, and potentially encoding the
semantics of the deleted instruction into the dbg.value's
DIExpression.
In the example in the testcase (which was extracted from XNU) there is a sequence of
%4 = load %struct.entry*, %struct.entry** %next2, align 8, !dbg !41
%5 = bitcast %struct.entry* %4 to i8*, !dbg !42
%add.ptr4 = getelementptr inbounds i8, i8* %5, i64 -8, !dbg !43
%6 = bitcast i8* %add.ptr4 to %struct.entry*, !dbg !44
call void @llvm.dbg.value(metadata %struct.entry* %6, i64 0, metadata !20, metadata !21), !dbg 34
When these instructions are eliminated by instcombine one after
another, we can still salvage the otherwise dead debug info:
- Bitcasts have no effect, so have the dbg.value point to operand(0)
- Loads can be expressed via a DW_OP_deref
- Constant gep instructions can be replaced by DWARF expression arithmetic
The API introduced by this patch is not specific to instcombine and
can be useful in other places, too.
rdar://problem/30725338
Differential Revision: https://reviews.llvm.org/D30919
llvm-svn: 297994
2017-03-17 05:14:09 +08:00
|
|
|
}
|
2018-07-07 01:32:39 +08:00
|
|
|
return true;
|
Salvage debug info from instructions about to be deleted
[Reapplies r297971 and punting on finding a better API for findDbgValues()]
This patch improves debug info quality in InstCombine by looking at
values that are about to be deleted, checking whether there are any
dbg.value instrinsics referring to them, and potentially encoding the
semantics of the deleted instruction into the dbg.value's
DIExpression.
In the example in the testcase (which was extracted from XNU) there is a sequence of
%4 = load %struct.entry*, %struct.entry** %next2, align 8, !dbg !41
%5 = bitcast %struct.entry* %4 to i8*, !dbg !42
%add.ptr4 = getelementptr inbounds i8, i8* %5, i64 -8, !dbg !43
%6 = bitcast i8* %add.ptr4 to %struct.entry*, !dbg !44
call void @llvm.dbg.value(metadata %struct.entry* %6, i64 0, metadata !20, metadata !21), !dbg 34
When these instructions are eliminated by instcombine one after
another, we can still salvage the otherwise dead debug info:
- Bitcasts have no effect, so have the dbg.value point to operand(0)
- Loads can be expressed via a DW_OP_deref
- Constant gep instructions can be replaced by DWARF expression arithmetic
The API introduced by this patch is not specific to instcombine and
can be useful in other places, too.
rdar://problem/30725338
Differential Revision: https://reviews.llvm.org/D30919
llvm-svn: 297994
2017-03-17 05:14:09 +08:00
|
|
|
} else if (auto *GEP = dyn_cast<GetElementPtrInst>(&I)) {
|
2018-01-06 07:27:02 +08:00
|
|
|
unsigned BitWidth =
|
2018-02-14 14:58:08 +08:00
|
|
|
M.getDataLayout().getIndexSizeInBits(GEP->getPointerAddressSpace());
|
2018-01-06 07:27:02 +08:00
|
|
|
// Rewrite a constant GEP into a DIExpression. Since we are performing
|
|
|
|
// arithmetic to compute the variable's *value* in the DIExpression, we
|
|
|
|
// need to mark the expression with a DW_OP_stack_value.
|
|
|
|
APInt Offset(BitWidth, 0);
|
|
|
|
if (GEP->accumulateConstantOffset(M.getDataLayout(), Offset))
|
|
|
|
for (auto *DII : DbgUsers)
|
|
|
|
applyOffset(DII, Offset.getSExtValue());
|
2018-07-07 01:32:39 +08:00
|
|
|
return true;
|
2017-11-07 06:49:39 +08:00
|
|
|
} else if (auto *BI = dyn_cast<BinaryOperator>(&I)) {
|
2018-02-16 03:13:03 +08:00
|
|
|
// Rewrite binary operations with constant integer operands.
|
2018-02-13 09:09:46 +08:00
|
|
|
auto *ConstInt = dyn_cast<ConstantInt>(I.getOperand(1));
|
|
|
|
if (!ConstInt || ConstInt->getBitWidth() > 64)
|
2018-07-07 01:32:39 +08:00
|
|
|
return false;
|
2018-02-13 09:09:46 +08:00
|
|
|
|
|
|
|
uint64_t Val = ConstInt->getSExtValue();
|
|
|
|
for (auto *DII : DbgUsers) {
|
|
|
|
switch (BI->getOpcode()) {
|
|
|
|
case Instruction::Add:
|
|
|
|
applyOffset(DII, Val);
|
|
|
|
break;
|
2018-02-13 09:09:47 +08:00
|
|
|
case Instruction::Sub:
|
|
|
|
applyOffset(DII, -int64_t(Val));
|
|
|
|
break;
|
2018-02-13 09:09:52 +08:00
|
|
|
case Instruction::Mul:
|
|
|
|
applyOps(DII, {dwarf::DW_OP_constu, Val, dwarf::DW_OP_mul});
|
|
|
|
break;
|
|
|
|
case Instruction::SDiv:
|
|
|
|
applyOps(DII, {dwarf::DW_OP_constu, Val, dwarf::DW_OP_div});
|
|
|
|
break;
|
|
|
|
case Instruction::SRem:
|
|
|
|
applyOps(DII, {dwarf::DW_OP_constu, Val, dwarf::DW_OP_mod});
|
|
|
|
break;
|
2018-02-13 09:09:46 +08:00
|
|
|
case Instruction::Or:
|
|
|
|
applyOps(DII, {dwarf::DW_OP_constu, Val, dwarf::DW_OP_or});
|
|
|
|
break;
|
2018-02-14 21:10:35 +08:00
|
|
|
case Instruction::And:
|
|
|
|
applyOps(DII, {dwarf::DW_OP_constu, Val, dwarf::DW_OP_and});
|
|
|
|
break;
|
2018-02-13 09:09:46 +08:00
|
|
|
case Instruction::Xor:
|
|
|
|
applyOps(DII, {dwarf::DW_OP_constu, Val, dwarf::DW_OP_xor});
|
|
|
|
break;
|
2018-02-13 09:09:49 +08:00
|
|
|
case Instruction::Shl:
|
|
|
|
applyOps(DII, {dwarf::DW_OP_constu, Val, dwarf::DW_OP_shl});
|
|
|
|
break;
|
|
|
|
case Instruction::LShr:
|
|
|
|
applyOps(DII, {dwarf::DW_OP_constu, Val, dwarf::DW_OP_shr});
|
|
|
|
break;
|
|
|
|
case Instruction::AShr:
|
|
|
|
applyOps(DII, {dwarf::DW_OP_constu, Val, dwarf::DW_OP_shra});
|
|
|
|
break;
|
2018-02-13 09:09:46 +08:00
|
|
|
default:
|
|
|
|
// TODO: Salvage constants from each kind of binop we know about.
|
2018-07-07 01:32:39 +08:00
|
|
|
return false;
|
2018-02-13 09:09:46 +08:00
|
|
|
}
|
|
|
|
}
|
2018-07-07 01:32:39 +08:00
|
|
|
return true;
|
2017-03-21 00:39:41 +08:00
|
|
|
} else if (isa<LoadInst>(&I)) {
|
2018-01-06 07:27:02 +08:00
|
|
|
MetadataAsValue *AddrMD = wrapMD(I.getOperand(0));
|
|
|
|
for (auto *DII : DbgUsers) {
|
Salvage debug info from instructions about to be deleted
[Reapplies r297971 and punting on finding a better API for findDbgValues()]
This patch improves debug info quality in InstCombine by looking at
values that are about to be deleted, checking whether there are any
dbg.value instrinsics referring to them, and potentially encoding the
semantics of the deleted instruction into the dbg.value's
DIExpression.
In the example in the testcase (which was extracted from XNU) there is a sequence of
%4 = load %struct.entry*, %struct.entry** %next2, align 8, !dbg !41
%5 = bitcast %struct.entry* %4 to i8*, !dbg !42
%add.ptr4 = getelementptr inbounds i8, i8* %5, i64 -8, !dbg !43
%6 = bitcast i8* %add.ptr4 to %struct.entry*, !dbg !44
call void @llvm.dbg.value(metadata %struct.entry* %6, i64 0, metadata !20, metadata !21), !dbg 34
When these instructions are eliminated by instcombine one after
another, we can still salvage the otherwise dead debug info:
- Bitcasts have no effect, so have the dbg.value point to operand(0)
- Loads can be expressed via a DW_OP_deref
- Constant gep instructions can be replaced by DWARF expression arithmetic
The API introduced by this patch is not specific to instcombine and
can be useful in other places, too.
rdar://problem/30725338
Differential Revision: https://reviews.llvm.org/D30919
llvm-svn: 297994
2017-03-17 05:14:09 +08:00
|
|
|
// Rewrite the load into DW_OP_deref.
|
2018-01-06 07:27:02 +08:00
|
|
|
auto *DIExpr = DII->getExpression();
|
2017-04-29 01:51:05 +08:00
|
|
|
DIExpr = DIExpression::prepend(DIExpr, DIExpression::WithDeref);
|
2018-01-06 07:27:02 +08:00
|
|
|
DII->setOperand(0, AddrMD);
|
2018-07-07 01:32:39 +08:00
|
|
|
DII->setOperand(2, MetadataAsValue::get(Ctx, DIExpr));
|
2018-05-14 20:53:11 +08:00
|
|
|
LLVM_DEBUG(dbgs() << "SALVAGE: " << *DII << '\n');
|
Salvage debug info from instructions about to be deleted
[Reapplies r297971 and punting on finding a better API for findDbgValues()]
This patch improves debug info quality in InstCombine by looking at
values that are about to be deleted, checking whether there are any
dbg.value instrinsics referring to them, and potentially encoding the
semantics of the deleted instruction into the dbg.value's
DIExpression.
In the example in the testcase (which was extracted from XNU) there is a sequence of
%4 = load %struct.entry*, %struct.entry** %next2, align 8, !dbg !41
%5 = bitcast %struct.entry* %4 to i8*, !dbg !42
%add.ptr4 = getelementptr inbounds i8, i8* %5, i64 -8, !dbg !43
%6 = bitcast i8* %add.ptr4 to %struct.entry*, !dbg !44
call void @llvm.dbg.value(metadata %struct.entry* %6, i64 0, metadata !20, metadata !21), !dbg 34
When these instructions are eliminated by instcombine one after
another, we can still salvage the otherwise dead debug info:
- Bitcasts have no effect, so have the dbg.value point to operand(0)
- Loads can be expressed via a DW_OP_deref
- Constant gep instructions can be replaced by DWARF expression arithmetic
The API introduced by this patch is not specific to instcombine and
can be useful in other places, too.
rdar://problem/30725338
Differential Revision: https://reviews.llvm.org/D30919
llvm-svn: 297994
2017-03-17 05:14:09 +08:00
|
|
|
}
|
2018-07-07 01:32:39 +08:00
|
|
|
return true;
|
Salvage debug info from instructions about to be deleted
[Reapplies r297971 and punting on finding a better API for findDbgValues()]
This patch improves debug info quality in InstCombine by looking at
values that are about to be deleted, checking whether there are any
dbg.value instrinsics referring to them, and potentially encoding the
semantics of the deleted instruction into the dbg.value's
DIExpression.
In the example in the testcase (which was extracted from XNU) there is a sequence of
%4 = load %struct.entry*, %struct.entry** %next2, align 8, !dbg !41
%5 = bitcast %struct.entry* %4 to i8*, !dbg !42
%add.ptr4 = getelementptr inbounds i8, i8* %5, i64 -8, !dbg !43
%6 = bitcast i8* %add.ptr4 to %struct.entry*, !dbg !44
call void @llvm.dbg.value(metadata %struct.entry* %6, i64 0, metadata !20, metadata !21), !dbg 34
When these instructions are eliminated by instcombine one after
another, we can still salvage the otherwise dead debug info:
- Bitcasts have no effect, so have the dbg.value point to operand(0)
- Loads can be expressed via a DW_OP_deref
- Constant gep instructions can be replaced by DWARF expression arithmetic
The API introduced by this patch is not specific to instcombine and
can be useful in other places, too.
rdar://problem/30725338
Differential Revision: https://reviews.llvm.org/D30919
llvm-svn: 297994
2017-03-17 05:14:09 +08:00
|
|
|
}
|
2018-07-07 01:32:39 +08:00
|
|
|
return false;
|
Salvage debug info from instructions about to be deleted
[Reapplies r297971 and punting on finding a better API for findDbgValues()]
This patch improves debug info quality in InstCombine by looking at
values that are about to be deleted, checking whether there are any
dbg.value instrinsics referring to them, and potentially encoding the
semantics of the deleted instruction into the dbg.value's
DIExpression.
In the example in the testcase (which was extracted from XNU) there is a sequence of
%4 = load %struct.entry*, %struct.entry** %next2, align 8, !dbg !41
%5 = bitcast %struct.entry* %4 to i8*, !dbg !42
%add.ptr4 = getelementptr inbounds i8, i8* %5, i64 -8, !dbg !43
%6 = bitcast i8* %add.ptr4 to %struct.entry*, !dbg !44
call void @llvm.dbg.value(metadata %struct.entry* %6, i64 0, metadata !20, metadata !21), !dbg 34
When these instructions are eliminated by instcombine one after
another, we can still salvage the otherwise dead debug info:
- Bitcasts have no effect, so have the dbg.value point to operand(0)
- Loads can be expressed via a DW_OP_deref
- Constant gep instructions can be replaced by DWARF expression arithmetic
The API introduced by this patch is not specific to instcombine and
can be useful in other places, too.
rdar://problem/30725338
Differential Revision: https://reviews.llvm.org/D30919
llvm-svn: 297994
2017-03-17 05:14:09 +08:00
|
|
|
}
|
|
|
|
|
2018-07-07 01:32:39 +08:00
|
|
|
/// A replacement for a dbg.value expression.
|
|
|
|
using DbgValReplacement = Optional<DIExpression *>;
|
|
|
|
|
|
|
|
/// Point debug users of \p From to \p To using exprs given by \p RewriteExpr,
|
|
|
|
/// possibly moving/deleting users to prevent use-before-def. Returns true if
|
|
|
|
/// changes are made.
|
|
|
|
static bool rewriteDebugUsers(
|
|
|
|
Instruction &From, Value &To, Instruction &DomPoint, DominatorTree &DT,
|
2018-08-06 11:59:47 +08:00
|
|
|
function_ref<DbgValReplacement(DbgVariableIntrinsic &DII)> RewriteExpr) {
|
2018-07-07 01:32:39 +08:00
|
|
|
// Find debug users of From.
|
2018-08-06 11:59:47 +08:00
|
|
|
SmallVector<DbgVariableIntrinsic *, 1> Users;
|
2018-06-21 00:50:25 +08:00
|
|
|
findDbgUsers(Users, &From);
|
|
|
|
if (Users.empty())
|
2018-07-07 01:32:39 +08:00
|
|
|
return false;
|
2018-06-21 00:50:25 +08:00
|
|
|
|
2018-07-07 01:32:39 +08:00
|
|
|
// Prevent use-before-def of To.
|
|
|
|
bool Changed = false;
|
2018-08-06 11:59:47 +08:00
|
|
|
SmallPtrSet<DbgVariableIntrinsic *, 1> DeleteOrSalvage;
|
2018-07-07 01:32:39 +08:00
|
|
|
if (isa<Instruction>(&To)) {
|
|
|
|
bool DomPointAfterFrom = From.getNextNonDebugInstruction() == &DomPoint;
|
|
|
|
|
|
|
|
for (auto *DII : Users) {
|
|
|
|
// It's common to see a debug user between From and DomPoint. Move it
|
|
|
|
// after DomPoint to preserve the variable update without any reordering.
|
|
|
|
if (DomPointAfterFrom && DII->getNextNonDebugInstruction() == &DomPoint) {
|
|
|
|
LLVM_DEBUG(dbgs() << "MOVE: " << *DII << '\n');
|
|
|
|
DII->moveAfter(&DomPoint);
|
|
|
|
Changed = true;
|
|
|
|
|
|
|
|
// Users which otherwise aren't dominated by the replacement value must
|
|
|
|
// be salvaged or deleted.
|
|
|
|
} else if (!DT.dominates(&DomPoint, DII)) {
|
|
|
|
DeleteOrSalvage.insert(DII);
|
|
|
|
}
|
2018-06-27 02:44:53 +08:00
|
|
|
}
|
2018-07-07 01:32:39 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
// Update debug users without use-before-def risk.
|
|
|
|
for (auto *DII : Users) {
|
|
|
|
if (DeleteOrSalvage.count(DII))
|
|
|
|
continue;
|
|
|
|
|
|
|
|
LLVMContext &Ctx = DII->getContext();
|
|
|
|
DbgValReplacement DVR = RewriteExpr(*DII);
|
|
|
|
if (!DVR)
|
|
|
|
continue;
|
|
|
|
|
|
|
|
DII->setOperand(0, wrapValueInMetadata(Ctx, &To));
|
|
|
|
DII->setOperand(2, MetadataAsValue::get(Ctx, *DVR));
|
|
|
|
LLVM_DEBUG(dbgs() << "REWRITE: " << *DII << '\n');
|
|
|
|
Changed = true;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!DeleteOrSalvage.empty()) {
|
|
|
|
// Try to salvage the remaining debug users.
|
|
|
|
Changed |= salvageDebugInfo(From);
|
|
|
|
|
|
|
|
// Delete the debug users which weren't salvaged.
|
|
|
|
for (auto *DII : DeleteOrSalvage) {
|
|
|
|
if (DII->getVariableLocation() == &From) {
|
|
|
|
LLVM_DEBUG(dbgs() << "Erased UseBeforeDef: " << *DII << '\n');
|
|
|
|
DII->eraseFromParent();
|
|
|
|
Changed = true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return Changed;
|
2018-06-27 02:44:53 +08:00
|
|
|
}
|
|
|
|
|
2018-07-07 01:32:39 +08:00
|
|
|
/// Check if a bitcast between a value of type \p FromTy to type \p ToTy would
|
|
|
|
/// losslessly preserve the bits and semantics of the value. This predicate is
|
|
|
|
/// symmetric, i.e swapping \p FromTy and \p ToTy should give the same result.
|
|
|
|
///
|
|
|
|
/// Note that Type::canLosslesslyBitCastTo is not suitable here because it
|
|
|
|
/// allows semantically unequivalent bitcasts, such as <2 x i64> -> <4 x i32>,
|
|
|
|
/// and also does not allow lossless pointer <-> integer conversions.
|
|
|
|
static bool isBitCastSemanticsPreserving(const DataLayout &DL, Type *FromTy,
|
|
|
|
Type *ToTy) {
|
|
|
|
// Trivially compatible types.
|
|
|
|
if (FromTy == ToTy)
|
|
|
|
return true;
|
|
|
|
|
|
|
|
// Handle compatible pointer <-> integer conversions.
|
|
|
|
if (FromTy->isIntOrPtrTy() && ToTy->isIntOrPtrTy()) {
|
|
|
|
bool SameSize = DL.getTypeSizeInBits(FromTy) == DL.getTypeSizeInBits(ToTy);
|
|
|
|
bool LosslessConversion = !DL.isNonIntegralPointerType(FromTy) &&
|
|
|
|
!DL.isNonIntegralPointerType(ToTy);
|
|
|
|
return SameSize && LosslessConversion;
|
|
|
|
}
|
|
|
|
|
|
|
|
// TODO: This is not exhaustive.
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool llvm::replaceAllDbgUsesWith(Instruction &From, Value &To,
|
|
|
|
Instruction &DomPoint, DominatorTree &DT) {
|
|
|
|
// Exit early if From has no debug users.
|
|
|
|
if (!From.isUsedByMetadata())
|
|
|
|
return false;
|
|
|
|
|
|
|
|
assert(&From != &To && "Can't replace something with itself");
|
|
|
|
|
|
|
|
Type *FromTy = From.getType();
|
|
|
|
Type *ToTy = To.getType();
|
|
|
|
|
2018-08-06 11:59:47 +08:00
|
|
|
auto Identity = [&](DbgVariableIntrinsic &DII) -> DbgValReplacement {
|
2018-07-07 01:32:39 +08:00
|
|
|
return DII.getExpression();
|
|
|
|
};
|
|
|
|
|
|
|
|
// Handle no-op conversions.
|
|
|
|
Module &M = *From.getModule();
|
|
|
|
const DataLayout &DL = M.getDataLayout();
|
|
|
|
if (isBitCastSemanticsPreserving(DL, FromTy, ToTy))
|
|
|
|
return rewriteDebugUsers(From, To, DomPoint, DT, Identity);
|
|
|
|
|
|
|
|
// Handle integer-to-integer widening and narrowing.
|
|
|
|
// FIXME: Use DW_OP_convert when it's available everywhere.
|
|
|
|
if (FromTy->isIntegerTy() && ToTy->isIntegerTy()) {
|
|
|
|
uint64_t FromBits = FromTy->getPrimitiveSizeInBits();
|
|
|
|
uint64_t ToBits = ToTy->getPrimitiveSizeInBits();
|
|
|
|
assert(FromBits != ToBits && "Unexpected no-op conversion");
|
|
|
|
|
|
|
|
// When the width of the result grows, assume that a debugger will only
|
|
|
|
// access the low `FromBits` bits when inspecting the source variable.
|
|
|
|
if (FromBits < ToBits)
|
|
|
|
return rewriteDebugUsers(From, To, DomPoint, DT, Identity);
|
|
|
|
|
|
|
|
// The width of the result has shrunk. Use sign/zero extension to describe
|
|
|
|
// the source variable's high bits.
|
2018-08-06 11:59:47 +08:00
|
|
|
auto SignOrZeroExt = [&](DbgVariableIntrinsic &DII) -> DbgValReplacement {
|
2018-07-07 01:32:39 +08:00
|
|
|
DILocalVariable *Var = DII.getVariable();
|
|
|
|
|
|
|
|
// Without knowing signedness, sign/zero extension isn't possible.
|
|
|
|
auto Signedness = Var->getSignedness();
|
|
|
|
if (!Signedness)
|
|
|
|
return None;
|
|
|
|
|
|
|
|
bool Signed = *Signedness == DIBasicType::Signedness::Signed;
|
|
|
|
|
|
|
|
if (!Signed) {
|
|
|
|
// In the unsigned case, assume that a debugger will initialize the
|
|
|
|
// high bits to 0 and do a no-op conversion.
|
|
|
|
return Identity(DII);
|
|
|
|
} else {
|
|
|
|
// In the signed case, the high bits are given by sign extension, i.e:
|
|
|
|
// (To >> (ToBits - 1)) * ((2 ^ FromBits) - 1)
|
|
|
|
// Calculate the high bits and OR them together with the low bits.
|
|
|
|
SmallVector<uint64_t, 8> Ops({dwarf::DW_OP_dup, dwarf::DW_OP_constu,
|
|
|
|
(ToBits - 1), dwarf::DW_OP_shr,
|
|
|
|
dwarf::DW_OP_lit0, dwarf::DW_OP_not,
|
|
|
|
dwarf::DW_OP_mul, dwarf::DW_OP_or});
|
|
|
|
return DIExpression::appendToStack(DII.getExpression(), Ops);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
return rewriteDebugUsers(From, To, DomPoint, DT, SignOrZeroExt);
|
|
|
|
}
|
|
|
|
|
|
|
|
// TODO: Floating-point conversions, vectors.
|
|
|
|
return false;
|
2018-06-21 00:50:25 +08:00
|
|
|
}
|
|
|
|
|
2016-01-24 13:26:18 +08:00
|
|
|
unsigned llvm::removeAllNonTerminatorAndEHPadInstructions(BasicBlock *BB) {
|
|
|
|
unsigned NumDeadInst = 0;
|
|
|
|
// Delete the instructions backwards, as it has a reduced likelihood of
|
|
|
|
// having to update as many def-use and use-def chains.
|
|
|
|
Instruction *EndInst = BB->getTerminator(); // Last not to be deleted.
|
2016-02-22 04:39:50 +08:00
|
|
|
while (EndInst != &BB->front()) {
|
2016-01-24 13:26:18 +08:00
|
|
|
// Delete the next to last instruction.
|
|
|
|
Instruction *Inst = &*--EndInst->getIterator();
|
|
|
|
if (!Inst->use_empty() && !Inst->getType()->isTokenTy())
|
|
|
|
Inst->replaceAllUsesWith(UndefValue::get(Inst->getType()));
|
|
|
|
if (Inst->isEHPad() || Inst->getType()->isTokenTy()) {
|
|
|
|
EndInst = Inst;
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
if (!isa<DbgInfoIntrinsic>(Inst))
|
|
|
|
++NumDeadInst;
|
|
|
|
Inst->eraseFromParent();
|
|
|
|
}
|
|
|
|
return NumDeadInst;
|
|
|
|
}
|
|
|
|
|
2016-11-19 05:01:12 +08:00
|
|
|
unsigned llvm::changeToUnreachable(Instruction *I, bool UseLLVMTrap,
|
2018-08-03 13:08:17 +08:00
|
|
|
bool PreserveLCSSA, DomTreeUpdater *DTU) {
|
2013-08-13 06:38:43 +08:00
|
|
|
BasicBlock *BB = I->getParent();
|
2018-01-13 05:06:48 +08:00
|
|
|
std::vector <DominatorTree::UpdateType> Updates;
|
|
|
|
|
2013-08-13 06:38:43 +08:00
|
|
|
// Loop over all of the successors, removing BB's entry from any PHI
|
|
|
|
// nodes.
|
2018-08-03 13:08:17 +08:00
|
|
|
if (DTU)
|
2018-01-13 05:06:48 +08:00
|
|
|
Updates.reserve(BB->getTerminator()->getNumSuccessors());
|
|
|
|
for (BasicBlock *Successor : successors(BB)) {
|
2016-11-19 05:01:12 +08:00
|
|
|
Successor->removePredecessor(BB, PreserveLCSSA);
|
2018-08-03 13:08:17 +08:00
|
|
|
if (DTU)
|
2018-01-13 05:06:48 +08:00
|
|
|
Updates.push_back({DominatorTree::Delete, BB, Successor});
|
|
|
|
}
|
2016-06-25 16:19:55 +08:00
|
|
|
// Insert a call to llvm.trap right before this. This turns the undefined
|
|
|
|
// behavior into a hard fail instead of falling through into random code.
|
|
|
|
if (UseLLVMTrap) {
|
|
|
|
Function *TrapFn =
|
|
|
|
Intrinsic::getDeclaration(BB->getParent()->getParent(), Intrinsic::trap);
|
|
|
|
CallInst *CallTrap = CallInst::Create(TrapFn, "", I);
|
|
|
|
CallTrap->setDebugLoc(I->getDebugLoc());
|
|
|
|
}
|
2018-08-08 04:21:56 +08:00
|
|
|
auto *UI = new UnreachableInst(I->getContext(), I);
|
|
|
|
UI->setDebugLoc(I->getDebugLoc());
|
2013-08-13 06:38:43 +08:00
|
|
|
|
|
|
|
// All instructions after this are dead.
|
2016-01-24 14:26:47 +08:00
|
|
|
unsigned NumInstrsRemoved = 0;
|
2015-10-13 10:39:05 +08:00
|
|
|
BasicBlock::iterator BBI = I->getIterator(), BBE = BB->end();
|
2013-08-13 06:38:43 +08:00
|
|
|
while (BBI != BBE) {
|
|
|
|
if (!BBI->use_empty())
|
|
|
|
BBI->replaceAllUsesWith(UndefValue::get(BBI->getType()));
|
|
|
|
BB->getInstList().erase(BBI++);
|
2016-01-24 14:26:47 +08:00
|
|
|
++NumInstrsRemoved;
|
2013-08-13 06:38:43 +08:00
|
|
|
}
|
2018-08-03 13:08:17 +08:00
|
|
|
if (DTU)
|
|
|
|
DTU->applyUpdates(Updates, /*ForceRemoveDuplicates*/ true);
|
2016-01-24 14:26:47 +08:00
|
|
|
return NumInstrsRemoved;
|
2013-08-13 06:38:43 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
/// changeToCall - Convert the specified invoke into a normal call.
|
2018-08-03 13:08:17 +08:00
|
|
|
static void changeToCall(InvokeInst *II, DomTreeUpdater *DTU = nullptr) {
|
2015-12-10 14:39:02 +08:00
|
|
|
SmallVector<Value*, 8> Args(II->arg_begin(), II->arg_end());
|
2015-12-09 06:26:08 +08:00
|
|
|
SmallVector<OperandBundleDef, 1> OpBundles;
|
|
|
|
II->getOperandBundlesAsDefs(OpBundles);
|
|
|
|
CallInst *NewCall = CallInst::Create(II->getCalledValue(), Args, OpBundles,
|
|
|
|
"", II);
|
2013-08-13 06:38:43 +08:00
|
|
|
NewCall->takeName(II);
|
|
|
|
NewCall->setCallingConv(II->getCallingConv());
|
|
|
|
NewCall->setAttributes(II->getAttributes());
|
|
|
|
NewCall->setDebugLoc(II->getDebugLoc());
|
|
|
|
II->replaceAllUsesWith(NewCall);
|
|
|
|
|
|
|
|
// Follow the call by a branch to the normal destination.
|
2018-01-13 05:06:48 +08:00
|
|
|
BasicBlock *NormalDestBB = II->getNormalDest();
|
|
|
|
BranchInst::Create(NormalDestBB, II);
|
2013-08-13 06:38:43 +08:00
|
|
|
|
|
|
|
// Update PHI nodes in the unwind destination
|
2018-01-13 05:06:48 +08:00
|
|
|
BasicBlock *BB = II->getParent();
|
|
|
|
BasicBlock *UnwindDestBB = II->getUnwindDest();
|
|
|
|
UnwindDestBB->removePredecessor(BB);
|
2013-08-13 06:38:43 +08:00
|
|
|
II->eraseFromParent();
|
2018-08-03 13:08:17 +08:00
|
|
|
if (DTU)
|
|
|
|
DTU->deleteEdgeRelaxed(BB, UnwindDestBB);
|
2013-08-13 06:38:43 +08:00
|
|
|
}
|
|
|
|
|
2016-11-15 05:41:13 +08:00
|
|
|
BasicBlock *llvm::changeToInvokeAndSplitBasicBlock(CallInst *CI,
|
|
|
|
BasicBlock *UnwindEdge) {
|
|
|
|
BasicBlock *BB = CI->getParent();
|
|
|
|
|
|
|
|
// Convert this function call into an invoke instruction. First, split the
|
|
|
|
// basic block.
|
|
|
|
BasicBlock *Split =
|
|
|
|
BB->splitBasicBlock(CI->getIterator(), CI->getName() + ".noexc");
|
|
|
|
|
|
|
|
// Delete the unconditional branch inserted by splitBasicBlock
|
|
|
|
BB->getInstList().pop_back();
|
|
|
|
|
|
|
|
// Create the new invoke instruction.
|
|
|
|
SmallVector<Value *, 8> InvokeArgs(CI->arg_begin(), CI->arg_end());
|
|
|
|
SmallVector<OperandBundleDef, 1> OpBundles;
|
|
|
|
|
|
|
|
CI->getOperandBundlesAsDefs(OpBundles);
|
|
|
|
|
|
|
|
// Note: we're round tripping operand bundles through memory here, and that
|
|
|
|
// can potentially be avoided with a cleverer API design that we do not have
|
|
|
|
// as of this time.
|
|
|
|
|
|
|
|
InvokeInst *II = InvokeInst::Create(CI->getCalledValue(), Split, UnwindEdge,
|
|
|
|
InvokeArgs, OpBundles, CI->getName(), BB);
|
|
|
|
II->setDebugLoc(CI->getDebugLoc());
|
|
|
|
II->setCallingConv(CI->getCallingConv());
|
|
|
|
II->setAttributes(CI->getAttributes());
|
|
|
|
|
|
|
|
// Make sure that anything using the call now uses the invoke! This also
|
2017-05-02 01:07:49 +08:00
|
|
|
// updates the CallGraph if present, because it uses a WeakTrackingVH.
|
2016-11-15 05:41:13 +08:00
|
|
|
CI->replaceAllUsesWith(II);
|
|
|
|
|
|
|
|
// Delete the original call
|
|
|
|
Split->getInstList().pop_front();
|
|
|
|
return Split;
|
|
|
|
}
|
|
|
|
|
2015-06-18 04:52:32 +08:00
|
|
|
static bool markAliveBlocks(Function &F,
|
2018-08-03 13:08:17 +08:00
|
|
|
SmallPtrSetImpl<BasicBlock *> &Reachable,
|
|
|
|
DomTreeUpdater *DTU = nullptr) {
|
2012-12-21 19:18:49 +08:00
|
|
|
SmallVector<BasicBlock*, 128> Worklist;
|
2015-10-13 10:39:05 +08:00
|
|
|
BasicBlock *BB = &F.front();
|
2013-08-13 06:38:43 +08:00
|
|
|
Worklist.push_back(BB);
|
|
|
|
Reachable.insert(BB);
|
|
|
|
bool Changed = false;
|
2012-12-21 19:18:49 +08:00
|
|
|
do {
|
2013-08-13 06:38:43 +08:00
|
|
|
BB = Worklist.pop_back_val();
|
|
|
|
|
|
|
|
// Do a quick scan of the basic block, turning any obviously unreachable
|
|
|
|
// instructions into LLVM unreachable insts. The instruction combining pass
|
|
|
|
// canonicalizes unreachable insts into stores to null or undef.
|
2016-06-25 16:34:38 +08:00
|
|
|
for (Instruction &I : *BB) {
|
2018-07-19 02:40:45 +08:00
|
|
|
if (auto *CI = dyn_cast<CallInst>(&I)) {
|
|
|
|
Value *Callee = CI->getCalledValue();
|
|
|
|
// Handle intrinsic calls.
|
|
|
|
if (Function *F = dyn_cast<Function>(Callee)) {
|
|
|
|
auto IntrinsicID = F->getIntrinsicID();
|
|
|
|
// Assumptions that are known to be false are equivalent to
|
|
|
|
// unreachable. Also, if the condition is undefined, then we make the
|
|
|
|
// choice most beneficial to the optimizer, and choose that to also be
|
|
|
|
// unreachable.
|
|
|
|
if (IntrinsicID == Intrinsic::assume) {
|
|
|
|
if (match(CI->getArgOperand(0), m_CombineOr(m_Zero(), m_Undef()))) {
|
|
|
|
// Don't insert a call to llvm.trap right before the unreachable.
|
2018-08-03 13:08:17 +08:00
|
|
|
changeToUnreachable(CI, false, false, DTU);
|
2016-04-21 13:09:12 +08:00
|
|
|
Changed = true;
|
|
|
|
break;
|
|
|
|
}
|
2018-07-19 02:40:45 +08:00
|
|
|
} else if (IntrinsicID == Intrinsic::experimental_guard) {
|
|
|
|
// A call to the guard intrinsic bails out of the current
|
|
|
|
// compilation unit if the predicate passed to it is false. If the
|
|
|
|
// predicate is a constant false, then we know the guard will bail
|
|
|
|
// out of the current compile unconditionally, so all code following
|
|
|
|
// it is dead.
|
|
|
|
//
|
|
|
|
// Note: unlike in llvm.assume, it is not "obviously profitable" for
|
|
|
|
// guards to treat `undef` as `false` since a guard on `undef` can
|
|
|
|
// still be useful for widening.
|
|
|
|
if (match(CI->getArgOperand(0), m_Zero()))
|
|
|
|
if (!isa<UnreachableInst>(CI->getNextNode())) {
|
|
|
|
changeToUnreachable(CI->getNextNode(), /*UseLLVMTrap=*/false,
|
2018-08-03 13:08:17 +08:00
|
|
|
false, DTU);
|
2018-07-19 02:40:45 +08:00
|
|
|
Changed = true;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} else if ((isa<ConstantPointerNull>(Callee) &&
|
|
|
|
!NullPointerIsDefined(CI->getFunction())) ||
|
|
|
|
isa<UndefValue>(Callee)) {
|
2018-08-03 13:08:17 +08:00
|
|
|
changeToUnreachable(CI, /*UseLLVMTrap=*/false, false, DTU);
|
2016-06-25 15:37:27 +08:00
|
|
|
Changed = true;
|
|
|
|
break;
|
|
|
|
}
|
2013-08-13 06:38:43 +08:00
|
|
|
if (CI->doesNotReturn()) {
|
|
|
|
// If we found a call to a no-return function, insert an unreachable
|
|
|
|
// instruction after it. Make sure there isn't *already* one there
|
|
|
|
// though.
|
2016-06-25 16:34:38 +08:00
|
|
|
if (!isa<UnreachableInst>(CI->getNextNode())) {
|
2016-06-25 16:19:55 +08:00
|
|
|
// Don't insert a call to llvm.trap right before the unreachable.
|
2018-08-03 13:08:17 +08:00
|
|
|
changeToUnreachable(CI->getNextNode(), false, false, DTU);
|
2013-08-13 06:38:43 +08:00
|
|
|
Changed = true;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
2018-07-19 02:40:45 +08:00
|
|
|
} else if (auto *SI = dyn_cast<StoreInst>(&I)) {
|
|
|
|
// Store to undef and store to null are undefined and used to signal
|
|
|
|
// that they should be changed to unreachable by passes that can't
|
|
|
|
// modify the CFG.
|
2013-08-13 06:38:43 +08:00
|
|
|
|
|
|
|
// Don't touch volatile stores.
|
|
|
|
if (SI->isVolatile()) continue;
|
|
|
|
|
|
|
|
Value *Ptr = SI->getOperand(1);
|
|
|
|
|
|
|
|
if (isa<UndefValue>(Ptr) ||
|
|
|
|
(isa<ConstantPointerNull>(Ptr) &&
|
llvm: Add support for "-fno-delete-null-pointer-checks"
Summary:
Support for this option is needed for building Linux kernel.
This is a very frequently requested feature by kernel developers.
More details : https://lkml.org/lkml/2018/4/4/601
GCC option description for -fdelete-null-pointer-checks:
This Assume that programs cannot safely dereference null pointers,
and that no code or data element resides at address zero.
-fno-delete-null-pointer-checks is the inverse of this implying that
null pointer dereferencing is not undefined.
This feature is implemented in LLVM IR in this CL as the function attribute
"null-pointer-is-valid"="true" in IR (Under review at D47894).
The CL updates several passes that assumed null pointer dereferencing is
undefined to not optimize when the "null-pointer-is-valid"="true"
attribute is present.
Reviewers: t.p.northover, efriedma, jyknight, chandlerc, rnk, srhines, void, george.burgess.iv
Reviewed By: efriedma, george.burgess.iv
Subscribers: eraman, haicheng, george.burgess.iv, drinkcat, theraven, reames, sanjoy, xbolva00, llvm-commits
Differential Revision: https://reviews.llvm.org/D47895
llvm-svn: 336613
2018-07-10 06:27:23 +08:00
|
|
|
!NullPointerIsDefined(SI->getFunction(),
|
|
|
|
SI->getPointerAddressSpace()))) {
|
2018-08-03 13:08:17 +08:00
|
|
|
changeToUnreachable(SI, true, false, DTU);
|
2013-08-13 06:38:43 +08:00
|
|
|
Changed = true;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-10-15 18:04:59 +08:00
|
|
|
Instruction *Terminator = BB->getTerminator();
|
2016-01-05 14:27:50 +08:00
|
|
|
if (auto *II = dyn_cast<InvokeInst>(Terminator)) {
|
|
|
|
// Turn invokes that call 'nounwind' functions into ordinary calls.
|
2013-08-13 06:38:43 +08:00
|
|
|
Value *Callee = II->getCalledValue();
|
llvm: Add support for "-fno-delete-null-pointer-checks"
Summary:
Support for this option is needed for building Linux kernel.
This is a very frequently requested feature by kernel developers.
More details : https://lkml.org/lkml/2018/4/4/601
GCC option description for -fdelete-null-pointer-checks:
This Assume that programs cannot safely dereference null pointers,
and that no code or data element resides at address zero.
-fno-delete-null-pointer-checks is the inverse of this implying that
null pointer dereferencing is not undefined.
This feature is implemented in LLVM IR in this CL as the function attribute
"null-pointer-is-valid"="true" in IR (Under review at D47894).
The CL updates several passes that assumed null pointer dereferencing is
undefined to not optimize when the "null-pointer-is-valid"="true"
attribute is present.
Reviewers: t.p.northover, efriedma, jyknight, chandlerc, rnk, srhines, void, george.burgess.iv
Reviewed By: efriedma, george.burgess.iv
Subscribers: eraman, haicheng, george.burgess.iv, drinkcat, theraven, reames, sanjoy, xbolva00, llvm-commits
Differential Revision: https://reviews.llvm.org/D47895
llvm-svn: 336613
2018-07-10 06:27:23 +08:00
|
|
|
if ((isa<ConstantPointerNull>(Callee) &&
|
|
|
|
!NullPointerIsDefined(BB->getParent())) ||
|
|
|
|
isa<UndefValue>(Callee)) {
|
2018-08-03 13:08:17 +08:00
|
|
|
changeToUnreachable(II, true, false, DTU);
|
2013-08-13 06:38:43 +08:00
|
|
|
Changed = true;
|
2015-06-18 04:52:32 +08:00
|
|
|
} else if (II->doesNotThrow() && canSimplifyInvokeNoUnwind(&F)) {
|
2013-08-13 06:38:43 +08:00
|
|
|
if (II->use_empty() && II->onlyReadsMemory()) {
|
|
|
|
// jump to the normal destination branch.
|
2018-01-13 05:06:48 +08:00
|
|
|
BasicBlock *NormalDestBB = II->getNormalDest();
|
|
|
|
BasicBlock *UnwindDestBB = II->getUnwindDest();
|
|
|
|
BranchInst::Create(NormalDestBB, II);
|
|
|
|
UnwindDestBB->removePredecessor(II->getParent());
|
2013-08-13 06:38:43 +08:00
|
|
|
II->eraseFromParent();
|
2018-08-03 13:08:17 +08:00
|
|
|
if (DTU)
|
|
|
|
DTU->deleteEdgeRelaxed(BB, UnwindDestBB);
|
2013-08-13 06:38:43 +08:00
|
|
|
} else
|
2018-08-03 13:08:17 +08:00
|
|
|
changeToCall(II, DTU);
|
2013-08-13 06:38:43 +08:00
|
|
|
Changed = true;
|
|
|
|
}
|
2016-01-05 14:27:50 +08:00
|
|
|
} else if (auto *CatchSwitch = dyn_cast<CatchSwitchInst>(Terminator)) {
|
|
|
|
// Remove catchpads which cannot be reached.
|
2016-01-05 15:42:17 +08:00
|
|
|
struct CatchPadDenseMapInfo {
|
|
|
|
static CatchPadInst *getEmptyKey() {
|
|
|
|
return DenseMapInfo<CatchPadInst *>::getEmptyKey();
|
|
|
|
}
|
2017-10-18 05:27:42 +08:00
|
|
|
|
2016-01-05 15:42:17 +08:00
|
|
|
static CatchPadInst *getTombstoneKey() {
|
|
|
|
return DenseMapInfo<CatchPadInst *>::getTombstoneKey();
|
|
|
|
}
|
2017-10-18 05:27:42 +08:00
|
|
|
|
2016-01-05 15:42:17 +08:00
|
|
|
static unsigned getHashValue(CatchPadInst *CatchPad) {
|
|
|
|
return static_cast<unsigned>(hash_combine_range(
|
|
|
|
CatchPad->value_op_begin(), CatchPad->value_op_end()));
|
|
|
|
}
|
2017-10-18 05:27:42 +08:00
|
|
|
|
2016-01-05 15:42:17 +08:00
|
|
|
static bool isEqual(CatchPadInst *LHS, CatchPadInst *RHS) {
|
|
|
|
if (LHS == getEmptyKey() || LHS == getTombstoneKey() ||
|
|
|
|
RHS == getEmptyKey() || RHS == getTombstoneKey())
|
|
|
|
return LHS == RHS;
|
|
|
|
return LHS->isIdenticalTo(RHS);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
// Set of unique CatchPads.
|
|
|
|
SmallDenseMap<CatchPadInst *, detail::DenseSetEmpty, 4,
|
|
|
|
CatchPadDenseMapInfo, detail::DenseSetPair<CatchPadInst *>>
|
|
|
|
HandlerSet;
|
|
|
|
detail::DenseSetEmpty Empty;
|
2016-01-05 14:27:50 +08:00
|
|
|
for (CatchSwitchInst::handler_iterator I = CatchSwitch->handler_begin(),
|
|
|
|
E = CatchSwitch->handler_end();
|
|
|
|
I != E; ++I) {
|
|
|
|
BasicBlock *HandlerBB = *I;
|
2016-01-05 15:42:17 +08:00
|
|
|
auto *CatchPad = cast<CatchPadInst>(HandlerBB->getFirstNonPHI());
|
|
|
|
if (!HandlerSet.insert({CatchPad, Empty}).second) {
|
2016-01-05 14:27:50 +08:00
|
|
|
CatchSwitch->removeHandler(I);
|
|
|
|
--I;
|
|
|
|
--E;
|
|
|
|
Changed = true;
|
|
|
|
}
|
|
|
|
}
|
2013-08-13 06:38:43 +08:00
|
|
|
}
|
|
|
|
|
2018-08-03 13:08:17 +08:00
|
|
|
Changed |= ConstantFoldTerminator(BB, true, nullptr, DTU);
|
2016-06-25 16:34:38 +08:00
|
|
|
for (BasicBlock *Successor : successors(BB))
|
|
|
|
if (Reachable.insert(Successor).second)
|
|
|
|
Worklist.push_back(Successor);
|
2012-12-21 19:18:49 +08:00
|
|
|
} while (!Worklist.empty());
|
2013-08-13 06:38:43 +08:00
|
|
|
return Changed;
|
|
|
|
}
|
|
|
|
|
2018-08-03 13:08:17 +08:00
|
|
|
void llvm::removeUnwindEdge(BasicBlock *BB, DomTreeUpdater *DTU) {
|
2018-10-15 18:04:59 +08:00
|
|
|
Instruction *TI = BB->getTerminator();
|
2015-09-27 09:47:46 +08:00
|
|
|
|
|
|
|
if (auto *II = dyn_cast<InvokeInst>(TI)) {
|
2018-08-03 13:08:17 +08:00
|
|
|
changeToCall(II, DTU);
|
2015-09-27 09:47:46 +08:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2018-10-18 08:39:18 +08:00
|
|
|
Instruction *NewTI;
|
2015-09-27 09:47:46 +08:00
|
|
|
BasicBlock *UnwindDest;
|
|
|
|
|
|
|
|
if (auto *CRI = dyn_cast<CleanupReturnInst>(TI)) {
|
|
|
|
NewTI = CleanupReturnInst::Create(CRI->getCleanupPad(), nullptr, CRI);
|
|
|
|
UnwindDest = CRI->getUnwindDest();
|
[IR] Reformulate LLVM's EH funclet IR
While we have successfully implemented a funclet-oriented EH scheme on
top of LLVM IR, our scheme has some notable deficiencies:
- catchendpad and cleanupendpad are necessary in the current design
but they are difficult to explain to others, even to seasoned LLVM
experts.
- catchendpad and cleanupendpad are optimization barriers. They cannot
be split and force all potentially throwing call-sites to be invokes.
This has a noticable effect on the quality of our code generation.
- catchpad, while similar in some aspects to invoke, is fairly awkward.
It is unsplittable, starts a funclet, and has control flow to other
funclets.
- The nesting relationship between funclets is currently a property of
control flow edges. Because of this, we are forced to carefully
analyze the flow graph to see if there might potentially exist illegal
nesting among funclets. While we have logic to clone funclets when
they are illegally nested, it would be nicer if we had a
representation which forbade them upfront.
Let's clean this up a bit by doing the following:
- Instead, make catchpad more like cleanuppad and landingpad: no control
flow, just a bunch of simple operands; catchpad would be splittable.
- Introduce catchswitch, a control flow instruction designed to model
the constraints of funclet oriented EH.
- Make funclet scoping explicit by having funclet instructions consume
the token produced by the funclet which contains them.
- Remove catchendpad and cleanupendpad. Their presence can be inferred
implicitly using coloring information.
N.B. The state numbering code for the CLR has been updated but the
veracity of it's output cannot be spoken for. An expert should take a
look to make sure the results are reasonable.
Reviewers: rnk, JosephTremoulet, andrew.w.kaylor
Differential Revision: http://reviews.llvm.org/D15139
llvm-svn: 255422
2015-12-12 13:38:55 +08:00
|
|
|
} else if (auto *CatchSwitch = dyn_cast<CatchSwitchInst>(TI)) {
|
|
|
|
auto *NewCatchSwitch = CatchSwitchInst::Create(
|
|
|
|
CatchSwitch->getParentPad(), nullptr, CatchSwitch->getNumHandlers(),
|
|
|
|
CatchSwitch->getName(), CatchSwitch);
|
|
|
|
for (BasicBlock *PadBB : CatchSwitch->handlers())
|
|
|
|
NewCatchSwitch->addHandler(PadBB);
|
|
|
|
|
|
|
|
NewTI = NewCatchSwitch;
|
|
|
|
UnwindDest = CatchSwitch->getUnwindDest();
|
2015-09-27 09:47:46 +08:00
|
|
|
} else {
|
|
|
|
llvm_unreachable("Could not find unwind successor");
|
|
|
|
}
|
|
|
|
|
|
|
|
NewTI->takeName(TI);
|
|
|
|
NewTI->setDebugLoc(TI->getDebugLoc());
|
|
|
|
UnwindDest->removePredecessor(BB);
|
[IR] Reformulate LLVM's EH funclet IR
While we have successfully implemented a funclet-oriented EH scheme on
top of LLVM IR, our scheme has some notable deficiencies:
- catchendpad and cleanupendpad are necessary in the current design
but they are difficult to explain to others, even to seasoned LLVM
experts.
- catchendpad and cleanupendpad are optimization barriers. They cannot
be split and force all potentially throwing call-sites to be invokes.
This has a noticable effect on the quality of our code generation.
- catchpad, while similar in some aspects to invoke, is fairly awkward.
It is unsplittable, starts a funclet, and has control flow to other
funclets.
- The nesting relationship between funclets is currently a property of
control flow edges. Because of this, we are forced to carefully
analyze the flow graph to see if there might potentially exist illegal
nesting among funclets. While we have logic to clone funclets when
they are illegally nested, it would be nicer if we had a
representation which forbade them upfront.
Let's clean this up a bit by doing the following:
- Instead, make catchpad more like cleanuppad and landingpad: no control
flow, just a bunch of simple operands; catchpad would be splittable.
- Introduce catchswitch, a control flow instruction designed to model
the constraints of funclet oriented EH.
- Make funclet scoping explicit by having funclet instructions consume
the token produced by the funclet which contains them.
- Remove catchendpad and cleanupendpad. Their presence can be inferred
implicitly using coloring information.
N.B. The state numbering code for the CLR has been updated but the
veracity of it's output cannot be spoken for. An expert should take a
look to make sure the results are reasonable.
Reviewers: rnk, JosephTremoulet, andrew.w.kaylor
Differential Revision: http://reviews.llvm.org/D15139
llvm-svn: 255422
2015-12-12 13:38:55 +08:00
|
|
|
TI->replaceAllUsesWith(NewTI);
|
2015-09-27 09:47:46 +08:00
|
|
|
TI->eraseFromParent();
|
2018-08-03 13:08:17 +08:00
|
|
|
if (DTU)
|
|
|
|
DTU->deleteEdgeRelaxed(BB, UnwindDest);
|
2015-09-27 09:47:46 +08:00
|
|
|
}
|
|
|
|
|
2017-07-08 02:54:14 +08:00
|
|
|
/// removeUnreachableBlocks - Remove blocks that are not reachable, even
|
2013-08-13 06:38:43 +08:00
|
|
|
/// if they are in a dead cycle. Return true if a change was made, false
|
2017-07-08 02:54:14 +08:00
|
|
|
/// otherwise. If `LVI` is passed, this function preserves LazyValueInfo
|
|
|
|
/// after modifying the CFG.
|
2018-01-13 05:06:48 +08:00
|
|
|
bool llvm::removeUnreachableBlocks(Function &F, LazyValueInfo *LVI,
|
2018-08-17 05:58:44 +08:00
|
|
|
DomTreeUpdater *DTU,
|
|
|
|
MemorySSAUpdater *MSSAU) {
|
2016-01-30 09:24:31 +08:00
|
|
|
SmallPtrSet<BasicBlock*, 16> Reachable;
|
2018-08-03 13:08:17 +08:00
|
|
|
bool Changed = markAliveBlocks(F, Reachable, DTU);
|
2012-12-21 19:18:49 +08:00
|
|
|
|
2013-08-13 06:38:43 +08:00
|
|
|
// If there are unreachable blocks in the CFG...
|
2012-12-21 19:18:49 +08:00
|
|
|
if (Reachable.size() == F.size())
|
2013-08-13 06:38:43 +08:00
|
|
|
return Changed;
|
2012-12-21 19:18:49 +08:00
|
|
|
|
|
|
|
assert(Reachable.size() < F.size());
|
2013-08-13 06:38:43 +08:00
|
|
|
NumRemoved += F.size()-Reachable.size();
|
|
|
|
|
2018-08-17 05:58:44 +08:00
|
|
|
SmallPtrSet<BasicBlock *, 16> DeadBlockSet;
|
2018-01-13 05:06:48 +08:00
|
|
|
for (Function::iterator I = ++F.begin(), E = F.end(); I != E; ++I) {
|
|
|
|
auto *BB = &*I;
|
|
|
|
if (Reachable.count(BB))
|
2012-12-21 19:18:49 +08:00
|
|
|
continue;
|
2018-08-17 05:58:44 +08:00
|
|
|
DeadBlockSet.insert(BB);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (MSSAU)
|
|
|
|
MSSAU->removeBlocks(DeadBlockSet);
|
|
|
|
|
|
|
|
// Loop over all of the basic blocks that are not reachable, dropping all of
|
|
|
|
// their internal references. Update DTU and LVI if available.
|
|
|
|
std::vector<DominatorTree::UpdateType> Updates;
|
|
|
|
for (auto *BB : DeadBlockSet) {
|
2018-01-13 05:06:48 +08:00
|
|
|
for (BasicBlock *Successor : successors(BB)) {
|
2018-08-17 05:58:44 +08:00
|
|
|
if (!DeadBlockSet.count(Successor))
|
2018-01-13 05:06:48 +08:00
|
|
|
Successor->removePredecessor(BB);
|
2018-08-03 13:08:17 +08:00
|
|
|
if (DTU)
|
2018-01-13 05:06:48 +08:00
|
|
|
Updates.push_back({DominatorTree::Delete, BB, Successor});
|
|
|
|
}
|
2016-01-10 15:13:04 +08:00
|
|
|
if (LVI)
|
2018-01-13 05:06:48 +08:00
|
|
|
LVI->eraseBlock(BB);
|
2013-08-13 06:38:43 +08:00
|
|
|
BB->dropAllReferences();
|
2013-03-22 16:43:04 +08:00
|
|
|
}
|
2018-01-13 05:06:48 +08:00
|
|
|
for (Function::iterator I = ++F.begin(); I != F.end();) {
|
|
|
|
auto *BB = &*I;
|
|
|
|
if (Reachable.count(BB)) {
|
|
|
|
++I;
|
|
|
|
continue;
|
|
|
|
}
|
2018-08-03 13:08:17 +08:00
|
|
|
if (DTU) {
|
2018-10-18 08:39:18 +08:00
|
|
|
// Remove the terminator of BB to clear the successor list of BB.
|
2018-08-03 13:08:17 +08:00
|
|
|
if (BB->getTerminator())
|
|
|
|
BB->getInstList().pop_back();
|
|
|
|
new UnreachableInst(BB->getContext(), BB);
|
|
|
|
assert(succ_empty(BB) && "The successor list of BB isn't empty before "
|
|
|
|
"applying corresponding DTU updates.");
|
2018-01-05 07:23:46 +08:00
|
|
|
++I;
|
2018-01-13 05:06:48 +08:00
|
|
|
} else {
|
|
|
|
I = F.getBasicBlockList().erase(I);
|
|
|
|
}
|
|
|
|
}
|
2012-12-21 19:18:49 +08:00
|
|
|
|
2018-08-03 13:08:17 +08:00
|
|
|
if (DTU) {
|
|
|
|
DTU->applyUpdates(Updates, /*ForceRemoveDuplicates*/ true);
|
[Dominators] Make RemoveUnreachableBlocks return false if the BasicBlock is already awaiting deletion
Summary:
Previously, `removeUnreachableBlocks` still returns true (which indicates the CFG is changed) even when all the unreachable blocks found is awaiting deletion in the DDT class.
This makes code pattern like
```
// Code modified from lib/Transforms/Scalar/SimplifyCFGPass.cpp
bool EverChanged = removeUnreachableBlocks(F, nullptr, DDT);
...
do {
EverChanged = someMightHappenModifications();
EverChanged |= removeUnreachableBlocks(F, nullptr, DDT);
} while (EverChanged);
```
become a dead loop.
Fix this by detecting whether a BasicBlock is already awaiting deletion.
Reviewers: kuhar, brzycki, dmgreen, grosser, davide
Reviewed By: kuhar, brzycki
Subscribers: llvm-commits
Differential Revision: https://reviews.llvm.org/D49738
llvm-svn: 338882
2018-08-03 20:45:29 +08:00
|
|
|
bool Deleted = false;
|
2018-08-17 05:58:44 +08:00
|
|
|
for (auto *BB : DeadBlockSet) {
|
[Dominators] Make RemoveUnreachableBlocks return false if the BasicBlock is already awaiting deletion
Summary:
Previously, `removeUnreachableBlocks` still returns true (which indicates the CFG is changed) even when all the unreachable blocks found is awaiting deletion in the DDT class.
This makes code pattern like
```
// Code modified from lib/Transforms/Scalar/SimplifyCFGPass.cpp
bool EverChanged = removeUnreachableBlocks(F, nullptr, DDT);
...
do {
EverChanged = someMightHappenModifications();
EverChanged |= removeUnreachableBlocks(F, nullptr, DDT);
} while (EverChanged);
```
become a dead loop.
Fix this by detecting whether a BasicBlock is already awaiting deletion.
Reviewers: kuhar, brzycki, dmgreen, grosser, davide
Reviewed By: kuhar, brzycki
Subscribers: llvm-commits
Differential Revision: https://reviews.llvm.org/D49738
llvm-svn: 338882
2018-08-03 20:45:29 +08:00
|
|
|
if (DTU->isBBPendingDeletion(BB))
|
|
|
|
--NumRemoved;
|
|
|
|
else
|
|
|
|
Deleted = true;
|
2018-08-03 13:08:17 +08:00
|
|
|
DTU->deleteBB(BB);
|
[Dominators] Make RemoveUnreachableBlocks return false if the BasicBlock is already awaiting deletion
Summary:
Previously, `removeUnreachableBlocks` still returns true (which indicates the CFG is changed) even when all the unreachable blocks found is awaiting deletion in the DDT class.
This makes code pattern like
```
// Code modified from lib/Transforms/Scalar/SimplifyCFGPass.cpp
bool EverChanged = removeUnreachableBlocks(F, nullptr, DDT);
...
do {
EverChanged = someMightHappenModifications();
EverChanged |= removeUnreachableBlocks(F, nullptr, DDT);
} while (EverChanged);
```
become a dead loop.
Fix this by detecting whether a BasicBlock is already awaiting deletion.
Reviewers: kuhar, brzycki, dmgreen, grosser, davide
Reviewed By: kuhar, brzycki
Subscribers: llvm-commits
Differential Revision: https://reviews.llvm.org/D49738
llvm-svn: 338882
2018-08-03 20:45:29 +08:00
|
|
|
}
|
|
|
|
if (!Deleted)
|
|
|
|
return false;
|
2018-08-03 13:08:17 +08:00
|
|
|
}
|
2012-12-21 19:18:49 +08:00
|
|
|
return true;
|
|
|
|
}
|
2014-08-15 23:46:38 +08:00
|
|
|
|
2015-10-03 06:12:22 +08:00
|
|
|
void llvm::combineMetadata(Instruction *K, const Instruction *J,
|
2018-08-07 23:36:11 +08:00
|
|
|
ArrayRef<unsigned> KnownIDs, bool DoesKMove) {
|
2014-11-12 05:30:22 +08:00
|
|
|
SmallVector<std::pair<unsigned, MDNode *>, 4> Metadata;
|
2015-08-21 06:00:30 +08:00
|
|
|
K->dropUnknownNonDebugMetadata(KnownIDs);
|
2014-08-15 23:46:38 +08:00
|
|
|
K->getAllMetadataOtherThanDebugLoc(Metadata);
|
2016-07-25 10:21:19 +08:00
|
|
|
for (const auto &MD : Metadata) {
|
|
|
|
unsigned Kind = MD.first;
|
2014-11-12 05:30:22 +08:00
|
|
|
MDNode *JMD = J->getMetadata(Kind);
|
2016-07-25 10:21:19 +08:00
|
|
|
MDNode *KMD = MD.second;
|
2014-08-15 23:46:38 +08:00
|
|
|
|
|
|
|
switch (Kind) {
|
|
|
|
default:
|
|
|
|
K->setMetadata(Kind, nullptr); // Remove unknown metadata
|
|
|
|
break;
|
|
|
|
case LLVMContext::MD_dbg:
|
|
|
|
llvm_unreachable("getAllMetadataOtherThanDebugLoc returned a MD_dbg");
|
|
|
|
case LLVMContext::MD_tbaa:
|
|
|
|
K->setMetadata(Kind, MDNode::getMostGenericTBAA(JMD, KMD));
|
|
|
|
break;
|
|
|
|
case LLVMContext::MD_alias_scope:
|
2015-02-09 01:07:14 +08:00
|
|
|
K->setMetadata(Kind, MDNode::getMostGenericAliasScope(JMD, KMD));
|
|
|
|
break;
|
2014-08-15 23:46:38 +08:00
|
|
|
case LLVMContext::MD_noalias:
|
2016-04-26 10:06:06 +08:00
|
|
|
case LLVMContext::MD_mem_parallel_loop_access:
|
2014-08-15 23:46:38 +08:00
|
|
|
K->setMetadata(Kind, MDNode::intersect(JMD, KMD));
|
|
|
|
break;
|
|
|
|
case LLVMContext::MD_range:
|
|
|
|
K->setMetadata(Kind, MDNode::getMostGenericRange(JMD, KMD));
|
|
|
|
break;
|
|
|
|
case LLVMContext::MD_fpmath:
|
|
|
|
K->setMetadata(Kind, MDNode::getMostGenericFPMath(JMD, KMD));
|
|
|
|
break;
|
|
|
|
case LLVMContext::MD_invariant_load:
|
|
|
|
// Only set the !invariant.load if it is present in both instructions.
|
|
|
|
K->setMetadata(Kind, JMD);
|
|
|
|
break;
|
2014-10-22 05:02:19 +08:00
|
|
|
case LLVMContext::MD_nonnull:
|
2018-08-07 23:36:11 +08:00
|
|
|
// If K does move, keep nonull if it is present in both instructions.
|
|
|
|
if (DoesKMove)
|
|
|
|
K->setMetadata(Kind, JMD);
|
2014-10-22 05:02:19 +08:00
|
|
|
break;
|
2015-10-03 06:12:22 +08:00
|
|
|
case LLVMContext::MD_invariant_group:
|
|
|
|
// Preserve !invariant.group in K.
|
|
|
|
break;
|
2015-11-03 01:53:51 +08:00
|
|
|
case LLVMContext::MD_align:
|
2017-06-26 11:31:31 +08:00
|
|
|
K->setMetadata(Kind,
|
2015-11-03 01:53:51 +08:00
|
|
|
MDNode::getMostGenericAlignmentOrDereferenceable(JMD, KMD));
|
|
|
|
break;
|
|
|
|
case LLVMContext::MD_dereferenceable:
|
|
|
|
case LLVMContext::MD_dereferenceable_or_null:
|
2017-06-26 11:31:31 +08:00
|
|
|
K->setMetadata(Kind,
|
2015-11-03 01:53:51 +08:00
|
|
|
MDNode::getMostGenericAlignmentOrDereferenceable(JMD, KMD));
|
|
|
|
break;
|
2014-08-15 23:46:38 +08:00
|
|
|
}
|
|
|
|
}
|
2015-10-03 06:12:22 +08:00
|
|
|
// Set !invariant.group from J if J has it. If both instructions have it
|
|
|
|
// then we will just pick it from J - even when they are different.
|
|
|
|
// Also make sure that K is load or store - f.e. combining bitcast with load
|
|
|
|
// could produce bitcast with invariant.group metadata, which is invalid.
|
|
|
|
// FIXME: we should try to preserve both invariant.group md if they are
|
|
|
|
// different, but right now instruction can only have one invariant.group.
|
|
|
|
if (auto *JMD = J->getMetadata(LLVMContext::MD_invariant_group))
|
|
|
|
if (isa<LoadInst>(K) || isa<StoreInst>(K))
|
|
|
|
K->setMetadata(LLVMContext::MD_invariant_group, JMD);
|
2014-08-15 23:46:38 +08:00
|
|
|
}
|
2015-05-23 07:53:24 +08:00
|
|
|
|
2018-08-24 19:40:04 +08:00
|
|
|
void llvm::combineMetadataForCSE(Instruction *K, const Instruction *J,
|
|
|
|
bool KDominatesJ) {
|
2016-08-08 12:10:22 +08:00
|
|
|
unsigned KnownIDs[] = {
|
|
|
|
LLVMContext::MD_tbaa, LLVMContext::MD_alias_scope,
|
|
|
|
LLVMContext::MD_noalias, LLVMContext::MD_range,
|
|
|
|
LLVMContext::MD_invariant_load, LLVMContext::MD_nonnull,
|
|
|
|
LLVMContext::MD_invariant_group, LLVMContext::MD_align,
|
|
|
|
LLVMContext::MD_dereferenceable,
|
|
|
|
LLVMContext::MD_dereferenceable_or_null};
|
2018-08-24 19:40:04 +08:00
|
|
|
combineMetadata(K, J, KnownIDs, KDominatesJ);
|
2016-08-08 12:10:22 +08:00
|
|
|
}
|
|
|
|
|
2018-08-07 21:27:33 +08:00
|
|
|
void llvm::patchReplacementInstruction(Instruction *I, Value *Repl) {
|
|
|
|
auto *ReplInst = dyn_cast<Instruction>(Repl);
|
|
|
|
if (!ReplInst)
|
|
|
|
return;
|
|
|
|
|
|
|
|
// Patch the replacement so that it is not more restrictive than the value
|
|
|
|
// being replaced.
|
|
|
|
// Note that if 'I' is a load being replaced by some operation,
|
|
|
|
// for example, by an arithmetic operation, then andIRFlags()
|
|
|
|
// would just erase all math flags from the original arithmetic
|
|
|
|
// operation, which is clearly not wanted and not needed.
|
|
|
|
if (!isa<LoadInst>(I))
|
|
|
|
ReplInst->andIRFlags(I);
|
|
|
|
|
|
|
|
// FIXME: If both the original and replacement value are part of the
|
|
|
|
// same control-flow region (meaning that the execution of one
|
|
|
|
// guarantees the execution of the other), then we can combine the
|
|
|
|
// noalias scopes here and do better than the general conservative
|
|
|
|
// answer used in combineMetadata().
|
|
|
|
|
|
|
|
// In general, GVN unifies expressions over different control-flow
|
|
|
|
// regions, and so we need a conservative combination of the noalias
|
|
|
|
// scopes.
|
|
|
|
static const unsigned KnownIDs[] = {
|
|
|
|
LLVMContext::MD_tbaa, LLVMContext::MD_alias_scope,
|
|
|
|
LLVMContext::MD_noalias, LLVMContext::MD_range,
|
|
|
|
LLVMContext::MD_fpmath, LLVMContext::MD_invariant_load,
|
2018-08-07 23:36:11 +08:00
|
|
|
LLVMContext::MD_invariant_group, LLVMContext::MD_nonnull};
|
|
|
|
combineMetadata(ReplInst, I, KnownIDs, false);
|
2018-08-07 21:27:33 +08:00
|
|
|
}
|
|
|
|
|
2017-05-10 03:39:44 +08:00
|
|
|
template <typename RootType, typename DominatesFn>
|
|
|
|
static unsigned replaceDominatedUsesWith(Value *From, Value *To,
|
|
|
|
const RootType &Root,
|
|
|
|
const DominatesFn &Dominates) {
|
2015-05-23 07:53:24 +08:00
|
|
|
assert(From->getType() == To->getType());
|
2017-05-10 03:39:44 +08:00
|
|
|
|
2015-05-23 07:53:24 +08:00
|
|
|
unsigned Count = 0;
|
|
|
|
for (Value::use_iterator UI = From->use_begin(), UE = From->use_end();
|
2017-05-10 03:39:44 +08:00
|
|
|
UI != UE;) {
|
2015-05-23 07:53:24 +08:00
|
|
|
Use &U = *UI++;
|
2017-05-10 03:39:44 +08:00
|
|
|
if (!Dominates(Root, U))
|
|
|
|
continue;
|
|
|
|
U.set(To);
|
2018-05-14 20:53:11 +08:00
|
|
|
LLVM_DEBUG(dbgs() << "Replace dominated use of '" << From->getName()
|
|
|
|
<< "' as " << *To << " in " << *U << "\n");
|
2017-05-10 03:39:44 +08:00
|
|
|
++Count;
|
2015-05-23 07:53:24 +08:00
|
|
|
}
|
|
|
|
return Count;
|
|
|
|
}
|
2015-09-03 03:59:59 +08:00
|
|
|
|
2017-05-23 21:36:25 +08:00
|
|
|
unsigned llvm::replaceNonLocalUsesWith(Instruction *From, Value *To) {
|
|
|
|
assert(From->getType() == To->getType());
|
|
|
|
auto *BB = From->getParent();
|
|
|
|
unsigned Count = 0;
|
|
|
|
|
|
|
|
for (Value::use_iterator UI = From->use_begin(), UE = From->use_end();
|
|
|
|
UI != UE;) {
|
|
|
|
Use &U = *UI++;
|
|
|
|
auto *I = cast<Instruction>(U.getUser());
|
|
|
|
if (I->getParent() == BB)
|
|
|
|
continue;
|
|
|
|
U.set(To);
|
|
|
|
++Count;
|
|
|
|
}
|
|
|
|
return Count;
|
|
|
|
}
|
|
|
|
|
2015-09-03 03:59:59 +08:00
|
|
|
unsigned llvm::replaceDominatedUsesWith(Value *From, Value *To,
|
|
|
|
DominatorTree &DT,
|
2017-05-10 03:39:44 +08:00
|
|
|
const BasicBlockEdge &Root) {
|
|
|
|
auto Dominates = [&DT](const BasicBlockEdge &Root, const Use &U) {
|
|
|
|
return DT.dominates(Root, U);
|
|
|
|
};
|
|
|
|
return ::replaceDominatedUsesWith(From, To, Root, Dominates);
|
|
|
|
}
|
2015-09-03 03:59:59 +08:00
|
|
|
|
2017-05-10 03:39:44 +08:00
|
|
|
unsigned llvm::replaceDominatedUsesWith(Value *From, Value *To,
|
|
|
|
DominatorTree &DT,
|
|
|
|
const BasicBlock *BB) {
|
|
|
|
auto ProperlyDominates = [&DT](const BasicBlock *BB, const Use &U) {
|
|
|
|
auto *I = cast<Instruction>(U.getUser())->getParent();
|
|
|
|
return DT.properlyDominates(BB, I);
|
|
|
|
};
|
|
|
|
return ::replaceDominatedUsesWith(From, To, BB, ProperlyDominates);
|
2015-09-03 03:59:59 +08:00
|
|
|
}
|
2015-10-09 07:18:30 +08:00
|
|
|
|
2017-07-28 00:49:39 +08:00
|
|
|
bool llvm::callsGCLeafFunction(ImmutableCallSite CS,
|
|
|
|
const TargetLibraryInfo &TLI) {
|
2015-10-09 07:18:30 +08:00
|
|
|
// Check if the function is specifically marked as a gc leaf function.
|
2016-01-06 07:59:08 +08:00
|
|
|
if (CS.hasFnAttr("gc-leaf-function"))
|
|
|
|
return true;
|
2016-03-26 04:12:13 +08:00
|
|
|
if (const Function *F = CS.getCalledFunction()) {
|
|
|
|
if (F->hasFnAttribute("gc-leaf-function"))
|
|
|
|
return true;
|
|
|
|
|
|
|
|
if (auto IID = F->getIntrinsicID())
|
|
|
|
// Most LLVM intrinsics do not take safepoints.
|
|
|
|
return IID != Intrinsic::experimental_gc_statepoint &&
|
|
|
|
IID != Intrinsic::experimental_deoptimize;
|
|
|
|
}
|
2015-10-09 07:18:30 +08:00
|
|
|
|
2017-07-28 00:49:39 +08:00
|
|
|
// Lib calls can be materialized by some passes, and won't be
|
|
|
|
// marked as 'gc-leaf-function.' All available Libcalls are
|
|
|
|
// GC-leaf.
|
|
|
|
LibFunc LF;
|
|
|
|
if (TLI.getLibFunc(CS, LF)) {
|
|
|
|
return TLI.has(LF);
|
|
|
|
}
|
|
|
|
|
2015-10-09 07:18:30 +08:00
|
|
|
return false;
|
|
|
|
}
|
2016-01-15 17:20:19 +08:00
|
|
|
|
2017-06-26 11:31:31 +08:00
|
|
|
void llvm::copyNonnullMetadata(const LoadInst &OldLI, MDNode *N,
|
|
|
|
LoadInst &NewLI) {
|
|
|
|
auto *NewTy = NewLI.getType();
|
|
|
|
|
|
|
|
// This only directly applies if the new type is also a pointer.
|
|
|
|
if (NewTy->isPointerTy()) {
|
|
|
|
NewLI.setMetadata(LLVMContext::MD_nonnull, N);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
// The only other translation we can do is to integral loads with !range
|
|
|
|
// metadata.
|
|
|
|
if (!NewTy->isIntegerTy())
|
|
|
|
return;
|
|
|
|
|
|
|
|
MDBuilder MDB(NewLI.getContext());
|
|
|
|
const Value *Ptr = OldLI.getPointerOperand();
|
|
|
|
auto *ITy = cast<IntegerType>(NewTy);
|
|
|
|
auto *NullInt = ConstantExpr::getPtrToInt(
|
|
|
|
ConstantPointerNull::get(cast<PointerType>(Ptr->getType())), ITy);
|
|
|
|
auto *NonNullInt = ConstantExpr::getAdd(NullInt, ConstantInt::get(ITy, 1));
|
|
|
|
NewLI.setMetadata(LLVMContext::MD_range,
|
|
|
|
MDB.createRange(NonNullInt, NullInt));
|
|
|
|
}
|
|
|
|
|
|
|
|
void llvm::copyRangeMetadata(const DataLayout &DL, const LoadInst &OldLI,
|
|
|
|
MDNode *N, LoadInst &NewLI) {
|
|
|
|
auto *NewTy = NewLI.getType();
|
|
|
|
|
2017-11-28 09:25:38 +08:00
|
|
|
// Give up unless it is converted to a pointer where there is a single very
|
|
|
|
// valuable mapping we can do reliably.
|
|
|
|
// FIXME: It would be nice to propagate this in more ways, but the type
|
|
|
|
// conversions make it hard.
|
|
|
|
if (!NewTy->isPointerTy())
|
2017-06-26 11:31:31 +08:00
|
|
|
return;
|
|
|
|
|
2018-02-14 14:58:08 +08:00
|
|
|
unsigned BitWidth = DL.getIndexTypeSizeInBits(NewTy);
|
2017-11-28 09:25:38 +08:00
|
|
|
if (!getConstantRangeFromMetadata(*N).contains(APInt(BitWidth, 0))) {
|
|
|
|
MDNode *NN = MDNode::get(OldLI.getContext(), None);
|
|
|
|
NewLI.setMetadata(LLVMContext::MD_nonnull, NN);
|
2017-06-26 11:31:31 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-09-19 16:16:56 +08:00
|
|
|
void llvm::dropDebugUsers(Instruction &I) {
|
|
|
|
SmallVector<DbgVariableIntrinsic *, 1> DbgUsers;
|
|
|
|
findDbgUsers(DbgUsers, &I);
|
|
|
|
for (auto *DII : DbgUsers)
|
|
|
|
DII->eraseFromParent();
|
|
|
|
}
|
|
|
|
|
2016-08-06 19:13:10 +08:00
|
|
|
namespace {
|
2017-10-18 05:27:42 +08:00
|
|
|
|
2016-01-15 17:20:19 +08:00
|
|
|
/// A potential constituent of a bitreverse or bswap expression. See
|
|
|
|
/// collectBitParts for a fuller explanation.
|
|
|
|
struct BitPart {
|
|
|
|
BitPart(Value *P, unsigned BW) : Provider(P) {
|
|
|
|
Provenance.resize(BW);
|
|
|
|
}
|
|
|
|
|
|
|
|
/// The Value that this is a bitreverse/bswap of.
|
|
|
|
Value *Provider;
|
2017-10-18 05:27:42 +08:00
|
|
|
|
2016-01-15 17:20:19 +08:00
|
|
|
/// The "provenance" of each bit. Provenance[A] = B means that bit A
|
|
|
|
/// in Provider becomes bit B in the result of this expression.
|
|
|
|
SmallVector<int8_t, 32> Provenance; // int8_t means max size is i128.
|
|
|
|
|
|
|
|
enum { Unset = -1 };
|
|
|
|
};
|
2017-10-18 05:27:42 +08:00
|
|
|
|
2016-08-06 19:13:10 +08:00
|
|
|
} // end anonymous namespace
|
2016-01-15 17:20:19 +08:00
|
|
|
|
|
|
|
/// Analyze the specified subexpression and see if it is capable of providing
|
|
|
|
/// pieces of a bswap or bitreverse. The subexpression provides a potential
|
|
|
|
/// piece of a bswap or bitreverse if it can be proven that each non-zero bit in
|
|
|
|
/// the output of the expression came from a corresponding bit in some other
|
|
|
|
/// value. This function is recursive, and the end result is a mapping of
|
|
|
|
/// bitnumber to bitnumber. It is the caller's responsibility to validate that
|
|
|
|
/// the bitnumber to bitnumber mapping is correct for a bswap or bitreverse.
|
|
|
|
///
|
|
|
|
/// For example, if the current subexpression if "(shl i32 %X, 24)" then we know
|
|
|
|
/// that the expression deposits the low byte of %X into the high byte of the
|
|
|
|
/// result and that all other bits are zero. This expression is accepted and a
|
|
|
|
/// BitPart is returned with Provider set to %X and Provenance[24-31] set to
|
|
|
|
/// [0-7].
|
|
|
|
///
|
|
|
|
/// To avoid revisiting values, the BitPart results are memoized into the
|
|
|
|
/// provided map. To avoid unnecessary copying of BitParts, BitParts are
|
|
|
|
/// constructed in-place in the \c BPS map. Because of this \c BPS needs to
|
|
|
|
/// store BitParts objects, not pointers. As we need the concept of a nullptr
|
|
|
|
/// BitParts (Value has been analyzed and the analysis failed), we an Optional
|
|
|
|
/// type instead to provide the same functionality.
|
|
|
|
///
|
|
|
|
/// Because we pass around references into \c BPS, we must use a container that
|
|
|
|
/// does not invalidate internal references (std::map instead of DenseMap).
|
|
|
|
static const Optional<BitPart> &
|
|
|
|
collectBitParts(Value *V, bool MatchBSwaps, bool MatchBitReversals,
|
|
|
|
std::map<Value *, Optional<BitPart>> &BPS) {
|
|
|
|
auto I = BPS.find(V);
|
|
|
|
if (I != BPS.end())
|
|
|
|
return I->second;
|
|
|
|
|
|
|
|
auto &Result = BPS[V] = None;
|
|
|
|
auto BitWidth = cast<IntegerType>(V->getType())->getBitWidth();
|
|
|
|
|
|
|
|
if (Instruction *I = dyn_cast<Instruction>(V)) {
|
|
|
|
// If this is an or instruction, it may be an inner node of the bswap.
|
|
|
|
if (I->getOpcode() == Instruction::Or) {
|
|
|
|
auto &A = collectBitParts(I->getOperand(0), MatchBSwaps,
|
|
|
|
MatchBitReversals, BPS);
|
|
|
|
auto &B = collectBitParts(I->getOperand(1), MatchBSwaps,
|
|
|
|
MatchBitReversals, BPS);
|
|
|
|
if (!A || !B)
|
|
|
|
return Result;
|
|
|
|
|
|
|
|
// Try and merge the two together.
|
|
|
|
if (!A->Provider || A->Provider != B->Provider)
|
|
|
|
return Result;
|
|
|
|
|
|
|
|
Result = BitPart(A->Provider, BitWidth);
|
|
|
|
for (unsigned i = 0; i < A->Provenance.size(); ++i) {
|
|
|
|
if (A->Provenance[i] != BitPart::Unset &&
|
|
|
|
B->Provenance[i] != BitPart::Unset &&
|
|
|
|
A->Provenance[i] != B->Provenance[i])
|
|
|
|
return Result = None;
|
|
|
|
|
|
|
|
if (A->Provenance[i] == BitPart::Unset)
|
|
|
|
Result->Provenance[i] = B->Provenance[i];
|
|
|
|
else
|
|
|
|
Result->Provenance[i] = A->Provenance[i];
|
|
|
|
}
|
|
|
|
|
|
|
|
return Result;
|
|
|
|
}
|
|
|
|
|
|
|
|
// If this is a logical shift by a constant, recurse then shift the result.
|
|
|
|
if (I->isLogicalShift() && isa<ConstantInt>(I->getOperand(1))) {
|
|
|
|
unsigned BitShift =
|
|
|
|
cast<ConstantInt>(I->getOperand(1))->getLimitedValue(~0U);
|
|
|
|
// Ensure the shift amount is defined.
|
|
|
|
if (BitShift > BitWidth)
|
|
|
|
return Result;
|
|
|
|
|
|
|
|
auto &Res = collectBitParts(I->getOperand(0), MatchBSwaps,
|
|
|
|
MatchBitReversals, BPS);
|
|
|
|
if (!Res)
|
|
|
|
return Result;
|
|
|
|
Result = Res;
|
|
|
|
|
|
|
|
// Perform the "shift" on BitProvenance.
|
|
|
|
auto &P = Result->Provenance;
|
|
|
|
if (I->getOpcode() == Instruction::Shl) {
|
|
|
|
P.erase(std::prev(P.end(), BitShift), P.end());
|
|
|
|
P.insert(P.begin(), BitShift, BitPart::Unset);
|
|
|
|
} else {
|
|
|
|
P.erase(P.begin(), std::next(P.begin(), BitShift));
|
|
|
|
P.insert(P.end(), BitShift, BitPart::Unset);
|
|
|
|
}
|
|
|
|
|
|
|
|
return Result;
|
|
|
|
}
|
|
|
|
|
|
|
|
// If this is a logical 'and' with a mask that clears bits, recurse then
|
|
|
|
// unset the appropriate bits.
|
|
|
|
if (I->getOpcode() == Instruction::And &&
|
|
|
|
isa<ConstantInt>(I->getOperand(1))) {
|
|
|
|
APInt Bit(I->getType()->getPrimitiveSizeInBits(), 1);
|
|
|
|
const APInt &AndMask = cast<ConstantInt>(I->getOperand(1))->getValue();
|
|
|
|
|
|
|
|
// Check that the mask allows a multiple of 8 bits for a bswap, for an
|
|
|
|
// early exit.
|
|
|
|
unsigned NumMaskedBits = AndMask.countPopulation();
|
|
|
|
if (!MatchBitReversals && NumMaskedBits % 8 != 0)
|
|
|
|
return Result;
|
2017-06-26 11:31:31 +08:00
|
|
|
|
2016-01-15 17:20:19 +08:00
|
|
|
auto &Res = collectBitParts(I->getOperand(0), MatchBSwaps,
|
|
|
|
MatchBitReversals, BPS);
|
|
|
|
if (!Res)
|
|
|
|
return Result;
|
|
|
|
Result = Res;
|
|
|
|
|
|
|
|
for (unsigned i = 0; i < BitWidth; ++i, Bit <<= 1)
|
|
|
|
// If the AndMask is zero for this bit, clear the bit.
|
|
|
|
if ((AndMask & Bit) == 0)
|
|
|
|
Result->Provenance[i] = BitPart::Unset;
|
2016-05-26 22:58:51 +08:00
|
|
|
return Result;
|
|
|
|
}
|
|
|
|
|
|
|
|
// If this is a zext instruction zero extend the result.
|
|
|
|
if (I->getOpcode() == Instruction::ZExt) {
|
|
|
|
auto &Res = collectBitParts(I->getOperand(0), MatchBSwaps,
|
|
|
|
MatchBitReversals, BPS);
|
|
|
|
if (!Res)
|
|
|
|
return Result;
|
2016-01-15 17:20:19 +08:00
|
|
|
|
2016-05-26 22:58:51 +08:00
|
|
|
Result = BitPart(Res->Provider, BitWidth);
|
|
|
|
auto NarrowBitWidth =
|
|
|
|
cast<IntegerType>(cast<ZExtInst>(I)->getSrcTy())->getBitWidth();
|
|
|
|
for (unsigned i = 0; i < NarrowBitWidth; ++i)
|
|
|
|
Result->Provenance[i] = Res->Provenance[i];
|
|
|
|
for (unsigned i = NarrowBitWidth; i < BitWidth; ++i)
|
|
|
|
Result->Provenance[i] = BitPart::Unset;
|
2016-01-15 17:20:19 +08:00
|
|
|
return Result;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Okay, we got to something that isn't a shift, 'or' or 'and'. This must be
|
|
|
|
// the input value to the bswap/bitreverse.
|
|
|
|
Result = BitPart(V, BitWidth);
|
|
|
|
for (unsigned i = 0; i < BitWidth; ++i)
|
|
|
|
Result->Provenance[i] = i;
|
|
|
|
return Result;
|
|
|
|
}
|
|
|
|
|
|
|
|
static bool bitTransformIsCorrectForBSwap(unsigned From, unsigned To,
|
|
|
|
unsigned BitWidth) {
|
|
|
|
if (From % 8 != To % 8)
|
|
|
|
return false;
|
|
|
|
// Convert from bit indices to byte indices and check for a byte reversal.
|
|
|
|
From >>= 3;
|
|
|
|
To >>= 3;
|
|
|
|
BitWidth >>= 3;
|
|
|
|
return From == BitWidth - To - 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
static bool bitTransformIsCorrectForBitReverse(unsigned From, unsigned To,
|
|
|
|
unsigned BitWidth) {
|
|
|
|
return From == BitWidth - To - 1;
|
|
|
|
}
|
|
|
|
|
2016-05-26 00:22:14 +08:00
|
|
|
bool llvm::recognizeBSwapOrBitReverseIdiom(
|
2016-01-15 17:20:19 +08:00
|
|
|
Instruction *I, bool MatchBSwaps, bool MatchBitReversals,
|
|
|
|
SmallVectorImpl<Instruction *> &InsertedInsts) {
|
|
|
|
if (Operator::getOpcode(I) != Instruction::Or)
|
|
|
|
return false;
|
|
|
|
if (!MatchBSwaps && !MatchBitReversals)
|
|
|
|
return false;
|
|
|
|
IntegerType *ITy = dyn_cast<IntegerType>(I->getType());
|
|
|
|
if (!ITy || ITy->getBitWidth() > 128)
|
|
|
|
return false; // Can't do vectors or integers > 128 bits.
|
|
|
|
unsigned BW = ITy->getBitWidth();
|
|
|
|
|
2016-05-26 22:58:51 +08:00
|
|
|
unsigned DemandedBW = BW;
|
|
|
|
IntegerType *DemandedTy = ITy;
|
|
|
|
if (I->hasOneUse()) {
|
|
|
|
if (TruncInst *Trunc = dyn_cast<TruncInst>(I->user_back())) {
|
|
|
|
DemandedTy = cast<IntegerType>(Trunc->getType());
|
|
|
|
DemandedBW = DemandedTy->getBitWidth();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-01-15 17:20:19 +08:00
|
|
|
// Try to find all the pieces corresponding to the bswap.
|
|
|
|
std::map<Value *, Optional<BitPart>> BPS;
|
|
|
|
auto Res = collectBitParts(I, MatchBSwaps, MatchBitReversals, BPS);
|
|
|
|
if (!Res)
|
|
|
|
return false;
|
|
|
|
auto &BitProvenance = Res->Provenance;
|
|
|
|
|
|
|
|
// Now, is the bit permutation correct for a bswap or a bitreverse? We can
|
|
|
|
// only byteswap values with an even number of bytes.
|
2016-05-26 22:58:51 +08:00
|
|
|
bool OKForBSwap = DemandedBW % 16 == 0, OKForBitReverse = true;
|
|
|
|
for (unsigned i = 0; i < DemandedBW; ++i) {
|
|
|
|
OKForBSwap &=
|
|
|
|
bitTransformIsCorrectForBSwap(BitProvenance[i], i, DemandedBW);
|
2016-01-15 17:20:19 +08:00
|
|
|
OKForBitReverse &=
|
2016-05-26 22:58:51 +08:00
|
|
|
bitTransformIsCorrectForBitReverse(BitProvenance[i], i, DemandedBW);
|
2016-01-15 17:20:19 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
Intrinsic::ID Intrin;
|
|
|
|
if (OKForBSwap && MatchBSwaps)
|
|
|
|
Intrin = Intrinsic::bswap;
|
|
|
|
else if (OKForBitReverse && MatchBitReversals)
|
|
|
|
Intrin = Intrinsic::bitreverse;
|
|
|
|
else
|
|
|
|
return false;
|
|
|
|
|
2016-05-26 22:58:51 +08:00
|
|
|
if (ITy != DemandedTy) {
|
|
|
|
Function *F = Intrinsic::getDeclaration(I->getModule(), Intrin, DemandedTy);
|
|
|
|
Value *Provider = Res->Provider;
|
|
|
|
IntegerType *ProviderTy = cast<IntegerType>(Provider->getType());
|
|
|
|
// We may need to truncate the provider.
|
|
|
|
if (DemandedTy != ProviderTy) {
|
|
|
|
auto *Trunc = CastInst::Create(Instruction::Trunc, Provider, DemandedTy,
|
|
|
|
"trunc", I);
|
|
|
|
InsertedInsts.push_back(Trunc);
|
|
|
|
Provider = Trunc;
|
|
|
|
}
|
|
|
|
auto *CI = CallInst::Create(F, Provider, "rev", I);
|
|
|
|
InsertedInsts.push_back(CI);
|
|
|
|
auto *ExtInst = CastInst::Create(Instruction::ZExt, CI, ITy, "zext", I);
|
|
|
|
InsertedInsts.push_back(ExtInst);
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2016-01-15 17:20:19 +08:00
|
|
|
Function *F = Intrinsic::getDeclaration(I->getModule(), Intrin, ITy);
|
|
|
|
InsertedInsts.push_back(CallInst::Create(F, Res->Provider, "rev", I));
|
|
|
|
return true;
|
|
|
|
}
|
2016-06-18 18:10:37 +08:00
|
|
|
|
|
|
|
// CodeGen has special handling for some string functions that may replace
|
|
|
|
// them with target-specific intrinsics. Since that'd skip our interceptors
|
|
|
|
// in ASan/MSan/TSan/DFSan, and thus make us miss some memory accesses,
|
|
|
|
// we mark affected calls as NoBuiltin, which will disable optimization
|
|
|
|
// in CodeGen.
|
2016-07-29 07:45:15 +08:00
|
|
|
void llvm::maybeMarkSanitizerLibraryCallNoBuiltin(
|
|
|
|
CallInst *CI, const TargetLibraryInfo *TLI) {
|
2016-06-18 18:10:37 +08:00
|
|
|
Function *F = CI->getCalledFunction();
|
[Analysis] Add LibFunc_ prefix to enums in TargetLibraryInfo. (NFC)
Summary:
The LibFunc::Func enum holds enumerators named for libc functions.
Unfortunately, there are real situations, including libc implementations, where
function names are actually macros (musl uses "#define fopen64 fopen", for
example; any other transitively visible macro would have similar effects).
Strictly speaking, a conforming C++ Standard Library should provide any such
macros as functions instead (via <cstdio>). However, there are some "library"
functions which are not part of the standard, and thus not subject to this
rule (fopen64, for example). So, in order to be both portable and consistent,
the enum should not use the bare function names.
The old enum naming used a namespace LibFunc and an enum Func, with bare
enumerators. This patch changes LibFunc to be an enum with enumerators prefixed
with "LibFFunc_". (Unfortunately, a scoped enum is not sufficient to override
macros.)
There are additional changes required in clang.
Reviewers: rsmith
Subscribers: mehdi_amini, mzolotukhin, nemanjai, llvm-commits
Differential Revision: https://reviews.llvm.org/D28476
llvm-svn: 292848
2017-01-24 07:16:46 +08:00
|
|
|
LibFunc Func;
|
2016-07-29 07:45:15 +08:00
|
|
|
if (F && !F->hasLocalLinkage() && F->hasName() &&
|
|
|
|
TLI->getLibFunc(F->getName(), Func) && TLI->hasOptimizedCodeGen(Func) &&
|
|
|
|
!F->doesNotAccessMemory())
|
Rename AttributeSet to AttributeList
Summary:
This class is a list of AttributeSetNodes corresponding the function
prototype of a call or function declaration. This class used to be
called ParamAttrListPtr, then AttrListPtr, then AttributeSet. It is
typically accessed by parameter and return value index, so
"AttributeList" seems like a more intuitive name.
Rename AttributeSetImpl to AttributeListImpl to follow suit.
It's useful to rename this class so that we can rename AttributeSetNode
to AttributeSet later. AttributeSet is the set of attributes that apply
to a single function, argument, or return value.
Reviewers: sanjoy, javed.absar, chandlerc, pete
Reviewed By: pete
Subscribers: pete, jholewinski, arsenm, dschuff, mehdi_amini, jfb, nhaehnle, sbc100, void, llvm-commits
Differential Revision: https://reviews.llvm.org/D31102
llvm-svn: 298393
2017-03-22 00:57:19 +08:00
|
|
|
CI->addAttribute(AttributeList::FunctionIndex, Attribute::NoBuiltin);
|
2016-06-18 18:10:37 +08:00
|
|
|
}
|
[GVNSink] GVNSink pass
This patch provides an initial prototype for a pass that sinks instructions based on GVN information, similar to GVNHoist. It is not yet ready for commiting but I've uploaded it to gather some initial thoughts.
This pass attempts to sink instructions into successors, reducing static
instruction count and enabling if-conversion.
We use a variant of global value numbering to decide what can be sunk.
Consider:
[ %a1 = add i32 %b, 1 ] [ %c1 = add i32 %d, 1 ]
[ %a2 = xor i32 %a1, 1 ] [ %c2 = xor i32 %c1, 1 ]
\ /
[ %e = phi i32 %a2, %c2 ]
[ add i32 %e, 4 ]
GVN would number %a1 and %c1 differently because they compute different
results - the VN of an instruction is a function of its opcode and the
transitive closure of its operands. This is the key property for hoisting
and CSE.
What we want when sinking however is for a numbering that is a function of
the *uses* of an instruction, which allows us to answer the question "if I
replace %a1 with %c1, will it contribute in an equivalent way to all
successive instructions?". The (new) PostValueTable class in GVN provides this
mapping.
This pass has some shown really impressive improvements especially for codesize already on internal benchmarks, so I have high hopes it can replace all the sinking logic in SimplifyCFG.
Differential revision: https://reviews.llvm.org/D24805
llvm-svn: 303850
2017-05-25 20:51:11 +08:00
|
|
|
|
|
|
|
bool llvm::canReplaceOperandWithVariable(const Instruction *I, unsigned OpIdx) {
|
|
|
|
// We can't have a PHI with a metadata type.
|
|
|
|
if (I->getOperand(OpIdx)->getType()->isMetadataTy())
|
|
|
|
return false;
|
|
|
|
|
|
|
|
// Early exit.
|
|
|
|
if (!isa<Constant>(I->getOperand(OpIdx)))
|
|
|
|
return true;
|
|
|
|
|
|
|
|
switch (I->getOpcode()) {
|
|
|
|
default:
|
|
|
|
return true;
|
|
|
|
case Instruction::Call:
|
|
|
|
case Instruction::Invoke:
|
2017-07-11 04:45:34 +08:00
|
|
|
// Can't handle inline asm. Skip it.
|
|
|
|
if (isa<InlineAsm>(ImmutableCallSite(I).getCalledValue()))
|
|
|
|
return false;
|
[GVNSink] GVNSink pass
This patch provides an initial prototype for a pass that sinks instructions based on GVN information, similar to GVNHoist. It is not yet ready for commiting but I've uploaded it to gather some initial thoughts.
This pass attempts to sink instructions into successors, reducing static
instruction count and enabling if-conversion.
We use a variant of global value numbering to decide what can be sunk.
Consider:
[ %a1 = add i32 %b, 1 ] [ %c1 = add i32 %d, 1 ]
[ %a2 = xor i32 %a1, 1 ] [ %c2 = xor i32 %c1, 1 ]
\ /
[ %e = phi i32 %a2, %c2 ]
[ add i32 %e, 4 ]
GVN would number %a1 and %c1 differently because they compute different
results - the VN of an instruction is a function of its opcode and the
transitive closure of its operands. This is the key property for hoisting
and CSE.
What we want when sinking however is for a numbering that is a function of
the *uses* of an instruction, which allows us to answer the question "if I
replace %a1 with %c1, will it contribute in an equivalent way to all
successive instructions?". The (new) PostValueTable class in GVN provides this
mapping.
This pass has some shown really impressive improvements especially for codesize already on internal benchmarks, so I have high hopes it can replace all the sinking logic in SimplifyCFG.
Differential revision: https://reviews.llvm.org/D24805
llvm-svn: 303850
2017-05-25 20:51:11 +08:00
|
|
|
// Many arithmetic intrinsics have no issue taking a
|
|
|
|
// variable, however it's hard to distingish these from
|
|
|
|
// specials such as @llvm.frameaddress that require a constant.
|
|
|
|
if (isa<IntrinsicInst>(I))
|
|
|
|
return false;
|
|
|
|
|
|
|
|
// Constant bundle operands may need to retain their constant-ness for
|
|
|
|
// correctness.
|
|
|
|
if (ImmutableCallSite(I).isBundleOperand(OpIdx))
|
|
|
|
return false;
|
|
|
|
return true;
|
|
|
|
case Instruction::ShuffleVector:
|
|
|
|
// Shufflevector masks are constant.
|
|
|
|
return OpIdx != 2;
|
2017-07-07 02:47:05 +08:00
|
|
|
case Instruction::Switch:
|
[GVNSink] GVNSink pass
This patch provides an initial prototype for a pass that sinks instructions based on GVN information, similar to GVNHoist. It is not yet ready for commiting but I've uploaded it to gather some initial thoughts.
This pass attempts to sink instructions into successors, reducing static
instruction count and enabling if-conversion.
We use a variant of global value numbering to decide what can be sunk.
Consider:
[ %a1 = add i32 %b, 1 ] [ %c1 = add i32 %d, 1 ]
[ %a2 = xor i32 %a1, 1 ] [ %c2 = xor i32 %c1, 1 ]
\ /
[ %e = phi i32 %a2, %c2 ]
[ add i32 %e, 4 ]
GVN would number %a1 and %c1 differently because they compute different
results - the VN of an instruction is a function of its opcode and the
transitive closure of its operands. This is the key property for hoisting
and CSE.
What we want when sinking however is for a numbering that is a function of
the *uses* of an instruction, which allows us to answer the question "if I
replace %a1 with %c1, will it contribute in an equivalent way to all
successive instructions?". The (new) PostValueTable class in GVN provides this
mapping.
This pass has some shown really impressive improvements especially for codesize already on internal benchmarks, so I have high hopes it can replace all the sinking logic in SimplifyCFG.
Differential revision: https://reviews.llvm.org/D24805
llvm-svn: 303850
2017-05-25 20:51:11 +08:00
|
|
|
case Instruction::ExtractValue:
|
|
|
|
// All operands apart from the first are constant.
|
|
|
|
return OpIdx == 0;
|
2017-07-07 02:47:05 +08:00
|
|
|
case Instruction::InsertValue:
|
|
|
|
// All operands apart from the first and the second are constant.
|
|
|
|
return OpIdx < 2;
|
[GVNSink] GVNSink pass
This patch provides an initial prototype for a pass that sinks instructions based on GVN information, similar to GVNHoist. It is not yet ready for commiting but I've uploaded it to gather some initial thoughts.
This pass attempts to sink instructions into successors, reducing static
instruction count and enabling if-conversion.
We use a variant of global value numbering to decide what can be sunk.
Consider:
[ %a1 = add i32 %b, 1 ] [ %c1 = add i32 %d, 1 ]
[ %a2 = xor i32 %a1, 1 ] [ %c2 = xor i32 %c1, 1 ]
\ /
[ %e = phi i32 %a2, %c2 ]
[ add i32 %e, 4 ]
GVN would number %a1 and %c1 differently because they compute different
results - the VN of an instruction is a function of its opcode and the
transitive closure of its operands. This is the key property for hoisting
and CSE.
What we want when sinking however is for a numbering that is a function of
the *uses* of an instruction, which allows us to answer the question "if I
replace %a1 with %c1, will it contribute in an equivalent way to all
successive instructions?". The (new) PostValueTable class in GVN provides this
mapping.
This pass has some shown really impressive improvements especially for codesize already on internal benchmarks, so I have high hopes it can replace all the sinking logic in SimplifyCFG.
Differential revision: https://reviews.llvm.org/D24805
llvm-svn: 303850
2017-05-25 20:51:11 +08:00
|
|
|
case Instruction::Alloca:
|
2017-07-07 02:47:05 +08:00
|
|
|
// Static allocas (constant size in the entry block) are handled by
|
|
|
|
// prologue/epilogue insertion so they're free anyway. We definitely don't
|
|
|
|
// want to make them non-constant.
|
2018-05-05 09:57:00 +08:00
|
|
|
return !cast<AllocaInst>(I)->isStaticAlloca();
|
[GVNSink] GVNSink pass
This patch provides an initial prototype for a pass that sinks instructions based on GVN information, similar to GVNHoist. It is not yet ready for commiting but I've uploaded it to gather some initial thoughts.
This pass attempts to sink instructions into successors, reducing static
instruction count and enabling if-conversion.
We use a variant of global value numbering to decide what can be sunk.
Consider:
[ %a1 = add i32 %b, 1 ] [ %c1 = add i32 %d, 1 ]
[ %a2 = xor i32 %a1, 1 ] [ %c2 = xor i32 %c1, 1 ]
\ /
[ %e = phi i32 %a2, %c2 ]
[ add i32 %e, 4 ]
GVN would number %a1 and %c1 differently because they compute different
results - the VN of an instruction is a function of its opcode and the
transitive closure of its operands. This is the key property for hoisting
and CSE.
What we want when sinking however is for a numbering that is a function of
the *uses* of an instruction, which allows us to answer the question "if I
replace %a1 with %c1, will it contribute in an equivalent way to all
successive instructions?". The (new) PostValueTable class in GVN provides this
mapping.
This pass has some shown really impressive improvements especially for codesize already on internal benchmarks, so I have high hopes it can replace all the sinking logic in SimplifyCFG.
Differential revision: https://reviews.llvm.org/D24805
llvm-svn: 303850
2017-05-25 20:51:11 +08:00
|
|
|
case Instruction::GetElementPtr:
|
|
|
|
if (OpIdx == 0)
|
|
|
|
return true;
|
|
|
|
gep_type_iterator It = gep_type_begin(I);
|
|
|
|
for (auto E = std::next(It, OpIdx); It != E; ++It)
|
|
|
|
if (It.isStruct())
|
|
|
|
return false;
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|