[PATCH] D29276: [ELF] - Linkerscript: do not fail on additional semicolons in linkerscript.
George Rimar via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Mon Jan 30 07:17:23 PST 2017
grimar updated this revision to Diff 86283.
grimar added a comment.
- Addressed review comments.
https://reviews.llvm.org/D29276
Files:
ELF/LinkerScript.cpp
test/ELF/linkerscript/sections.s
Index: test/ELF/linkerscript/sections.s
===================================================================
--- test/ELF/linkerscript/sections.s
+++ test/ELF/linkerscript/sections.s
@@ -93,6 +93,11 @@
# SEC-MULTI: 6 .shstrtab 00000035 {{[0-9a-f]*}}
# SEC-MULTI: 7 .strtab 00000008 {{[0-9a-f]*}}
+# Input section pattern contains additional semicolon.
+# Case found in linux kernel script. Check we are able to parse it.
+# RUN: echo "SECTIONS { .text : { ;;*(.text);;S = 0;; } }" > %t.script
+# RUN: ld.lld -o /dev/null --script %t.script %t
+
.globl _start
_start:
mov $60, %rax
Index: ELF/LinkerScript.cpp
===================================================================
--- ELF/LinkerScript.cpp
+++ ELF/LinkerScript.cpp
@@ -1493,7 +1493,9 @@
while (!Error && !consume("}")) {
StringRef Tok = next();
- if (SymbolAssignment *Assignment = readProvideOrAssignment(Tok)) {
+ if (Tok == ";") {
+ // Unnecessary semicolons are permitted here, but should be ignored.
+ } else if (SymbolAssignment *Assignment = readProvideOrAssignment(Tok)) {
Cmd->Commands.emplace_back(Assignment);
} else if (BytesDataCommand *Data = readBytesDataCommand(Tok)) {
Cmd->Commands.emplace_back(Data);
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D29276.86283.patch
Type: text/x-patch
Size: 1245 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20170130/f81ea81b/attachment-0001.bin>
More information about the llvm-commits
mailing list