[lld] r367515 - [ELF] Fix finding locations in messages for undefined hidden symbols.
Igor Kudrin via llvm-commits
llvm-commits at lists.llvm.org
Wed Jul 31 22:23:46 PDT 2019
Author: ikudrin
Date: Wed Jul 31 22:23:45 2019
New Revision: 367515
URL: http://llvm.org/viewvc/llvm-project?rev=367515&view=rev
Log:
[ELF] Fix finding locations in messages for undefined hidden symbols.
Previously, when `--vs-diagnostics` was used, the linker printed
something like
hidden(undef.s): error: undefined hidden symbol: foo
>>> referenced by undef.s:15
Differential Revision: https://reviews.llvm.org/D65499
Added:
lld/trunk/test/ELF/vs-diagnostics-undefined-hidden.s
Modified:
lld/trunk/Common/ErrorHandler.cpp
Modified: lld/trunk/Common/ErrorHandler.cpp
URL: http://llvm.org/viewvc/llvm-project/lld/trunk/Common/ErrorHandler.cpp?rev=367515&r1=367514&r2=367515&view=diff
==============================================================================
--- lld/trunk/Common/ErrorHandler.cpp (original)
+++ lld/trunk/Common/ErrorHandler.cpp Wed Jul 31 22:23:45 2019
@@ -87,7 +87,7 @@ void lld::checkError(Error e) {
static std::string getLocation(std::string msg, std::string defaultMsg) {
static std::vector<std::regex> Regexes{
- std::regex(R"(^undefined symbol:.*\n>>> referenced by (\S+):(\d+)\n.*)"),
+ std::regex(R"(^undefined (?:\S+ )?symbol:.*\n>>> referenced by (\S+):(\d+)\n.*)"),
std::regex(R"(^undefined symbol:.*\n>>> referenced by (.*):)"),
std::regex(
R"(^duplicate symbol: .*\n>>> defined in (\S+)\n>>> defined in.*)"),
@@ -95,8 +95,6 @@ static std::string getLocation(std::stri
R"(^duplicate symbol: .*\n>>> defined at (\S+):(\d+).*)"),
std::regex(
R"(.*\n>>> defined in .*\n>>> referenced by (\S+):(\d+))"),
- std::regex(
- R"(^undefined (internal|hidden|protected) symbol: .*\n>>> referenced by (\S+):(\d+)\n.*)"),
std::regex(R"((\S+):(\d+): unclosed quote)"),
};
Added: lld/trunk/test/ELF/vs-diagnostics-undefined-hidden.s
URL: http://llvm.org/viewvc/llvm-project/lld/trunk/test/ELF/vs-diagnostics-undefined-hidden.s?rev=367515&view=auto
==============================================================================
--- lld/trunk/test/ELF/vs-diagnostics-undefined-hidden.s (added)
+++ lld/trunk/test/ELF/vs-diagnostics-undefined-hidden.s Wed Jul 31 22:23:45 2019
@@ -0,0 +1,42 @@
+// REQUIRES: x86
+// RUN: llvm-mc -filetype=obj -triple=x86_64 %s -o %t.o
+// RUN: not ld.lld --vs-diagnostics -shared %t.o -o /dev/null 2>&1 \
+// RUN: | FileCheck %s
+
+// CHECK: undef.s(15): error: undefined hidden symbol: foo
+// CHECK-NEXT: >>> referenced by undef.s:15
+
+// CHECK: undef.s(27): error: undefined protected symbol: bar
+// CHECK-NEXT: >>> referenced by undef.s:27
+
+.file 1 "undef.s"
+
+.hidden foo
+.protected bar
+.text
+_start:
+.loc 1 15
+ jmp foo
+.loc 1 27
+ jmp bar
+
+.section .debug_abbrev,"", at progbits
+ .byte 1 # Abbreviation Code
+ .byte 17 # DW_TAG_compile_unit
+ .byte 0 # DW_CHILDREN_no
+ .byte 16 # DW_AT_stmt_list
+ .byte 23 # DW_FORM_sec_offset
+ .byte 0 # EOM(1)
+ .byte 0 # EOM(2)
+ .byte 0 # EOM(3)
+
+.section .debug_info,"", at progbits
+ .long .Lend0 - .Lbegin0 # Length of Unit
+.Lbegin0:
+ .short 4 # DWARF version number
+ .long .debug_abbrev # Offset Into Abbrev. Section
+ .byte 8 # Address Size (in bytes)
+ .byte 1 # Abbrev [1] 0xb:0x1f DW_TAG_compile_unit
+ .long .debug_line # DW_AT_stmt_list
+.Lend0:
+ .section .debug_line,"", at progbits
More information about the llvm-commits
mailing list