[PATCH] D30188: [ELF] - Do not segfault when using --gc-sections with linker script

George Rimar via Phabricator via llvm-commits llvm-commits at lists.llvm.org
Tue Feb 21 07:58:26 PST 2017


This revision was automatically updated to reflect the committed changes.
Closed by commit rL295727: [ELF] - Do not segfault when using --gc-sections with linker script (authored by grimar).

Changed prior to commit:
  https://reviews.llvm.org/D30188?vs=89191&id=89217#toc

Repository:
  rL LLVM

https://reviews.llvm.org/D30188

Files:
  lld/trunk/ELF/LinkerScript.cpp
  lld/trunk/test/ELF/linkerscript/sections-gc.s


Index: lld/trunk/ELF/LinkerScript.cpp
===================================================================
--- lld/trunk/ELF/LinkerScript.cpp
+++ lld/trunk/ELF/LinkerScript.cpp
@@ -503,6 +503,8 @@
         continue;
 
     auto *IB = static_cast<InputSectionBase<ELFT> *>(ID);
+    if (!IB->Live)
+      continue;
     switchTo(IB->OutSec);
     if (auto *I = dyn_cast<InputSection<ELFT>>(IB))
       output(I);
Index: lld/trunk/test/ELF/linkerscript/sections-gc.s
===================================================================
--- lld/trunk/test/ELF/linkerscript/sections-gc.s
+++ lld/trunk/test/ELF/linkerscript/sections-gc.s
@@ -0,0 +1,19 @@
+# REQUIRES: x86
+# RUN: llvm-mc -filetype=obj -triple=x86_64-unknown-linux %s -o %t
+# RUN: echo "SECTIONS { .text : { *(.text*) } }" > %t.script
+# RUN: ld.lld %t --gc-sections --script %t.script -o %t1
+# RUN: llvm-objdump -section-headers %t1 | FileCheck %s
+
+# CHECK:      Sections:
+# CHECK-NEXT:  Name      Size
+# CHECK:       .text     00000001
+
+.section .text.foo, "ax"
+.global _start
+_start:
+  nop
+
+.section .text.bar, "ax"
+.global bar
+bar:
+  nop


-------------- next part --------------
A non-text attachment was scrubbed...
Name: D30188.89217.patch
Type: text/x-patch
Size: 1118 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20170221/cafbca42/attachment.bin>


More information about the llvm-commits mailing list