1#Source : 2#__thread int a = 1; 3#__thread int b; 4# 5#int main () { 6# b = 2; 7# throw (a + b) ; 8# return 0; 9#} 10# compiled as clang++ source.cpp 11# and clang++ -m32 source.cpp 12 13RUN: llvm-readobj -program-headers %p/Inputs/phdrs-elf.exe-i386 --elf-output-style=GNU \ 14RUN: | FileCheck %s -check-prefix ELF32 15RUN: llvm-readobj -program-headers %p/Inputs/phdrs-elf.exe-x86_64 \ 16RUN: --elf-output-style=GNU | FileCheck %s -check-prefix ELF64 17 18ELF32: Elf file type is EXEC (Executable file) 19ELF32-NEXT: Entry point 0x8048460 20ELF32-NEXT: There are 10 program headers, starting at offset 52 21 22ELF32: Program Headers: 23ELF32-NEXT: Type Offset VirtAddr PhysAddr FileSiz MemSiz Flg Align 24ELF32-NEXT: PHDR 0x000034 0x08048034 0x08048034 0x00140 0x00140 R E 0x4 25ELF32-NEXT: INTERP 0x000174 0x08048174 0x08048174 0x00013 0x00013 R 0x1 26ELF32-NEXT: [Requesting program interpreter: /lib/ld-linux.so.2] 27ELF32-NEXT: LOAD 0x000000 0x08048000 0x08048000 0x006d0 0x006d0 R E 0x1000 28ELF32-NEXT: LOAD 0x000ef0 0x08049ef0 0x08049ef0 0x00128 0x00140 RW 0x1000 29ELF32-NEXT: DYNAMIC 0x000f08 0x08049f08 0x08049f08 0x000e8 0x000e8 RW 0x4 30ELF32-NEXT: NOTE 0x000188 0x08048188 0x08048188 0x00044 0x00044 R 0x4 31ELF32-NEXT: TLS 0x000ef0 0x08049ef0 0x08049ef0 0x00004 0x00008 R 0x4 32ELF32-NEXT: GNU_EH_FRAME 0x000640 0x08048640 0x08048640 0x0001c 0x0001c R 0x4 33ELF32-NEXT: GNU_STACK 0x000000 0x00000000 0x00000000 0x00000 0x00000 RW 0x4 34ELF32-NEXT: GNU_RELRO 0x000ef0 0x08049ef0 0x08049ef0 0x00110 0x00110 R 0x1 35 36ELF32: Section to Segment mapping: 37ELF32-NEXT: Segment Sections... 38ELF32-NEXT: 00 39ELF32-NEXT: 01 .interp 40ELF32-NEXT: 02 .interp .note.ABI-tag .note.gnu.build-id .hash .gnu.hash .dynsym .dynstr .gnu.version .gnu.version_r .rel.dyn .rel.plt .init .plt .text .fini .rodata .eh_frame_hdr .eh_frame 41ELF32-NEXT: 03 .tdata .ctors .dtors .jcr .dynamic .got .got.plt .data .bss 42ELF32-NEXT: 04 .dynamic 43ELF32-NEXT: 05 .note.ABI-tag .note.gnu.build-id 44ELF32-NEXT: 06 .tdata .tbss 45ELF32-NEXT: 07 .eh_frame_hdr 46ELF32-NEXT: 08 47ELF32-NEXT: 09 .tdata .ctors .dtors .jcr .dynamic .got 48 49ELF64: Elf file type is EXEC (Executable file) 50ELF64-NEXT: Entry point 0x400610 51ELF64-NEXT: There are 10 program headers, starting at offset 64 52 53ELF64: Program Headers: 54ELF64-NEXT: Type Offset VirtAddr PhysAddr FileSiz MemSiz Flg Align 55ELF64-NEXT: PHDR 0x000040 0x0000000000400040 0x0000000000400040 0x000230 0x000230 R E 0x8 56ELF64-NEXT: INTERP 0x000270 0x0000000000400270 0x0000000000400270 0x00001c 0x00001c R 0x1 57ELF64-NEXT: [Requesting program interpreter: /lib64/ld-linux-x86-64.so.2] 58ELF64-NEXT: LOAD 0x000000 0x0000000000400000 0x0000000000400000 0x000924 0x000924 R E 0x200000 59ELF64-NEXT: LOAD 0x000db4 0x0000000000600db4 0x0000000000600db4 0x000274 0x0002a4 RW 0x200000 60ELF64-NEXT: DYNAMIC 0x000dd0 0x0000000000600dd0 0x0000000000600dd0 0x000210 0x000210 RW 0x8 61ELF64-NEXT: NOTE 0x00028c 0x000000000040028c 0x000000000040028c 0x000044 0x000044 R 0x4 62ELF64-NEXT: TLS 0x000db4 0x0000000000600db4 0x0000000000600db4 0x000004 0x000008 R 0x4 63ELF64-NEXT: GNU_EH_FRAME 0x00083c 0x000000000040083c 0x000000000040083c 0x00002c 0x00002c R 0x4 64ELF64-NEXT: GNU_STACK 0x000000 0x0000000000000000 0x0000000000000000 0x000000 0x000000 RW 0x8 65ELF64-NEXT: GNU_RELRO 0x000db4 0x0000000000600db4 0x0000000000600db4 0x00024c 0x00024c R 0x1 66 67ELF64: Section to Segment mapping: 68ELF64-NEXT: Segment Sections... 69ELF64-NEXT: 00 70ELF64-NEXT: 01 .interp 71ELF64-NEXT: 02 .interp .note.ABI-tag .note.gnu.build-id .hash .gnu.hash .dynsym .dynstr .gnu.version .gnu.version_r .rela.dyn .rela.plt .init .plt .text .fini .rodata .eh_frame_hdr .eh_frame 72ELF64-NEXT: 03 .tdata .init_array .fini_array .jcr .dynamic .got .got.plt .data .bss 73ELF64-NEXT: 04 .dynamic 74ELF64-NEXT: 05 .note.ABI-tag .note.gnu.build-id 75ELF64-NEXT: 06 .tdata .tbss 76ELF64-NEXT: 07 .eh_frame_hdr 77ELF64-NEXT: 08 78ELF64-NEXT: 09 .tdata .init_array .fini_array .jcr .dynamic .got 79