Resolve aliases, when possible
authorAnton Korobeynikov <asl@math.spbu.ru>
Tue, 9 Sep 2008 19:04:59 +0000 (19:04 +0000)
committerAnton Korobeynikov <asl@math.spbu.ru>
Tue, 9 Sep 2008 19:04:59 +0000 (19:04 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@56001 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Transforms/IPO/GlobalOpt.cpp
test/Transforms/GlobalOpt/alias-resolve.ll [new file with mode: 0644]

index f9a7c73534b0e61a351969b22ae661ab5b528d17..8c6631aa2bcbc25e4ab70e4ef2444cf62b351862 100644 (file)
@@ -65,6 +65,7 @@ namespace {
     GlobalVariable *FindGlobalCtors(Module &M);
     bool OptimizeFunctions(Module &M);
     bool OptimizeGlobalVars(Module &M);
+    bool ResolveAliases(Module &M);
     bool OptimizeGlobalCtorsList(GlobalVariable *&GCL);
     bool ProcessInternalGlobal(GlobalVariable *GV,Module::global_iterator &GVI);
   };
@@ -2214,6 +2215,23 @@ bool GlobalOpt::OptimizeGlobalCtorsList(GlobalVariable *&GCL) {
   return true;
 }
 
+bool GlobalOpt::ResolveAliases(Module &M) {
+  bool Changed = false;
+
+  for (Module::alias_iterator I = M.alias_begin(),
+         E = M.alias_end(); I != E; ++I) {
+    if (I->use_empty())
+      continue;
+
+    if (const GlobalValue *GV = I->resolveAliasedGlobal(/*traverseWeak*/ false))
+      if (GV != I) {
+        I->replaceAllUsesWith(const_cast<GlobalValue*>(GV));
+        Changed = true;
+      }
+  }
+
+  return Changed;
+}
 
 bool GlobalOpt::runOnModule(Module &M) {
   bool Changed = false;
@@ -2235,6 +2253,10 @@ bool GlobalOpt::runOnModule(Module &M) {
     // Optimize non-address-taken globals.
     LocalChange |= OptimizeGlobalVars(M);
     Changed |= LocalChange;
+
+    // Resolve aliases, when possible.
+    LocalChange |= ResolveAliases(M);
+    Changed |= LocalChange;
   }
   
   // TODO: Move all global ctors functions to the end of the module for code
diff --git a/test/Transforms/GlobalOpt/alias-resolve.ll b/test/Transforms/GlobalOpt/alias-resolve.ll
new file mode 100644 (file)
index 0000000..3cae413
--- /dev/null
@@ -0,0 +1,19 @@
+; RUN: llvm-as < %s | opt -globalopt | llvm-dis > %t
+; RUN: cat %t | grep foo1 | count 1
+; RUN: cat %t | grep foo2 | count 4
+; RUN: cat %t | grep bar1 | count 1
+; RUN: cat %t | grep bar2 | count 4
+
+@foo1 = alias void ()* @foo2
+@foo2 = alias weak void()* @bar1
+@bar1  = alias void ()* @bar2
+
+declare void @bar2()
+
+define void @baz() {
+entry:
+        call void @foo1()
+        call void @foo2()
+        call void @bar1()
+        ret void
+}