2 // RUN
: llvm-mc
-filetype
=obj
-triple
=armv7a-none-linux-gnueabi
%s
-o
%t
3 // RUN
: llvm-mc
-filetype
=obj
-triple
=armv7a-none-linux-gnueabi
%S
/Inputs
/arm-exidx-cantunwind.s
-o
%tcantunwind
4 // Check that relocatable link maintains SHF_LINK_ORDER
5 // RUN
: ld.lld
-r
%t %tcantunwind
-o
%t4
6 // RUN
: llvm-readobj
-S
%t4 | FileCheck
%s
8 // RUN
: llvm-mc
-filetype
=obj
-triple
=armv7aeb-none-linux-gnueabi
-mcpu
=cortex-a8
%s
-o
%t
9 // RUN
: llvm-mc
-filetype
=obj
-triple
=armv7aeb-none-linux-gnueabi
-mcpu
=cortex-a8
%S
/Inputs
/arm-exidx-cantunwind.s
-o
%tcantunwind
10 // Check that relocatable link maintains SHF_LINK_ORDER for big endian
11 // RUN
: ld.lld
-r
%t %tcantunwind
-o
%t4
12 // RUN
: llvm-readobj
-S
%t4 | FileCheck
%s
13 // RUN
: ld.lld
--be8
-r
%t %tcantunwind
-o
%t4
14 // RUN
: llvm-readobj
-S
%t4 | FileCheck
%s
16 // Each assembler created
.ARM.exidx section has the SHF_LINK_ORDER flag set
17 // with the sh_link containing the section index of the executable section
18 // containing the function it describes. To maintain this property in
19 // relocatable links we pass through the
.ARM.exidx section, the section it
20 // it has
a sh_link to
, and the associated relocation sections uncombined.
23 .section .text, "ax",%progbits
31 .section .text.f1, "ax", %progbits
39 .section .text.f2, "ax", %progbits
54 // CHECK-NEXT
: Name
: .text
56 // CHECK
: Name
: .ARM.exidx
57 // CHECK-NEXT
: Type
: SHT_ARM_EXIDX
(0x70000001)
58 // CHECK-NEXT
: Flags
[ (0x82)
59 // CHECK-NEXT
: SHF_ALLOC
(0x2)
60 // CHECK-NEXT
: SHF_LINK_ORDER
(0x80)
62 // CHECK-NEXT
: Address
63 // CHECK-NEXT
: Offset
:
64 // CHECK-NEXT
: Size
: 24
65 // CHECK-NEXT
: Link
: 1
69 // CHECK-NEXT
: Name
: .text.f1
71 // CHECK
: Name
: .ARM.exidx.text.f1
72 // CHECK-NEXT
: Type
: SHT_ARM_EXIDX
(0x70000001)
73 // CHECK-NEXT
: Flags
[ (0x82)
74 // CHECK-NEXT
: SHF_ALLOC
(0x2)
75 // CHECK-NEXT
: SHF_LINK_ORDER
(0x80)
77 // CHECK-NEXT
: Address
78 // CHECK-NEXT
: Offset
:
79 // CHECK-NEXT
: Size
: 8
80 // CHECK-NEXT
: Link
: 4
84 // CHECK-NEXT
: Name
: .text.f2
86 // CHECK
: Name
: .ARM.exidx.text.f2
87 // CHECK-NEXT
: Type
: SHT_ARM_EXIDX
(0x70000001)
88 // CHECK-NEXT
: Flags
[ (0x82)
89 // CHECK-NEXT
: SHF_ALLOC
(0x2)
90 // CHECK-NEXT
: SHF_LINK_ORDER
(0x80)
92 // CHECK-NEXT
: Address
93 // CHECK-NEXT
: Offset
:
94 // CHECK-NEXT
: Size
: 16
95 // CHECK-NEXT
: Link
: 7
99 // CHECK-NEXT
: Name
: .func1
101 // CHECK
: Name
: .ARM.exidx.func1
102 // CHECK-NEXT
: Type
: SHT_ARM_EXIDX
(0x70000001)
103 // CHECK-NEXT
: Flags
[ (0x82)
104 // CHECK-NEXT
: SHF_ALLOC
(0x2)
105 // CHECK-NEXT
: SHF_LINK_ORDER
(0x80)
107 // CHECK-NEXT
: Address
108 // CHECK-NEXT
: Offset
:
109 // CHECK-NEXT
: Size
: 8
110 // CHECK-NEXT
: Link
: 10
114 // CHECK-NEXT
: Name
: .func2
116 // CHECK
: Name
: .ARM.exidx.func2
117 // CHECK-NEXT
: Type
: SHT_ARM_EXIDX
(0x70000001)
118 // CHECK-NEXT
: Flags
[ (0x82)
119 // CHECK-NEXT
: SHF_ALLOC
(0x2)
120 // CHECK-NEXT
: SHF_LINK_ORDER
(0x80)
122 // CHECK-NEXT
: Address
123 // CHECK-NEXT
: Offset
:
124 // CHECK-NEXT
: Size
: 8
125 // CHECK-NEXT
: Link
: 13
129 // CHECK-NEXT
: Name
: .func3
131 // CHECK
: Name
: .ARM.exidx.func3
132 // CHECK-NEXT
: Type
: SHT_ARM_EXIDX
(0x70000001)
133 // CHECK-NEXT
: Flags
[ (0x82)
134 // CHECK-NEXT
: SHF_ALLOC
(0x2)
135 // CHECK-NEXT
: SHF_LINK_ORDER
(0x80)
137 // CHECK-NEXT
: Address
138 // CHECK-NEXT
: Offset
:
139 // CHECK-NEXT
: Size
: 8
140 // CHECK-NEXT
: Link
: 16