If a global is just loaded and restored, realize that it is not changing
authorChris Lattner <sabre@nondot.org>
Sun, 14 Nov 2004 20:50:30 +0000 (20:50 +0000)
committerChris Lattner <sabre@nondot.org>
Sun, 14 Nov 2004 20:50:30 +0000 (20:50 +0000)
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!

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@17746 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Transforms/IPO/GlobalOpt.cpp

index 054c5ee4306cee58598ebb9da3552349211d459c..b8edc32f16f540480477dd1a9118af3bdbcb2d04 100644 (file)
@@ -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;