diff options
author | George Rimar <grimar@accesssoftek.com> | 2019-07-29 07:58:29 +0000 |
---|---|---|
committer | George Rimar <grimar@accesssoftek.com> | 2019-07-29 07:58:29 +0000 |
commit | aef03e86c1c6cadbbb2e7fdd1a2947f7e7cc5961 (patch) | |
tree | 6dc064301f97cbdbf5f1adbb893cef5a05e762ef | |
parent | 99f73ebe5c96de340c3a148c4a99e4aca5d13b7a (diff) | |
download | bcm5719-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.yaml | 58 | ||||
-rw-r--r-- | llvm/tools/obj2yaml/elf2yaml.cpp | 8 |
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(); |