mirror of
https://github.com/RPCSX/llvm.git
synced 2025-01-10 22:46:20 +00:00
[GVNHoist] Enable aggressive hoisting when optimizing for code-size
Enable scalar hoisting at -Oz as it is safe to hoist scalars to a place where they are partially needed. Differential Revision: https://reviews.llvm.org/D27111 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@288141 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
bdcd71da4d
commit
06f75183e3
@ -202,7 +202,12 @@ public:
|
||||
GVNHoist(DominatorTree *DT, AliasAnalysis *AA, MemoryDependenceResults *MD,
|
||||
MemorySSA *MSSA, bool OptForMinSize)
|
||||
: DT(DT), AA(AA), MD(MD), MSSA(MSSA), OptForMinSize(OptForMinSize),
|
||||
HoistingGeps(OptForMinSize), HoistedCtr(0) {}
|
||||
HoistingGeps(OptForMinSize), HoistedCtr(0) {
|
||||
// Hoist as far as possible when optimizing for code-size.
|
||||
if (OptForMinSize)
|
||||
MaxNumberOfBBSInPath = -1;
|
||||
}
|
||||
|
||||
bool run(Function &F) {
|
||||
VN.setDomTree(DT);
|
||||
VN.setAliasAnalysis(AA);
|
||||
@ -500,10 +505,13 @@ private:
|
||||
bool safeToHoistScalar(const BasicBlock *HoistBB,
|
||||
SmallPtrSetImpl<const BasicBlock *> &WL,
|
||||
int &NBBsOnAllPaths) {
|
||||
// Check that the hoisted expression is needed on all paths. Enable scalar
|
||||
// hoisting at -Oz as it is safe to hoist scalars to a place where they are
|
||||
// partially needed.
|
||||
if (!OptForMinSize && !hoistingFromAllPaths(HoistBB, WL))
|
||||
// Enable scalar hoisting at -Oz as it is safe to hoist scalars to a place
|
||||
// where they are partially needed.
|
||||
if (OptForMinSize)
|
||||
return true;
|
||||
|
||||
// Check that the hoisted expression is needed on all paths.
|
||||
if (!hoistingFromAllPaths(HoistBB, WL))
|
||||
return false;
|
||||
|
||||
for (const BasicBlock *BB : WL)
|
||||
|
Loading…
x
Reference in New Issue
Block a user