summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGeorge Rimar <grimar@accesssoftek.com>2019-07-29 07:58:29 +0000
committerGeorge Rimar <grimar@accesssoftek.com>2019-07-29 07:58:29 +0000
commitaef03e86c1c6cadbbb2e7fdd1a2947f7e7cc5961 (patch)
tree6dc064301f97cbdbf5f1adbb893cef5a05e762ef
parent99f73ebe5c96de340c3a148c4a99e4aca5d13b7a (diff)
downloadbcm5719-llvm-aef03e86c1c6cadbbb2e7fdd1a2947f7e7cc5961.tar.gz
bcm5719-llvm-aef03e86c1c6cadbbb2e7fdd1a2947f7e7cc5961.zip
[obj2yaml] - Report a error when unable to resolve a sh_link reference properly.
Because of a bug we did not report a error in the case shown in the test. With this patch we do. Differential revision: https://reviews.llvm.org/D65214 llvm-svn: 367203
-rw-r--r--llvm/test/tools/obj2yaml/elf-shlink.yaml58
-rw-r--r--llvm/tools/obj2yaml/elf2yaml.cpp8
2 files changed, 64 insertions, 2 deletions
diff --git a/llvm/test/tools/obj2yaml/elf-shlink.yaml b/llvm/test/tools/obj2yaml/elf-shlink.yaml
new file mode 100644
index 00000000000..7592b4e818c
--- /dev/null
+++ b/llvm/test/tools/obj2yaml/elf-shlink.yaml
@@ -0,0 +1,58 @@
+## Check obj2yaml reports a proper error when unable to resolve
+## a sh_link reference in a regular section.
+## (We had a bug: the error was silently ignored).
+
+# RUN: yaml2obj --docnum=1 %s -o %t1.o
+# RUN: not obj2yaml %t1.o 2>&1 | FileCheck %s -DFILE=%t1.o --check-prefix=ERR1
+
+## ERR1: Error reading file: [[FILE]]: unable to resolve sh_link reference in section '.test': invalid section index: 100
+
+--- !ELF
+FileHeader:
+ Class: ELFCLASS64
+ Data: ELFDATA2LSB
+ Type: ET_REL
+ Machine: EM_X86_64
+Sections:
+ - Name: .test
+ Type: SHT_PROGBITS
+ Link: 100
+
+## Check obj2yaml produce the correct output when a sh_link
+## reference in a regular section can be resolved.
+
+# RUN: yaml2obj --docnum=2 %s -o %t2.o
+# RUN: obj2yaml %t2.o
+# RUN: llvm-readobj -S %t2.o | FileCheck %s --check-prefix=OK
+
+# OK: Name: .test
+# OK: Link:
+# OK-SAME: 1
+
+--- !ELF
+FileHeader:
+ Class: ELFCLASS64
+ Data: ELFDATA2LSB
+ Type: ET_REL
+ Machine: EM_X86_64
+Sections:
+ - Name: .test
+ Type: SHT_PROGBITS
+ Link: 1
+
+## The same as above, but using a section name instead of the numeric value.
+
+# RUN: yaml2obj --docnum=3 %s -o %t3.o
+# RUN: obj2yaml %t3.o
+# RUN: llvm-readobj -S %t3.o | FileCheck %s --check-prefix=OK
+
+--- !ELF
+FileHeader:
+ Class: ELFCLASS64
+ Data: ELFDATA2LSB
+ Type: ET_REL
+ Machine: EM_X86_64
+Sections:
+ - Name: .test
+ Type: SHT_PROGBITS
+ Link: .test
diff --git a/llvm/tools/obj2yaml/elf2yaml.cpp b/llvm/tools/obj2yaml/elf2yaml.cpp
index bd27c103403..dea3cf73a5d 100644
--- a/llvm/tools/obj2yaml/elf2yaml.cpp
+++ b/llvm/tools/obj2yaml/elf2yaml.cpp
@@ -376,8 +376,12 @@ Error ELFDumper<ELFT>::dumpCommonSection(const Elf_Shdr *Shdr,
if (Shdr->sh_link != ELF::SHN_UNDEF) {
auto LinkSection = Obj.getSection(Shdr->sh_link);
- if (LinkSection.takeError())
- return LinkSection.takeError();
+ if (!LinkSection)
+ return make_error<StringError>(
+ "unable to resolve sh_link reference in section '" + S.Name +
+ "': " + toString(LinkSection.takeError()),
+ inconvertibleErrorCode());
+
NameOrErr = getUniquedSectionName(*LinkSection);
if (!NameOrErr)
return NameOrErr.takeError();
OpenPOWER on IntegriCloud