diff options
| author | Rumeet Dhindsa <rdhindsa@google.com> | 2018-03-30 20:49:34 +0000 |
|---|---|---|
| committer | Rumeet Dhindsa <rdhindsa@google.com> | 2018-03-30 20:49:34 +0000 |
| commit | 7588a8e89d6ba615a06d7d3dbba1f38e745c1ed3 (patch) | |
| tree | dd395d5ea4a232e2a5425e28ede8a9d4a26b2638 | |
| parent | 40926451d2aaf5498acb3891f46b78f54b7fcbe1 (diff) | |
| download | bcm5719-llvm-7588a8e89d6ba615a06d7d3dbba1f38e745c1ed3.tar.gz bcm5719-llvm-7588a8e89d6ba615a06d7d3dbba1f38e745c1ed3.zip | |
Initialize Elf Header to zero to ensure that bytes not assigned any value later on are initialized properly.
Differential Revision: https://reviews.llvm.org/D44986
llvm-svn: 328902
| -rw-r--r-- | lld/ELF/Writer.cpp | 4 | ||||
| -rw-r--r-- | lld/test/ELF/elf-header.s | 18 |
2 files changed, 22 insertions, 0 deletions
diff --git a/lld/ELF/Writer.cpp b/lld/ELF/Writer.cpp index 4868a11a1c8..e685c8ec4e5 100644 --- a/lld/ELF/Writer.cpp +++ b/lld/ELF/Writer.cpp @@ -2092,6 +2092,10 @@ static uint8_t getAbiVersion() { template <class ELFT> void Writer<ELFT>::writeHeader() { uint8_t *Buf = Buffer->getBufferStart(); + // For executable segments, the trap instructions are written before writing + // the header. Setting Elf header bytes to zero ensures that any unused bytes + // in header are zero-cleared, instead of having trap instructions. + memset(Buf, 0, sizeof(Elf_Ehdr)); memcpy(Buf, "\177ELF", 4); // Write the ELF header. diff --git a/lld/test/ELF/elf-header.s b/lld/test/ELF/elf-header.s new file mode 100644 index 00000000000..e188650f731 --- /dev/null +++ b/lld/test/ELF/elf-header.s @@ -0,0 +1,18 @@ +# REQUIRES: x86 +# RUN: llvm-mc -filetype=obj -triple=x86_64-pc-linux %s -o %t.o +# RUN: ld.lld %t.o -o %t1 +# RUN: llvm-readobj -file-headers %t1 | FileCheck %s + +# RUN: ld.lld %t.o -no-rosegment -o %t2 +# RUN: llvm-readobj -file-headers %t2 | FileCheck %s + +# CHECK: ElfHeader { +# CHECK-NEXT: Ident { +# CHECK-NEXT: Magic: (7F 45 4C 46) +# CHECK-NEXT: Class: 64-bit (0x2) +# CHECK-NEXT: DataEncoding: LittleEndian (0x1) +# CHECK-NEXT: FileVersion: 1 +# CHECK-NEXT: OS/ABI: SystemV (0x0) +# CHECK-NEXT: ABIVersion: 0 +# CHECK-NEXT: Unused: (00 00 00 00 00 00 00) +# CHECK-NEXT: } |

