mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-25 04:02:41 +01:00
da574d3bff
For sections with different virtual and physical addresses, alignment and placement in the output binary should be based on the physical address. Ran into this problem with a bare metal ARM project where llvm-objcopy added a lot of zero-padding before the .data section that had differing addresses. GNU objcopy did not add the padding, and after this fix, neither does llvm-objcopy. Update a test case so a section has different physical and virtual addresses. Fixes B35708 Authored By: Owen Shaw (owenpshaw) Differential Revision: https://reviews.llvm.org/D41619 llvm-svn: 323144
62 lines
1.6 KiB
Plaintext
62 lines
1.6 KiB
Plaintext
# RUN: yaml2obj %s -o %t
|
|
# RUN: llvm-objcopy -R .text4 -O binary %t %t2
|
|
# RUN: od -Ax -v -t x1 %t2 | FileCheck %s
|
|
# RUN: wc -c %t2 | FileCheck %s -check-prefix=SIZE
|
|
|
|
!ELF
|
|
FileHeader:
|
|
Class: ELFCLASS64
|
|
Data: ELFDATA2LSB
|
|
Type: ET_EXEC
|
|
Machine: EM_X86_64
|
|
Sections:
|
|
- Name: .text
|
|
Type: SHT_PROGBITS
|
|
Flags: [ SHF_ALLOC, SHF_EXECINSTR ]
|
|
Address: 0x1000
|
|
AddressAlign: 0x1000
|
|
Content: "c3c3c3c3"
|
|
Size: 0x1000
|
|
- Name: .text2
|
|
Type: SHT_PROGBITS
|
|
Flags: [ SHF_ALLOC, SHF_EXECINSTR ]
|
|
Address: 0x2000
|
|
AddressAlign: 0x1000
|
|
Content: "DEADBEEF"
|
|
Size: 0x1000
|
|
- Name: .text3
|
|
Type: SHT_PROGBITS
|
|
Flags: [ SHF_ALLOC, SHF_EXECINSTR ]
|
|
Address: 0x3000
|
|
AddressAlign: 0x1000
|
|
Content: "32323232"
|
|
Size: 0x1000
|
|
- Name: .text4
|
|
Type: SHT_PROGBITS
|
|
Flags: [ SHF_ALLOC, SHF_EXECINSTR ]
|
|
Address: 0x4000
|
|
AddressAlign: 0x1000
|
|
Content: "FFFFFFFF"
|
|
Size: 0x1000
|
|
ProgramHeaders:
|
|
- Type: PT_LOAD
|
|
Flags: [ PF_R ]
|
|
VAddr: 0x1000
|
|
PAddr: 0x1000
|
|
Sections:
|
|
- Section: .text
|
|
- Section: .text2
|
|
- Type: PT_LOAD
|
|
Flags: [ PF_R ]
|
|
VAddr: 0x3000
|
|
PAddr: 0x3000
|
|
Sections:
|
|
- Section: .text3
|
|
- Section: .text4
|
|
|
|
# CHECK: 000000 c3 c3 c3 c3
|
|
# CHECK: 001000 de ad be ef
|
|
# CHECK: 002000 32 32 32 32
|
|
|
|
# SIZE: 12288
|