Skip to content

Commit

Permalink
Merging r358885:
Browse files Browse the repository at this point in the history
------------------------------------------------------------------------
r358885 | grimar | 2019-04-22 06:40:42 -0700 (Mon, 22 Apr 2019) | 8 lines

[LLD][ELF] - Do not forget to use ch_addralign field after decompressing the sections.

LLD did not use ELF::Chdr::ch_addralign for decompressed sections.
This resulted in a broken output.

Fixes https://bugs.llvm.org/show_bug.cgi?id=40482.

Differential revision: https://reviews.llvm.org/D60959
------------------------------------------------------------------------

llvm-svn: 359209
  • Loading branch information
tstellar committed Apr 25, 2019
1 parent 7aa4dc9 commit 604a417
Show file tree
Hide file tree
Showing 2 changed files with 69 additions and 0 deletions.
2 changes: 2 additions & 0 deletions lld/ELF/InputSection.cpp
Expand Up @@ -248,6 +248,7 @@ void InputSectionBase::parseCompressedHeader() {
}

UncompressedSize = Hdr->ch_size;
Alignment = std::max<uint64_t>(Hdr->ch_addralign, 1);
RawData = RawData.slice(sizeof(*Hdr));
return;
}
Expand All @@ -265,6 +266,7 @@ void InputSectionBase::parseCompressedHeader() {
}

UncompressedSize = Hdr->ch_size;
Alignment = std::max<uint64_t>(Hdr->ch_addralign, 1);
RawData = RawData.slice(sizeof(*Hdr));
}

Expand Down
67 changes: 67 additions & 0 deletions lld/test/ELF/compressed-input-alignment.test
@@ -0,0 +1,67 @@
# REQUIRES: zlib, x86

# RUN: yaml2obj -docnum=1 %s -o %t.o
# RUN: ld.lld %t.o %t.o -o %t2
# RUN: llvm-readobj -sections -section-data %t2 | FileCheck %s

# RUN: yaml2obj -docnum=2 %s -o %t.o
# RUN: ld.lld %t.o %t.o -o %t2
# RUN: llvm-readobj -sections -section-data %t2 | FileCheck %s

# CHECK: Name: .debug_info
# CHECK-NEXT: Type: SHT_PROGBITS
# CHECK-NEXT: Flags [
# CHECK-NEXT: ]
# CHECK-NEXT: Address: 0x0
# CHECK-NEXT: Offset: 0xE8
# CHECK-NEXT: Size: 108
# CHECK-NEXT: Link: 0
# CHECK-NEXT: Info: 0
# CHECK-NEXT: AddressAlignment: 1
# CHECK-NEXT: EntrySize: 0
# CHECK-NEXT: SectionData (
# CHECK-NEXT: 0000: {{.*}} |ABCDEFGHIJKLMNOP|
# CHECK-NEXT: 0010: {{.*}} |QRSTUVWXYZ.ABCDE|
# CHECK-NEXT: 0020: {{.*}} |FGHIJKLMNOPQRSTU|
# CHECK-NEXT: 0030: {{.*}} |VWXYZ.ABCDEFGHIJ|
# CHECK-NEXT: 0040: {{.*}} |KLMNOPQRSTUVWXYZ|
# CHECK-NEXT: 0050: {{.*}} |.ABCDEFGHIJKLMNO|
# CHECK-NEXT: 0060: {{.*}} |PQRSTUVWXYZ.|
# CHECK-NEXT: )
# CHECK-NEXT: }

## YAML below is produced from the following code. AddressAlign of .debug_info is 8,
## while compressed header has ch_addralign = 1. LLD had a bug and did not use the
## value of ch_addralign at all. We produced broken section content.
##
## .section .debug_info,"",@progbits
## .string "ABCDEFGHIJKLMNOPQRSTUVWXYZ"
## .string "ABCDEFGHIJKLMNOPQRSTUVWXYZ"

--- !ELF
FileHeader:
Class: ELFCLASS64
Data: ELFDATA2LSB
Type: ET_REL
Machine: EM_X86_64
Sections:
- Name: .debug_info
Type: SHT_PROGBITS
Flags: [ SHF_COMPRESSED ]
AddressAlign: 0x0000000000000008
Content: 010000000000000036000000000000000100000000000000789C73747276717573F7F0F4F2F6F1F5F30F080C0A0E090D0B8F888C6270C42D0500ADA00FBF

## YAML below is the same as above, with a single change: ch_addralign field of the compressed
## header was set to 0. This is allowed by the standard, we have to support it.
--- !ELF
FileHeader:
Class: ELFCLASS64
Data: ELFDATA2LSB
Type: ET_REL
Machine: EM_X86_64
Sections:
- Name: .debug_info
Type: SHT_PROGBITS
Flags: [ SHF_COMPRESSED ]
AddressAlign: 0x0000000000000008
Content: 010000000000000036000000000000000000000000000000789C73747276717573F7F0F4F2F6F1F5F30F080C0A0E090D0B8F888C6270C42D0500ADA00FBF

0 comments on commit 604a417

Please sign in to comment.