[PATCH] D42798: [ThinLTO] - Fix for "ThinLTO inlines variables that should be discarded".

George Rimar via Phabricator via llvm-commits llvm-commits at lists.llvm.org
Thu Feb 1 08:03:47 PST 2018


grimar created this revision.
grimar added reviewers: tejohnson, pcc, rafael.
Herald added subscribers: inglorion, mehdi_amini.

This fixes PR36187.

Patch teaches ThinLTO to drop non-prevailing variables, 
just like we recently did for functions (in r323633).


https://reviews.llvm.org/D42798

Files:
  lib/LTO/LTOBackend.cpp
  test/LTO/Resolution/X86/not-prevailing-variables.ll
  test/tools/gold/X86/global_with_section.ll


Index: test/tools/gold/X86/global_with_section.ll
===================================================================
--- test/tools/gold/X86/global_with_section.ll
+++ test/tools/gold/X86/global_with_section.ll
@@ -45,7 +45,9 @@
 
 ; Confirm via a variable with a non-C identifier section that we are getting
 ; the expected internalization.
-; CHECK-DAG: @var_with_nonC_section = internal global i32 0, section ".nonCsection"
+; CHECK-REGULARLTO-DAG: @var_with_nonC_section = internal global i32 0, section ".nonCsection"
+; Check we dropped definition of dead variable.
+; CHECK-THINLTO-DAG: @var_with_nonC_section = external dso_local global i32, section ".nonCsection"
 @var_with_nonC_section = global i32 0, section ".nonCsection"
 
 ; We should not internalize @deadfunc_with_section due to section
Index: test/LTO/Resolution/X86/not-prevailing-variables.ll
===================================================================
--- test/LTO/Resolution/X86/not-prevailing-variables.ll
+++ test/LTO/Resolution/X86/not-prevailing-variables.ll
@@ -0,0 +1,35 @@
+; RUN: opt -module-summary %s -o %t1.o
+; RUN: llvm-lto2 run -save-temps -o %t2.o %t1.o      \
+; RUN:   -r %t1.o,testVar1,plx -r %t1.o,testVar2,plx \
+; RUN:   -r %t1.o,var1,pl -r %t1.o,var2,lx
+
+; Test contains two variables: var1 and var2.
+; var2 is not prevailing and here we check it is not inlined.
+
+; Check 'var2' was not inlined.
+; RUN: llvm-objdump -d %t2.o.1 | FileCheck %s
+; CHECK:      testVar1:
+; CHECK-NEXT:   movl $10, %eax
+; CHECK-NEXT:   retq
+; CHECK:      testVar2:
+; CHECK-NEXT:   movl  (%rip), %eax
+; CHECK-NEXT:   retq
+
+; Check 'var2' is undefined.
+; RUN: llvm-readelf --symbols %t2.o.1 | FileCheck %s --check-prefix=UND
+; UND: NOTYPE  GLOBAL DEFAULT UND var2
+
+target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128"
+target triple = "x86_64-unknown-linux-gnu"
+
+ at var1 = global i32 10, align 4
+define i32 @testVar1() {
+  %1 = load i32, i32* @var1, align 4
+  ret i32 %1
+}
+
+ at var2 = global i32 11, align 4
+define i32 @testVar2() {
+  %1 = load i32, i32* @var2, align 4
+  ret i32 %1
+}
Index: lib/LTO/LTOBackend.cpp
===================================================================
--- lib/LTO/LTOBackend.cpp
+++ lib/LTO/LTOBackend.cpp
@@ -401,13 +401,17 @@
 
 static void dropDeadSymbols(Module &Mod, const GVSummaryMapTy &DefinedGlobals,
                             const ModuleSummaryIndex &Index) {
-  for (auto &GV : Mod) {
+  auto MaybeDrop = [&](GlobalValue &GV) {
     auto It = DefinedGlobals.find(GV.getGUID());
-    if (It == DefinedGlobals.end())
-      continue;
-    if (!Index.isGlobalValueLive(It->second))
-      convertToDeclaration(GV);
-  }
+    if (It != DefinedGlobals.end())
+      if (!Index.isGlobalValueLive(It->second))
+        convertToDeclaration(GV);
+  };
+
+  for (auto &GV : Mod)
+    MaybeDrop(GV);
+  for (auto &GV : Mod.globals())
+    MaybeDrop(GV);
 }
 
 Error lto::thinBackend(Config &Conf, unsigned Task, AddStreamFn AddStream,


-------------- next part --------------
A non-text attachment was scrubbed...
Name: D42798.132399.patch
Type: text/x-patch
Size: 2982 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20180201/600644e5/attachment.bin>


More information about the llvm-commits mailing list