Index: llvm/trunk/lib/LTO/LTOBackend.cpp =================================================================== --- llvm/trunk/lib/LTO/LTOBackend.cpp +++ llvm/trunk/lib/LTO/LTOBackend.cpp @@ -250,10 +250,10 @@ if (Conf.PreOptModuleHook && !Conf.PreOptModuleHook(Task, Mod)) return Error(); - thinLTOResolveWeakForLinkerModule(Mod, DefinedGlobals); - renameModuleForThinLTO(Mod, CombinedIndex); + thinLTOResolveWeakForLinkerModule(Mod, DefinedGlobals); + if (Conf.PostPromoteModuleHook && !Conf.PostPromoteModuleHook(Task, Mod)) return Error(); Index: llvm/trunk/test/ThinLTO/X86/internalize.ll =================================================================== --- llvm/trunk/test/ThinLTO/X86/internalize.ll +++ llvm/trunk/test/ThinLTO/X86/internalize.ll @@ -3,10 +3,19 @@ ; RUN: llvm-lto -thinlto-action=internalize -thinlto-index %t.index.bc %t1.bc -o - | llvm-dis -o - | FileCheck %s --check-prefix=REGULAR ; RUN: llvm-lto -thinlto-action=internalize -thinlto-index %t.index.bc %t1.bc -o - --exported-symbol=foo | llvm-dis -o - | FileCheck %s --check-prefix=INTERNALIZE +; RUN: llvm-lto2 %t1.bc -o %t.o -save-temps \ +; RUN: -r=%t1.bc,_foo,pxl \ +; RUN: -r=%t1.bc,_bar,pl \ +; RUN: -r=%t1.bc,_linkonce_func,pl +; RUN: llvm-dis < %t.o.1.2.internalize.bc | FileCheck %s --check-prefix=INTERNALIZE + + ; REGULAR: define void @foo ; REGULAR: define void @bar +; REGULAR: define linkonce void @linkonce_func() ; INTERNALIZE: define void @foo ; INTERNALIZE: define internal void @bar +; INTERNALIZE: define internal void @linkonce_func() target datalayout = "e-m:o-i64:64-f80:128-n8:16:32:64-S128" target triple = "x86_64-apple-macosx10.11.0" @@ -15,5 +24,9 @@ ret void } define void @bar() { + call void @linkonce_func() + ret void +} +define linkonce void @linkonce_func() { ret void } \ No newline at end of file