LLVM  8.0.1
Macros | Functions
Sink.cpp File Reference
#include "llvm/Transforms/Scalar/Sink.h"
#include "llvm/ADT/Statistic.h"
#include "llvm/Analysis/AliasAnalysis.h"
#include "llvm/Analysis/LoopInfo.h"
#include "llvm/Analysis/ValueTracking.h"
#include "llvm/IR/CFG.h"
#include "llvm/IR/DataLayout.h"
#include "llvm/IR/Dominators.h"
#include "llvm/IR/IntrinsicInst.h"
#include "llvm/IR/Module.h"
#include "llvm/Support/Debug.h"
#include "llvm/Support/raw_ostream.h"
#include "llvm/Transforms/Scalar.h"
Include dependency graph for Sink.cpp:

Go to the source code of this file.

Macros

#define DEBUG_TYPE   "sink"
 

Functions

 STATISTIC (NumSunk, "Number of instructions sunk")
 
 STATISTIC (NumSinkIter, "Number of sinking iterations")
 
static bool AllUsesDominatedByBlock (Instruction *Inst, BasicBlock *BB, DominatorTree &DT)
 AllUsesDominatedByBlock - Return true if all uses of the specified value occur in blocks dominated by the specified block. More...
 
static bool isSafeToMove (Instruction *Inst, AliasAnalysis &AA, SmallPtrSetImpl< Instruction *> &Stores)
 
static bool IsAcceptableTarget (Instruction *Inst, BasicBlock *SuccToSinkTo, DominatorTree &DT, LoopInfo &LI)
 IsAcceptableTarget - Return true if it is possible to sink the instruction in the specified basic block. More...
 
static bool SinkInstruction (Instruction *Inst, SmallPtrSetImpl< Instruction *> &Stores, DominatorTree &DT, LoopInfo &LI, AAResults &AA)
 SinkInstruction - Determine whether it is safe to sink the specified machine instruction out of its current block into a successor. More...
 
static bool ProcessBlock (BasicBlock &BB, DominatorTree &DT, LoopInfo &LI, AAResults &AA)
 
static bool iterativelySinkInstructions (Function &F, DominatorTree &DT, LoopInfo &LI, AAResults &AA)
 

Macro Definition Documentation

◆ DEBUG_TYPE

#define DEBUG_TYPE   "sink"

Definition at line 30 of file Sink.cpp.

Function Documentation

◆ AllUsesDominatedByBlock()

static bool AllUsesDominatedByBlock ( Instruction Inst,
BasicBlock BB,
DominatorTree DT 
)
static

AllUsesDominatedByBlock - Return true if all uses of the specified value occur in blocks dominated by the specified block.

Definition at line 37 of file Sink.cpp.

References llvm::DominatorTree::dominates(), llvm::PHINode::getIncomingValueNumForOperand(), llvm::Instruction::getParent(), and llvm::Value::uses().

Referenced by IsAcceptableTarget().

◆ IsAcceptableTarget()

static bool IsAcceptableTarget ( Instruction Inst,
BasicBlock SuccToSinkTo,
DominatorTree DT,
LoopInfo LI 
)
static

◆ isSafeToMove()

static bool isSafeToMove ( Instruction Inst,
AliasAnalysis AA,
SmallPtrSetImpl< Instruction *> &  Stores 
)
static

◆ iterativelySinkInstructions()

static bool iterativelySinkInstructions ( Function F,
DominatorTree DT,
LoopInfo LI,
AAResults AA 
)
static

Definition at line 239 of file Sink.cpp.

References llvm::dbgs(), I, LLVM_DEBUG, and ProcessBlock().

Referenced by llvm::SinkingPass::run().

◆ ProcessBlock()

static bool ProcessBlock ( BasicBlock BB,
DominatorTree DT,
LoopInfo LI,
AAResults AA 
)
static

◆ SinkInstruction()

static bool SinkInstruction ( Instruction Inst,
SmallPtrSetImpl< Instruction *> &  Stores,
DominatorTree DT,
LoopInfo LI,
AAResults AA 
)
static

◆ STATISTIC() [1/2]

STATISTIC ( NumSunk  ,
"Number of instructions sunk"   
)

◆ STATISTIC() [2/2]

STATISTIC ( NumSinkIter  ,
"Number of sinking iterations"   
)