[PATCH] D93925: [ELF] Drop '>>> defined in ' for locations of linker synthesized symbols
Fangrui Song via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Tue Dec 29 15:13:47 PST 2020
MaskRay created this revision.
MaskRay added reviewers: grimar, psmith.
Herald added subscribers: arichardson, emaste.
Herald added a reviewer: espindola.
MaskRay requested review of this revision.
Herald added a project: LLVM.
Herald added a subscriber: llvm-commits.
Repository:
rG LLVM Github Monorepo
https://reviews.llvm.org/D93925
Files:
lld/ELF/Relocations.cpp
lld/test/ELF/x86-64-gotpc-err.s
Index: lld/test/ELF/x86-64-gotpc-err.s
===================================================================
--- lld/test/ELF/x86-64-gotpc-err.s
+++ lld/test/ELF/x86-64-gotpc-err.s
@@ -3,23 +3,24 @@
# RUN: llvm-mc -filetype=obj -triple=x86_64 %t/a.s -o %t/a.o
# RUN: not ld.lld -T %t/lds %t/a.o -o /dev/null 2>&1 | FileCheck %s
-# CHECK: error: {{.*}}:(.text+0x2): relocation R_X86_64_GOTPCRELX out of range: 2147483655 is not in [-2147483648, 2147483647]; references data
-# CHECK: error: {{.*}}:(.text+0x9): relocation R_X86_64_REX_GOTPCRELX out of range: 2147483648 is not in [-2147483648, 2147483647]; references data
+## Test diagnostics for GOTPCRELX overflows. In addition, test that there is no
+## `>>> defined in` for linker synthesized __stop_* symbols (there is no
+## associated file or linker script line number).
+
+# CHECK: error: {{.*}}:(.text+0x2): relocation R_X86_64_GOTPCRELX out of range: 2147483655 is not in [-2147483648, 2147483647]; references __stop_data
+# CHECK-NEXT: error: {{.*}}:(.text+0x9): relocation R_X86_64_REX_GOTPCRELX out of range: 2147483648 is not in [-2147483648, 2147483647]; references __stop_data
# CHECK-NOT: error:
#--- a.s
- movl data at GOTPCREL(%rip), %eax # out of range
- movq data at GOTPCREL(%rip), %rax # out of range
- movq data at GOTPCREL(%rip), %rax # in range
+ movl __stop_data at GOTPCREL(%rip), %eax # out of range
+ movq __stop_data at GOTPCREL(%rip), %rax # out of range
+ movq __stop_data at GOTPCREL(%rip), %rax # in range
-.data
+.section data,"aw", at progbits
.space 13
-.globl data
-data:
- .long 0
#--- lds
SECTIONS {
.text 0x200000 : { *(.text) }
- .data 0x80200000 : { *(.data) }
+ data 0x80200000 : { *(data) }
}
Index: lld/ELF/Relocations.cpp
===================================================================
--- lld/ELF/Relocations.cpp
+++ lld/ELF/Relocations.cpp
@@ -74,12 +74,12 @@
}
static std::string getDefinedLocation(const Symbol &sym) {
- std::string msg = "\n>>> defined in ";
+ const char msg[] = "\n>>> defined in ";
if (sym.file)
- msg += toString(sym.file);
- else if (Optional<std::string> loc = getLinkerScriptLocation(sym))
- msg += *loc;
- return msg;
+ return msg + toString(sym.file);
+ if (Optional<std::string> loc = getLinkerScriptLocation(sym))
+ return msg + *loc;
+ return {};
}
// Construct a message in the following format.
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D93925.314030.patch
Type: text/x-patch
Size: 2385 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20201229/aec475a0/attachment.bin>
More information about the llvm-commits
mailing list