Skip to content

Commit 27ef749

Browse files
committed
[ELF][test] Refactor some .eh_frame tests
* Improve eh-frame-merge.s * Delete invalid .eh_frame+5 test in ehframe-relocation.s
1 parent 3e9805e commit 27ef749

File tree

3 files changed

+36
-56
lines changed

3 files changed

+36
-56
lines changed

lld/test/ELF/eh-frame-begin-end.s

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -10,7 +10,7 @@
1010
// CHECK-NEXT: Flags [
1111
// CHECK-NEXT: SHF_ALLOC
1212
// CHECK-NEXT: ]
13-
// CHECK-NEXT: Address: 0x200120
13+
// CHECK-NEXT: Address:
1414
// CHECK-NEXT: Offset: 0x120
1515
// CHECK-NEXT: Size: 4
1616

lld/test/ELF/eh-frame-merge.s

Lines changed: 35 additions & 52 deletions
Original file line numberDiff line numberDiff line change
@@ -1,12 +1,39 @@
1-
// REQUIRES: x86
2-
// RUN: llvm-mc -filetype=obj -triple=x86_64-pc-linux %s -o %t.o
3-
// RUN: ld.lld --hash-style=sysv %t.o %t.o -o %t -shared
4-
// RUN: llvm-readobj -S --section-data %t | FileCheck %s
1+
# REQUIRES: x86
2+
# RUN: llvm-mc -filetype=obj -triple=x86_64 %s -o %t.o
3+
# RUN: ld.lld %t.o %t.o -shared --emit-relocs -o %t.so
4+
# RUN: llvm-readelf -S -r %t.so | FileCheck %s --check-prefixes=CHECK,RELOC
5+
# RUN: llvm-dwarfdump --eh-frame %t.so | FileCheck %s --check-prefix=EH
56

6-
/// Also show that the merging happens when going via a -r link.
7-
// RUN: ld.lld -r %t.o %t.o -o %t.r.o
8-
// RUN: ld.lld --hash-style=sysv %t.r.o -o %t2 -shared
9-
// RUN: llvm-readobj -S --section-data %t2 | FileCheck %s
7+
## Also show that the merging happens when going via a -r link.
8+
# RUN: ld.lld -r %t.o %t.o -o %t.ro
9+
# RUN: ld.lld %t.ro -o %t2.so -shared
10+
# RUN: llvm-readelf -S -r %t2.so | FileCheck %s
11+
12+
# CHECK: Name Type Address Off Size ES Flg Lk Inf Al
13+
# CHECK: .eh_frame PROGBITS [[#%x,]] [[#%x,]] 000064 00 A 0 0 8
14+
# CHECK: foo PROGBITS {{0*}}[[#%x,FOO:]] [[#%x,]] 000002 00 AX 0 0 1
15+
# CHECK-NEXT: bar PROGBITS {{0*}}[[#%x,FOO+2]] [[#%x,]] 000002 00 AX 0 0 1
16+
17+
# RELOC: Offset Info Type Symbol's Value Symbol's Name + Addend
18+
# RELOC-NEXT: {{0*}}[[#%x,OFF:]] [[#%x,]] R_X86_64_PC32 [[#%x,]] foo + 0
19+
# RELOC-NEXT: {{0*}}[[#%x,OFF+20]] [[#%x,]] R_X86_64_PC32 [[#%x,]] bar + 0
20+
# RELOC-NEXT: {{0*}}[[#OFF]] [[#%x,]] R_X86_64_PC32 [[#%x,]] foo + 1
21+
# RELOC-NEXT: {{0*}}[[#OFF+20]] [[#%x,]] R_X86_64_NONE 0{{$}}
22+
23+
# EH: Format: DWARF32
24+
# EH: 00000018 00000014 0000001c FDE cie=00000000 pc={{0*}}[[#%x,FOO:]]...
25+
# EH-SAME: {{0*}}[[#%x,FOO+1]]
26+
# EH-COUNT-7: DW_CFA_nop:
27+
# EH-EMPTY:
28+
# EH: 00000030 00000014 00000034 FDE cie=00000000 pc={{0*}}[[#%x,FOO+2]]...{{0*}}[[#%x,FOO+4]]
29+
# EH-COUNT-7: DW_CFA_nop:
30+
# EH-EMPTY:
31+
# EH: 00000048 00000014 0000004c FDE cie=00000000 pc={{0*}}[[#%x,FOO+1]]...{{0*}}[[#%x,FOO+2]]
32+
# EH-COUNT-7: DW_CFA_nop:
33+
# EH-EMPTY:
34+
# EH-NEXT: 0x[[#%x,]]: CFA=RSP+8: RIP=[CFA-8]
35+
# EH-EMPTY:
36+
# EH-NEXT: 00000060 ZERO terminator
1037

1138
.section foo,"ax",@progbits
1239
.cfi_startproc
@@ -18,47 +45,3 @@
1845
nop
1946
nop
2047
.cfi_endproc
21-
22-
// FIXME: We could really use a .eh_frame parser.
23-
// The intention is to show that:
24-
// * There is only one copy of the CIE
25-
// * There are two copies of the first FDE
26-
// * There is only one copy of the second FDE
27-
28-
// CHECK: Name: .eh_frame
29-
// CHECK-NEXT: Type: SHT_PROGBITS
30-
// CHECK-NEXT: Flags [
31-
// CHECK-NEXT: SHF_ALLOC
32-
// CHECK-NEXT: ]
33-
// CHECK-NEXT: Address:
34-
// CHECK-NEXT: Offset:
35-
// CHECK-NEXT: Size: 100
36-
// CHECK-NEXT: Link: 0
37-
// CHECK-NEXT: Info: 0
38-
// CHECK-NEXT: AddressAlignment: 8
39-
// CHECK-NEXT: EntrySize: 0
40-
// CHECK-NEXT: SectionData (
41-
// CHECK-NEXT: 0000: 14000000 00000000 017A5200 01781001 |
42-
// CHECK-NEXT: 0010: 1B0C0708 90010000 14000000 1C000000 |
43-
// CHECK-NEXT: 0020: 44100000 01000000 00000000 00000000 |
44-
// CHECK-NEXT: 0030: 14000000 34000000 2E100000 02000000 |
45-
// CHECK-NEXT: 0040: 00000000 00000000 14000000 4C000000 |
46-
// CHECK-NEXT: 0050: 15100000 01000000 00000000 00000000 |
47-
// CHECK-NEXT: 0060: 00000000
48-
// CHECK-NEXT: )
49-
50-
// CHECK: Name: foo
51-
// CHECK-NEXT: Type: SHT_PROGBITS
52-
// CHECK-NEXT: Flags [
53-
// CHECK-NEXT: SHF_ALLOC
54-
// CHECK-NEXT: SHF_EXECINSTR
55-
// CHECK-NEXT: ]
56-
// CHECK-NEXT: Address: 0x125C
57-
58-
// CHECK: Name: bar
59-
// CHECK-NEXT: Type: SHT_PROGBITS
60-
// CHECK-NEXT: Flags [
61-
// CHECK-NEXT: SHF_ALLOC
62-
// CHECK-NEXT: SHF_EXECINSTR
63-
// CHECK-NEXT: ]
64-
// CHECK-NEXT: Address: 0x125E

lld/test/ELF/ehframe-relocation.s

Lines changed: 0 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -16,17 +16,14 @@
1616
// CHECK-NOT: .eh_frame
1717

1818
// 0x200120 = 2097440
19-
// 0x200120 + 5 = 2097445
2019
// DISASM: Disassembly of section .text:
2120
// DISASM-EMPTY:
2221
// DISASM-NEXT: <_start>:
2322
// DISASM-NEXT: 201154: {{.*}} movq 2097440, %rax
24-
// DISASM-NEXT: 20115c: {{.*}} movq 2097445, %rax
2523

2624
.section .eh_frame,"a",@unwind
2725

2826
.section .text
2927
.globl _start
3028
_start:
3129
movq .eh_frame, %rax
32-
movq .eh_frame + 5, %rax

0 commit comments

Comments
 (0)