diff options
author | Chris Lattner <sabre@nondot.org> | 2004-11-14 20:50:30 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2004-11-14 20:50:30 +0000 |
commit | 28eeb73f2f44187237dc5dc46a345fdbf8e5663b (patch) | |
tree | cb36ccfe737b787e8a6d48602af8866aef45321a /llvm | |
parent | 78d31c13ffc182589e417843971722ae8746f77b (diff) | |
download | bcm5719-llvm-28eeb73f2f44187237dc5dc46a345fdbf8e5663b.tar.gz bcm5719-llvm-28eeb73f2f44187237dc5dc46a345fdbf8e5663b.zip |
If a global is just loaded and restored, realize that it is not changing
value. This allows us to turn more globals into constants and eliminate them.
This patch implements GlobalOpt/load-store-global.llx.
Note that this patch speeds up 255.vortex from:
Output/255.vortex.out-cbe.time:program 7.640000
Output/255.vortex.out-llc.time:program 9.810000
to:
Output/255.vortex.out-cbe.time:program 7.250000
Output/255.vortex.out-llc.time:program 9.490000
Which isn't bad at all!
llvm-svn: 17746
Diffstat (limited to 'llvm')
-rw-r--r-- | llvm/lib/Transforms/IPO/GlobalOpt.cpp | 12 |
1 files changed, 9 insertions, 3 deletions
diff --git a/llvm/lib/Transforms/IPO/GlobalOpt.cpp b/llvm/lib/Transforms/IPO/GlobalOpt.cpp index 054c5ee4306..b8edc32f16f 100644 --- a/llvm/lib/Transforms/IPO/GlobalOpt.cpp +++ b/llvm/lib/Transforms/IPO/GlobalOpt.cpp @@ -155,14 +155,20 @@ static bool AnalyzeGlobal(Value *V, GlobalStatus &GS, // stores. if (GS.StoredType != GlobalStatus::isStored) if (GlobalVariable *GV = dyn_cast<GlobalVariable>(SI->getOperand(1))){ - if (SI->getOperand(0) == GV->getInitializer()) { + Value *StoredVal = SI->getOperand(0); + if (StoredVal == GV->getInitializer()) { + if (GS.StoredType < GlobalStatus::isInitializerStored) + GS.StoredType = GlobalStatus::isInitializerStored; + } else if (isa<LoadInst>(StoredVal) && + cast<LoadInst>(StoredVal)->getOperand(0) == GV) { + // G = G if (GS.StoredType < GlobalStatus::isInitializerStored) GS.StoredType = GlobalStatus::isInitializerStored; } else if (GS.StoredType < GlobalStatus::isStoredOnce) { GS.StoredType = GlobalStatus::isStoredOnce; - GS.StoredOnceValue = SI->getOperand(0); + GS.StoredOnceValue = StoredVal; } else if (GS.StoredType == GlobalStatus::isStoredOnce && - GS.StoredOnceValue == SI->getOperand(0)) { + GS.StoredOnceValue == StoredVal) { // noop. } else { GS.StoredType = GlobalStatus::isStored; |