blob: 1f293030c7dde7e50add40c5d33ee18717d3efc6 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
|
# RUN: llvm-mc --filetype=obj --gsframe -triple x86_64 %s -o %t.o
# RUN: llvm-readelf --sframe %t.o | FileCheck %s
# Tests selection for the proper FDE AddrX encoding at the boundaries
# between uint8_t, uint16_t, and uint32_t. The first FRE always fits
# anywhere, because its address-offset is zero. The last FRE
# determines the smallest AddrX it is possible to use. Align
# functions to 1024 to make it easier to interpet offsets.
.cfi_sections .sframe
.align 1024
fde0_uses_addr1:
# CHECK: FuncDescEntry [0] {
# CHECK: Start FRE Offset: 0x0
# CHECK-NEXT: Num FREs: 2
# CHECK: FRE Type: Addr1 (0x0)
.cfi_startproc
# CHECK: Frame Row Entry {
# CHECK-NEXT: Start Address: 0x0
# CHECK-NEXT: Return Address Signed: No
# CHECK-NEXT: Offset Size: B1 (0x0)
# CHECK-NEXT: Base Register: SP (0x1)
# CHECK-NEXT: CFA Offset: 8
# CHECK-NEXT: RA Offset: -8
# CHECK-NEXT: }
.fill 0xFF
.cfi_def_cfa_offset 16
# CHECK-NEXT: Frame Row Entry {
# CHECK-NEXT: Start Address: 0xFF
# CHECK-NEXT: Return Address Signed: No
# CHECK-NEXT: Offset Size: B1 (0x0)
# CHECK-NEXT: Base Register: SP (0x1)
# CHECK-NEXT: CFA Offset: 16
# CHECK-NEXT: RA Offset: -8
nop
.cfi_endproc
.align 1024
fde1_uses_addr2:
# CHECK: FuncDescEntry [1] {
# CHECK: Start FRE Offset: 0x6
# CHECK-NEXT: Num FREs: 2
# CHECK: FRE Type: Addr2 (0x1)
.cfi_startproc
# CHECK: Frame Row Entry {
# CHECK-NEXT: Start Address: 0x400
.fill 0xFF + 1
.cfi_def_cfa_offset 16
# CHECK: Frame Row Entry {
# CHECK-NEXT: Start Address: 0x500
.cfi_endproc
.align 1024
fde2_uses_addr2:
# CHECK: FuncDescEntry [2] {
# CHECK: Start FRE Offset: 0xE
# CHECK-NEXT: Num FREs: 2
# CHECK: FRE Type: Addr2 (0x1)
.cfi_startproc
# CHECK: Frame Row Entry {
# CHECK-NEXT: Start Address: 0x800
.fill 0xFFFF
.cfi_def_cfa_offset 16
# CHECK: Frame Row Entry {
# CHECK-NEXT: Start Address: 0x107FF
nop
.cfi_endproc
.align 1024
fde3_uses_addr4:
# CHECK: FuncDescEntry [3] {
# CHECK: Start FRE Offset: 0x16
# CHECK-NEXT: Num FREs: 2
# CHECK: FRE Type: Addr4 (0x2)
.cfi_startproc
# CHECK: Frame Row Entry {
# CHECK-NEXT: Start Address: 0x10800
.fill 0xFFFF + 1
# CHECK: Frame Row Entry {
# CHECK-NEXT: Start Address: 0x20800
.cfi_def_cfa_offset 16
nop
.cfi_endproc
|