[lld] r298577 - [ELF] Allow references to reserved symbols in linker scripts
Petr Hosek via llvm-commits
llvm-commits at lists.llvm.org
Wed Mar 22 20:52:35 PDT 2017
Author: phosek
Date: Wed Mar 22 22:52:34 2017
New Revision: 298577
URL: http://llvm.org/viewvc/llvm-project?rev=298577&view=rev
Log:
[ELF] Allow references to reserved symbols in linker scripts
This requires collectign all symbols referenced in the linker script
and adding them to symbol table as undefined symbol.
Differential Revision: https://reviews.llvm.org/D31147
Added:
lld/trunk/test/ELF/linkerscript/symbol-reserved.s
Modified:
lld/trunk/ELF/Driver.cpp
lld/trunk/ELF/LinkerScript.cpp
lld/trunk/ELF/LinkerScript.h
Modified: lld/trunk/ELF/Driver.cpp
URL: http://llvm.org/viewvc/llvm-project/lld/trunk/ELF/Driver.cpp?rev=298577&r1=298576&r2=298577&view=diff
==============================================================================
--- lld/trunk/ELF/Driver.cpp (original)
+++ lld/trunk/ELF/Driver.cpp Wed Mar 22 22:52:34 2017
@@ -921,6 +921,11 @@ template <class ELFT> void LinkerDriver:
if (ErrorCount)
return;
+ // Some symbols (such as __ehdr_start) are defined lazily only when there
+ // are undefined symbols for them, so we add these to trigger that logic.
+ for (StringRef Sym : Script->Opt.UndefinedSymbols)
+ Symtab.addUndefined(Sym);
+
for (auto *Arg : Args.filtered(OPT_wrap))
Symtab.wrap(Arg->getValue());
Modified: lld/trunk/ELF/LinkerScript.cpp
URL: http://llvm.org/viewvc/llvm-project/lld/trunk/ELF/LinkerScript.cpp?rev=298577&r1=298576&r2=298577&view=diff
==============================================================================
--- lld/trunk/ELF/LinkerScript.cpp (original)
+++ lld/trunk/ELF/LinkerScript.cpp Wed Mar 22 22:52:34 2017
@@ -999,8 +999,8 @@ ExprValue LinkerScript::getSymbolValue(c
if (SymbolBody *B = findSymbol(S)) {
if (auto *D = dyn_cast<DefinedRegular>(B))
return {D->Section, D->Value};
- auto *C = cast<DefinedCommon>(B);
- return {InX::Common, C->Offset};
+ if (auto *C = dyn_cast<DefinedCommon>(B))
+ return {InX::Common, C->Offset};
}
error(Loc + ": symbol not found: " + S);
return 0;
@@ -1867,8 +1867,11 @@ Expr ScriptParser::readPrimary() {
return [=] { return V; };
// Tok is a symbol name.
- if (Tok != "." && !isValidCIdentifier(Tok))
- setError("malformed number: " + Tok);
+ if (Tok != ".") {
+ if (!isValidCIdentifier(Tok))
+ setError("malformed number: " + Tok);
+ Script->Opt.UndefinedSymbols.push_back(Tok);
+ }
return [=] { return Script->getSymbolValue(Location, Tok); };
}
Modified: lld/trunk/ELF/LinkerScript.h
URL: http://llvm.org/viewvc/llvm-project/lld/trunk/ELF/LinkerScript.h?rev=298577&r1=298576&r2=298577&view=diff
==============================================================================
--- lld/trunk/ELF/LinkerScript.h (original)
+++ lld/trunk/ELF/LinkerScript.h Wed Mar 22 22:52:34 2017
@@ -217,6 +217,9 @@ struct ScriptConfiguration {
// A map from memory region name to a memory region descriptor.
llvm::DenseMap<llvm::StringRef, MemoryRegion> MemoryRegions;
+
+ // A list of undefined symbols referenced by the script.
+ std::vector<llvm::StringRef> UndefinedSymbols;
};
class LinkerScript {
Added: lld/trunk/test/ELF/linkerscript/symbol-reserved.s
URL: http://llvm.org/viewvc/llvm-project/lld/trunk/test/ELF/linkerscript/symbol-reserved.s?rev=298577&view=auto
==============================================================================
--- lld/trunk/test/ELF/linkerscript/symbol-reserved.s (added)
+++ lld/trunk/test/ELF/linkerscript/symbol-reserved.s Wed Mar 22 22:52:34 2017
@@ -0,0 +1,16 @@
+# REQUIRES: x86
+# RUN: llvm-mc -filetype=obj -triple=x86_64-unknown-linux %s -o %t
+# RUN: echo "PROVIDE_HIDDEN(newsym = __ehdr_start + 5);" > %t.script
+# RUN: ld.lld -o %t1 %t.script %t
+# RUN: llvm-objdump -t %t1 | FileCheck %s
+
+# CHECK: 0000000000200005 .text 00000000 .hidden newsym
+
+# RUN: ld.lld -o %t1.so %t.script %t -shared
+# RUN: llvm-objdump -t %t1.so | FileCheck --check-prefix=SHARED %s
+
+# SHARED: 0000000000000005 .dynsym 00000000 .hidden newsym
+
+.global _start
+_start:
+ lea newsym(%rip),%rax
More information about the llvm-commits
mailing list