mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-12-25 21:16:19 +00:00
Resolve aliases, when possible
llvm-svn: 56001
This commit is contained in:
parent
727b25981a
commit
4676c09dc8
@ -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
|
||||
|
19
test/Transforms/GlobalOpt/alias-resolve.ll
Normal file
19
test/Transforms/GlobalOpt/alias-resolve.ll
Normal file
@ -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
|
||||
}
|
Loading…
Reference in New Issue
Block a user