| # RUN: yaml2obj %s -o - | \ |
| # RUN: llvm-dwarfdump -debug-frame - | \ |
| # RUN: FileCheck %s |
| |
| ## This checks that we resolve relocations when reading CIE pointers. |
| ## The second FDE references the second CIE. The value for the CIE pointer |
| ## field in the raw section data is 0, thus, to recover the real reference, |
| ## it is required to read the addend from the corresponding RELA relocation. |
| |
| # CHECK: .debug_frame contents: |
| # CHECK: 00000000 0000000c ffffffff CIE |
| # CHECK: 00000010 00000014 00000000 FDE cie=00000000 pc=00000000...00000001 |
| # CHECK: 00000028 0000000c ffffffff CIE |
| # CHECK: 00000038 00000014 00000028 FDE cie=00000028 pc=00000010...00000011 |
| |
| --- !ELF |
| FileHeader: |
| Class: ELFCLASS64 |
| Data: ELFDATA2LSB |
| Type: ET_REL |
| Machine: EM_X86_64 |
| Sections: |
| - Name: .debug_frame |
| Type: SHT_PROGBITS |
| Content: 0C000000FFFFFFFF02000178100000001400000000000000000000000000000001000000000000000C000000FFFFFFFF0200017810000000140000000000000010000000000000000100000000000000 |
| - Name: .rela.debug_frame |
| Type: SHT_RELA |
| Info: .debug_frame |
| Relocations: |
| - Offset: 0x0000000000000014 |
| Symbol: .debug_frame |
| Type: R_X86_64_32 |
| - Offset: 0x000000000000003C |
| Symbol: .debug_frame |
| Type: R_X86_64_32 |
| Addend: 0x28 |
| Symbols: |
| - Name: .debug_frame |
| Type: STT_SECTION |
| Section: .debug_frame |
| ... |