annotate lld/test/ELF/eh-frame-negative-pcrel-sdata8.s @ 236:c4bab56944e8 llvm-original

LLVM 16
author kono
date Wed, 09 Nov 2022 17:45:10 +0900
parents 0572611fdcc8
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
150
anatofuz
parents:
diff changeset
1 # REQUIRES: x86
anatofuz
parents:
diff changeset
2
anatofuz
parents:
diff changeset
3 # Test handling of FDE pc negative relative addressing with DW_EH_PE_sdata8.
anatofuz
parents:
diff changeset
4 # This situation can arise when .eh_frame is placed after .text.
anatofuz
parents:
diff changeset
5
anatofuz
parents:
diff changeset
6 # RUN: llvm-mc -filetype=obj -triple=x86_64-pc-linux %s -o %t.o
anatofuz
parents:
diff changeset
7 # RUN: echo "SECTIONS { .text : { *(.text) } .eh_frame : { *(.eh_frame) } }" > %t.script
anatofuz
parents:
diff changeset
8 # RUN: ld.lld --eh-frame-hdr --script %t.script --section-start .text=0x1000 %t.o -o %t
anatofuz
parents:
diff changeset
9 # RUN: llvm-readobj -S --section-data %t | FileCheck %s
anatofuz
parents:
diff changeset
10
anatofuz
parents:
diff changeset
11 # CHECK: Section {
anatofuz
parents:
diff changeset
12 # CHECK: Index:
anatofuz
parents:
diff changeset
13 # CHECK: Name: .eh_frame
anatofuz
parents:
diff changeset
14 # CHECK-NEXT: Type: SHT_PROGBITS
anatofuz
parents:
diff changeset
15 # CHECK-NEXT: Flags [
anatofuz
parents:
diff changeset
16 # CHECK-NEXT: SHF_ALLOC
anatofuz
parents:
diff changeset
17 # CHECK-NEXT: ]
anatofuz
parents:
diff changeset
18 # CHECK-NEXT: Address: 0x1001
anatofuz
parents:
diff changeset
19 # CHECK-NEXT: Offset: 0x1001
anatofuz
parents:
diff changeset
20 # CHECK-NEXT: Size:
anatofuz
parents:
diff changeset
21 # CHECK-NEXT: Link:
anatofuz
parents:
diff changeset
22 # CHECK-NEXT: Info:
anatofuz
parents:
diff changeset
23 # CHECK-NEXT: AddressAlignment:
anatofuz
parents:
diff changeset
24 # CHECK-NEXT: EntrySize:
anatofuz
parents:
diff changeset
25 # CHECK-NEXT: SectionData (
236
c4bab56944e8 LLVM 16
kono
parents: 173
diff changeset
26 # CHECK-NEXT: 0000: 10000000 00000000 017A5200 01010101
c4bab56944e8 LLVM 16
kono
parents: 173
diff changeset
27 # CHECK-NEXT: 0010: 1C000000 10000000 18000000 E3FFFFFF
c4bab56944e8 LLVM 16
kono
parents: 173
diff changeset
28 # CHECK-NEXT: 0020: FFFFFFFF 00000000 00000000
c4bab56944e8 LLVM 16
kono
parents: 173
diff changeset
29 # ^
c4bab56944e8 LLVM 16
kono
parents: 173
diff changeset
30 # E3FFFFFF FFFFFFFF = _start(0x1000) - PC(.eh_frame(0x1001) + 0x1C)
150
anatofuz
parents:
diff changeset
31
anatofuz
parents:
diff changeset
32 # CHECK: Section {
anatofuz
parents:
diff changeset
33 # CHECK: Index:
anatofuz
parents:
diff changeset
34 # CHECK: Name: .eh_frame_hdr
anatofuz
parents:
diff changeset
35 # CHECK-NEXT: Type: SHT_PROGBITS
anatofuz
parents:
diff changeset
36 # CHECK-NEXT: Flags [
anatofuz
parents:
diff changeset
37 # CHECK-NEXT: SHF_ALLOC
anatofuz
parents:
diff changeset
38 # CHECK-NEXT: ]
236
c4bab56944e8 LLVM 16
kono
parents: 173
diff changeset
39 # CHECK-NEXT: Address: 0x1030
c4bab56944e8 LLVM 16
kono
parents: 173
diff changeset
40 # CHECK-NEXT: Offset: 0x1030
150
anatofuz
parents:
diff changeset
41 # CHECK-NEXT: Size: 20
anatofuz
parents:
diff changeset
42 # CHECK-NEXT: Link: 0
anatofuz
parents:
diff changeset
43 # CHECK-NEXT: Info: 0
anatofuz
parents:
diff changeset
44 # CHECK-NEXT: AddressAlignment: 4
anatofuz
parents:
diff changeset
45 # CHECK-NEXT: EntrySize: 0
anatofuz
parents:
diff changeset
46 # CHECK-NEXT: SectionData (
236
c4bab56944e8 LLVM 16
kono
parents: 173
diff changeset
47 # CHECK-NEXT: 0000: 011B033B CDFFFFFF 01000000 D0FFFFFF
c4bab56944e8 LLVM 16
kono
parents: 173
diff changeset
48 # CHECK-NEXT: 0010: E5FFFFFF
150
anatofuz
parents:
diff changeset
49 # Header (always 4 bytes): 011B033B
236
c4bab56944e8 LLVM 16
kono
parents: 173
diff changeset
50 # CDFFFFFF = .eh_frame(0x1001) - .eh_frame_hdr(0x1030) - 4
150
anatofuz
parents:
diff changeset
51 # 01000000 = 1 = the number of FDE pointers in the table.
236
c4bab56944e8 LLVM 16
kono
parents: 173
diff changeset
52 # D0FFFFFF = _start(0x1000) - .eh_frame_hdr(0x1030)
c4bab56944e8 LLVM 16
kono
parents: 173
diff changeset
53 # E5FFFFFF = FDE(.eh_frame(0x1001) + 0x18) - .eh_frame_hdr(0x1030)
150
anatofuz
parents:
diff changeset
54
anatofuz
parents:
diff changeset
55 .text
anatofuz
parents:
diff changeset
56 .global _start
anatofuz
parents:
diff changeset
57 _start:
anatofuz
parents:
diff changeset
58 nop
anatofuz
parents:
diff changeset
59
173
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
60 .section .eh_frame,"a",@unwind
150
anatofuz
parents:
diff changeset
61 .long 16 # Size
anatofuz
parents:
diff changeset
62 .long 0x00 # ID
anatofuz
parents:
diff changeset
63 .byte 0x01 # Version.
anatofuz
parents:
diff changeset
64
anatofuz
parents:
diff changeset
65 .byte 0x7A # Augmentation string: "zR"
anatofuz
parents:
diff changeset
66 .byte 0x52
anatofuz
parents:
diff changeset
67 .byte 0x00
anatofuz
parents:
diff changeset
68
anatofuz
parents:
diff changeset
69 .byte 0x01
anatofuz
parents:
diff changeset
70
anatofuz
parents:
diff changeset
71 .byte 0x01 # LEB128
anatofuz
parents:
diff changeset
72 .byte 0x01 # LEB128
anatofuz
parents:
diff changeset
73
anatofuz
parents:
diff changeset
74 .byte 0x01 # LEB128
anatofuz
parents:
diff changeset
75 .byte 0x1C # DW_EH_PE_pcrel | DW_EH_PE_sdata8
anatofuz
parents:
diff changeset
76
anatofuz
parents:
diff changeset
77 .byte 0x00
anatofuz
parents:
diff changeset
78 .byte 0x00
anatofuz
parents:
diff changeset
79 .byte 0x00
anatofuz
parents:
diff changeset
80
anatofuz
parents:
diff changeset
81 .long 16 # Size
anatofuz
parents:
diff changeset
82 .long 24 # ID
anatofuz
parents:
diff changeset
83 fde:
anatofuz
parents:
diff changeset
84 .quad _start - fde
anatofuz
parents:
diff changeset
85 .long 0