diff options
author | George Rimar <grimar@accesssoftek.com> | 2016-10-04 08:49:52 +0000 |
---|---|---|
committer | George Rimar <grimar@accesssoftek.com> | 2016-10-04 08:49:52 +0000 |
commit | 0c82561c4c5aced6caaf3a1d56d7704d95e3eae8 (patch) | |
tree | 396e0e242fb58fb014be7292862160a6c360ea54 | |
parent | 5cbf23664d7ad269b4c824ae3e86d6e9d1ec3c0a (diff) | |
download | bcm5719-llvm-0c82561c4c5aced6caaf3a1d56d7704d95e3eae8.tar.gz bcm5719-llvm-0c82561c4c5aced6caaf3a1d56d7704d95e3eae8.zip |
[ELF] - Do not crash if common symbol has alignment 0.
Testcase contains a common symbol with zero alignment,
previously lld would crash, patch fixes that.
Differential revision: https://reviews.llvm.org/D25085
llvm-svn: 283197
-rw-r--r-- | lld/ELF/InputFiles.cpp | 3 | ||||
-rw-r--r-- | lld/test/ELF/invalid/Inputs/common-symbol-alignment.elf | bin | 0 -> 456 bytes | |||
-rw-r--r-- | lld/test/ELF/invalid/common-symbol-alignment.s | 6 |
3 files changed, 9 insertions, 0 deletions
diff --git a/lld/ELF/InputFiles.cpp b/lld/ELF/InputFiles.cpp index 9d229564ade..0981e2cd48f 100644 --- a/lld/ELF/InputFiles.cpp +++ b/lld/ELF/InputFiles.cpp @@ -400,6 +400,9 @@ SymbolBody *elf::ObjectFile<ELFT>::createSymbolBody(const Elf_Sym *Sym) { /*CanOmitFromDynSym*/ false, this) ->body(); case SHN_COMMON: + if (Sym->st_value == 0) + fatal(getFilename(this) + ": common symbol '" + Name + + "' alignment is 0"); return elf::Symtab<ELFT>::X->addCommon(Name, Sym->st_size, Sym->st_value, Binding, Sym->st_other, Sym->getType(), this) diff --git a/lld/test/ELF/invalid/Inputs/common-symbol-alignment.elf b/lld/test/ELF/invalid/Inputs/common-symbol-alignment.elf Binary files differnew file mode 100644 index 00000000000..9e7823b852b --- /dev/null +++ b/lld/test/ELF/invalid/Inputs/common-symbol-alignment.elf diff --git a/lld/test/ELF/invalid/common-symbol-alignment.s b/lld/test/ELF/invalid/common-symbol-alignment.s new file mode 100644 index 00000000000..671205f87cc --- /dev/null +++ b/lld/test/ELF/invalid/common-symbol-alignment.s @@ -0,0 +1,6 @@ +# REQUIRES: x86 + +## common-symbol-alignment.elf contains common symbol with zero alignment. +# RUN: not ld.lld %S/Inputs/common-symbol-alignment.elf \ +# RUN: -o %t 2>&1 | FileCheck %s +# CHECK: common symbol 'bar' alignment is 0 |