summaryrefslogtreecommitdiffstats
path: root/llvm/test/tools/llvm-objcopy/adjacent-segments.test
diff options
context:
space:
mode:
authorJake Ehrlich <jakehehrlich@google.com>2017-09-19 21:37:35 +0000
committerJake Ehrlich <jakehehrlich@google.com>2017-09-19 21:37:35 +0000
commitd246b0a2843d68768d5695ca40e298ddcb7adf9b (patch)
tree9a93581e4879ad5ce7fae509bfc141af5741d23d /llvm/test/tools/llvm-objcopy/adjacent-segments.test
parent74ea1f0938b9c7eb85ed3a75586f81d945ca2208 (diff)
downloadbcm5719-llvm-d246b0a2843d68768d5695ca40e298ddcb7adf9b.tar.gz
bcm5719-llvm-d246b0a2843d68768d5695ca40e298ddcb7adf9b.zip
Reland "[llvm-objcopy] Add support for nested and overlapping segments"
I didn't initialize a pointer to be nullptr that I needed to. This change adds support for nested and even overlapping segments. This means that PT_PHDR, PT_GNU_RELRO, PT_TLS, and PT_DYNAMIC can be supported properly. Differential Revision: https://reviews.llvm.org/D36558 llvm-svn: 313682
Diffstat (limited to 'llvm/test/tools/llvm-objcopy/adjacent-segments.test')
-rw-r--r--llvm/test/tools/llvm-objcopy/adjacent-segments.test62
1 files changed, 62 insertions, 0 deletions
diff --git a/llvm/test/tools/llvm-objcopy/adjacent-segments.test b/llvm/test/tools/llvm-objcopy/adjacent-segments.test
new file mode 100644
index 00000000000..45f4224f7e8
--- /dev/null
+++ b/llvm/test/tools/llvm-objcopy/adjacent-segments.test
@@ -0,0 +1,62 @@
+# This test tests that if two non-overlapping segments are right next to each
+# other no problems arise.
+
+# RUN: yaml2obj %s -o %t
+# RUN: llvm-objcopy %t %t2
+# RUN: llvm-readobj --program-headers %t2 | FileCheck %s
+
+!ELF
+FileHeader:
+ Class: ELFCLASS64
+ Data: ELFDATA2LSB
+ Type: ET_EXEC
+ Machine: EM_X86_64
+Sections:
+ - Name: .text
+ Type: SHT_PROGBITS
+ Flags: [ SHF_ALLOC, SHF_EXECINSTR ]
+ AddressAlign: 0x1000
+ Size: 24
+ - Name: .text2
+ Type: SHT_PROGBITS
+ Flags: [ SHF_ALLOC, SHF_EXECINSTR ]
+ AddressAlign: 0x10
+ Size: 16
+ProgramHeaders:
+ - Type: PT_LOAD
+ Flags: [ PF_X, PF_R ]
+ Sections:
+ - Section: .text
+ - Type: PT_LOAD
+ Flags: [ PF_X, PF_R ]
+ Sections:
+ - Section: .text2
+
+#CHECK: ProgramHeaders [
+#CHECK-NEXT: ProgramHeader {
+#CHECK-NEXT: Type: PT_LOAD (0x1)
+#CHECK-NEXT: Offset: 0x1000
+#CHECK-NEXT: VirtualAddress: 0x0
+#CHECK-NEXT: PhysicalAddress: 0x0
+#CHECK-NEXT: FileSize: 24
+#CHECK-NEXT: MemSize: 24
+#CHECK-NEXT: Flags [ (0x5)
+#CHECK-NEXT: PF_R (0x4)
+#CHECK-NEXT: PF_X (0x1)
+#CHECK-NEXT: ]
+#CHECK-NEXT: Alignment: 4096
+#CHECK-NEXT: }
+#CHECK-NEXT: ProgramHeader {
+#CHECK-NEXT: Type: PT_LOAD (0x1)
+#CHECK-NEXT: Offset: 0x1020
+#CHECK-NEXT: VirtualAddress: 0x0
+#CHECK-NEXT: PhysicalAddress: 0x0
+#CHECK-NEXT: FileSize: 16
+#CHECK-NEXT: MemSize: 16
+#CHECK-NEXT: Flags [ (0x5)
+#CHECK-NEXT: PF_R (0x4)
+#CHECK-NEXT: PF_X (0x1)
+#CHECK-NEXT: ]
+#CHECK-NEXT: Alignment: 16
+#CHECK-NEXT: }
+#CHECK-NEXT:]
OpenPOWER on IntegriCloud