annotate lld/test/ELF/icf-safe.s @ 192:d7606dcf6fce

Added tag llvm10 for changeset 0572611fdcc8
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Mon, 14 Dec 2020 18:01:34 +0900
parents 1d019706d866
children 2e18cbf3894f
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 # RUN: llvm-mc -filetype=obj -triple=x86_64-unknown-linux %s -o %t1.o
anatofuz
parents:
diff changeset
4 # RUN: llvm-objcopy %t1.o %t1copy.o
anatofuz
parents:
diff changeset
5 # RUN: llvm-mc -filetype=obj -triple=x86_64-unknown-linux %S/Inputs/icf-safe.s -o %t2.o
anatofuz
parents:
diff changeset
6 # RUN: ld.lld %t1.o %t2.o -o %t2 --icf=safe --print-icf-sections | FileCheck %s
anatofuz
parents:
diff changeset
7 # RUN: ld.lld %t1.o %t2.o -o %t3 --icf=safe --print-icf-sections -shared | FileCheck --check-prefix=EXPORT %s
anatofuz
parents:
diff changeset
8 # RUN: ld.lld %t1.o %t2.o -o %t3 --icf=safe --print-icf-sections --export-dynamic | FileCheck --check-prefix=EXPORT %s
anatofuz
parents:
diff changeset
9 # RUN: ld.lld %t1.o %t2.o -o %t2 --icf=all --print-icf-sections | FileCheck --check-prefix=ALL %s
anatofuz
parents:
diff changeset
10 # RUN: ld.lld %t1.o %t2.o -o %t2 --icf=all --print-icf-sections --export-dynamic | FileCheck --check-prefix=ALL-EXPORT %s
anatofuz
parents:
diff changeset
11 # RUN: ld.lld %t1copy.o -o %t4 --icf=safe 2>&1 | FileCheck --check-prefix=OBJCOPY %s
anatofuz
parents:
diff changeset
12
anatofuz
parents:
diff changeset
13 # CHECK-NOT: selected section {{.*}}:(.text.f1)
anatofuz
parents:
diff changeset
14 # CHECK: selected section {{.*}}:(.text.f3)
anatofuz
parents:
diff changeset
15 # CHECK: removing identical section {{.*}}:(.text.f4)
anatofuz
parents:
diff changeset
16
anatofuz
parents:
diff changeset
17 # CHECK-NOT: selected section {{.*}}:(.rodata.h1)
anatofuz
parents:
diff changeset
18 # CHECK: selected section {{.*}}:(.rodata.h3)
anatofuz
parents:
diff changeset
19 # CHECK: removing identical section {{.*}}:(.rodata.h4)
anatofuz
parents:
diff changeset
20
anatofuz
parents:
diff changeset
21 # CHECK-NOT: selected section {{.*}}:(.rodata.l1)
anatofuz
parents:
diff changeset
22 # CHECK: selected section {{.*}}:(.rodata.l3)
anatofuz
parents:
diff changeset
23 # CHECK: removing identical section {{.*}}:(.rodata.l4)
anatofuz
parents:
diff changeset
24
anatofuz
parents:
diff changeset
25 # CHECK-NOT: selected section {{.*}}:(.rodata.g1)
anatofuz
parents:
diff changeset
26 # CHECK: selected section {{.*}}:(.rodata.g3)
anatofuz
parents:
diff changeset
27 # CHECK: removing identical section {{.*}}:(.rodata.g4)
anatofuz
parents:
diff changeset
28
anatofuz
parents:
diff changeset
29 # CHECK-NOT: selected section {{.*}}:(.text.non_addrsig{{.}})
anatofuz
parents:
diff changeset
30
anatofuz
parents:
diff changeset
31 # With --icf=all address-significance implies keep-unique only for rodata, not
anatofuz
parents:
diff changeset
32 # text.
anatofuz
parents:
diff changeset
33 # ALL: selected section {{.*}}:(.text.f3)
anatofuz
parents:
diff changeset
34 # ALL: removing identical section {{.*}}:(.text.f4)
anatofuz
parents:
diff changeset
35
anatofuz
parents:
diff changeset
36 # ALL-NOT: selected section {{.*}}:(.rodata.h1)
anatofuz
parents:
diff changeset
37 # ALL: selected section {{.*}}:(.rodata.h3)
anatofuz
parents:
diff changeset
38 # ALL: removing identical section {{.*}}:(.rodata.h4)
anatofuz
parents:
diff changeset
39
anatofuz
parents:
diff changeset
40 # ALL-NOT: selected section {{.*}}:(.rodata.l1)
anatofuz
parents:
diff changeset
41 # ALL: selected section {{.*}}:(.rodata.l3)
anatofuz
parents:
diff changeset
42 # ALL: removing identical section {{.*}}:(.rodata.l4)
anatofuz
parents:
diff changeset
43
anatofuz
parents:
diff changeset
44 # ALL-NOT: selected section {{.*}}:(.rodata.g1)
anatofuz
parents:
diff changeset
45 # ALL: selected section {{.*}}:(.rodata.g3)
anatofuz
parents:
diff changeset
46 # ALL: removing identical section {{.*}}:(.rodata.g4)
anatofuz
parents:
diff changeset
47
anatofuz
parents:
diff changeset
48 # ALL: selected section {{.*}}:(.text.f1)
anatofuz
parents:
diff changeset
49 # ALL: removing identical section {{.*}}:(.text.f2)
anatofuz
parents:
diff changeset
50 # ALL: removing identical section {{.*}}:(.text.non_addrsig1)
anatofuz
parents:
diff changeset
51 # ALL: removing identical section {{.*}}:(.text.non_addrsig2)
anatofuz
parents:
diff changeset
52
anatofuz
parents:
diff changeset
53 # llvm-mc normally emits an empty .text section into every object file. Since
anatofuz
parents:
diff changeset
54 # nothing actually refers to it via a relocation, it doesn't have any associated
anatofuz
parents:
diff changeset
55 # symbols (thus nor can anything refer to it via a relocation, making it safe to
anatofuz
parents:
diff changeset
56 # merge with the empty section in the other input file). Here we check that the
anatofuz
parents:
diff changeset
57 # only two sections merged are the two empty sections and the sections with only
anatofuz
parents:
diff changeset
58 # STB_LOCAL or STV_HIDDEN symbols. The dynsym entries should have prevented
anatofuz
parents:
diff changeset
59 # anything else from being merged.
anatofuz
parents:
diff changeset
60 # EXPORT-NOT: selected section
anatofuz
parents:
diff changeset
61 # EXPORT: selected section {{.*}}:(.rodata.h3)
anatofuz
parents:
diff changeset
62 # EXPORT: removing identical section {{.*}}:(.rodata.h4)
anatofuz
parents:
diff changeset
63 # EXPORT-NOT: selected section
anatofuz
parents:
diff changeset
64 # EXPORT: selected section {{.*}}:(.text)
anatofuz
parents:
diff changeset
65 # EXPORT: removing identical section {{.*}}:(.text)
anatofuz
parents:
diff changeset
66 # EXPORT-NOT: selected section
anatofuz
parents:
diff changeset
67 # EXPORT: selected section {{.*}}:(.rodata.l3)
anatofuz
parents:
diff changeset
68 # EXPORT: removing identical section {{.*}}:(.rodata.l4)
anatofuz
parents:
diff changeset
69 # EXPORT-NOT: selected section
anatofuz
parents:
diff changeset
70
anatofuz
parents:
diff changeset
71 # If --icf=all is specified when exporting we can also merge the exported text
anatofuz
parents:
diff changeset
72 # sections, but not the exported rodata.
anatofuz
parents:
diff changeset
73 # ALL-EXPORT-NOT: selected section
anatofuz
parents:
diff changeset
74 # ALL-EXPORT: selected section {{.*}}:(.text.f3)
anatofuz
parents:
diff changeset
75 # ALL-EXPORT: removing identical section {{.*}}:(.text.f4)
anatofuz
parents:
diff changeset
76 # ALL-EXPORT-NOT: selected section
anatofuz
parents:
diff changeset
77 # ALL-EXPORT: selected section {{.*}}:(.rodata.h3)
anatofuz
parents:
diff changeset
78 # ALL-EXPORT: removing identical section {{.*}}:(.rodata.h4)
anatofuz
parents:
diff changeset
79 # ALL-EXPORT-NOT: selected section
anatofuz
parents:
diff changeset
80 # ALL-EXPORT: selected section {{.*}}:(.text)
anatofuz
parents:
diff changeset
81 # ALL-EXPORT: removing identical section {{.*}}:(.text)
anatofuz
parents:
diff changeset
82 # ALL-EXPORT-NOT: selected section
anatofuz
parents:
diff changeset
83 # ALL-EXPORT: selected section {{.*}}:(.rodata.l3)
anatofuz
parents:
diff changeset
84 # ALL-EXPORT: removing identical section {{.*}}:(.rodata.l4)
anatofuz
parents:
diff changeset
85 # ALL-EXPORT-NOT: selected section
anatofuz
parents:
diff changeset
86 # ALL-EXPORT: selected section {{.*}}:(.text.f1)
anatofuz
parents:
diff changeset
87 # ALL-EXPORT: removing identical section {{.*}}:(.text.f2)
anatofuz
parents:
diff changeset
88 # ALL-EXPORT: removing identical section {{.*}}:(.text.non_addrsig1)
anatofuz
parents:
diff changeset
89 # ALL-EXPORT: removing identical section {{.*}}:(.text.non_addrsig2)
anatofuz
parents:
diff changeset
90 # ALL-EXPORT-NOT: selected section
anatofuz
parents:
diff changeset
91
anatofuz
parents:
diff changeset
92 # OBJCOPY: --icf=safe is incompatible with object files created using objcopy or ld -r
anatofuz
parents:
diff changeset
93
anatofuz
parents:
diff changeset
94 .section .text.f1,"ax",@progbits
anatofuz
parents:
diff changeset
95 .globl f1
anatofuz
parents:
diff changeset
96 f1:
anatofuz
parents:
diff changeset
97 ret
anatofuz
parents:
diff changeset
98
anatofuz
parents:
diff changeset
99 .section .text.f2,"ax",@progbits
anatofuz
parents:
diff changeset
100 .globl f2
anatofuz
parents:
diff changeset
101 f2:
anatofuz
parents:
diff changeset
102 ret
anatofuz
parents:
diff changeset
103
anatofuz
parents:
diff changeset
104 .section .text.f3,"ax",@progbits
anatofuz
parents:
diff changeset
105 .globl f3
anatofuz
parents:
diff changeset
106 f3:
anatofuz
parents:
diff changeset
107 ud2
anatofuz
parents:
diff changeset
108
anatofuz
parents:
diff changeset
109 .section .text.f4,"ax",@progbits
anatofuz
parents:
diff changeset
110 .globl f4
anatofuz
parents:
diff changeset
111 f4:
anatofuz
parents:
diff changeset
112 ud2
anatofuz
parents:
diff changeset
113
anatofuz
parents:
diff changeset
114 .section .rodata.g1,"a",@progbits
anatofuz
parents:
diff changeset
115 .globl g1
anatofuz
parents:
diff changeset
116 g1:
anatofuz
parents:
diff changeset
117 .byte 1
anatofuz
parents:
diff changeset
118
anatofuz
parents:
diff changeset
119 .section .rodata.g2,"a",@progbits
anatofuz
parents:
diff changeset
120 .globl g2
anatofuz
parents:
diff changeset
121 g2:
anatofuz
parents:
diff changeset
122 .byte 1
anatofuz
parents:
diff changeset
123
anatofuz
parents:
diff changeset
124 .section .rodata.g3,"a",@progbits
anatofuz
parents:
diff changeset
125 .globl g3
anatofuz
parents:
diff changeset
126 g3:
anatofuz
parents:
diff changeset
127 .byte 2
anatofuz
parents:
diff changeset
128
anatofuz
parents:
diff changeset
129 .section .rodata.g4,"a",@progbits
anatofuz
parents:
diff changeset
130 .globl g4
anatofuz
parents:
diff changeset
131 g4:
anatofuz
parents:
diff changeset
132 .byte 2
anatofuz
parents:
diff changeset
133
anatofuz
parents:
diff changeset
134 .section .rodata.l1,"a",@progbits
anatofuz
parents:
diff changeset
135 l1:
anatofuz
parents:
diff changeset
136 .byte 3
anatofuz
parents:
diff changeset
137
anatofuz
parents:
diff changeset
138 .section .rodata.l2,"a",@progbits
anatofuz
parents:
diff changeset
139 l2:
anatofuz
parents:
diff changeset
140 .byte 3
anatofuz
parents:
diff changeset
141
anatofuz
parents:
diff changeset
142 .section .rodata.l3,"a",@progbits
anatofuz
parents:
diff changeset
143 l3:
anatofuz
parents:
diff changeset
144 .byte 4
anatofuz
parents:
diff changeset
145
anatofuz
parents:
diff changeset
146 .section .rodata.l4,"a",@progbits
anatofuz
parents:
diff changeset
147 l4:
anatofuz
parents:
diff changeset
148 .byte 4
anatofuz
parents:
diff changeset
149
anatofuz
parents:
diff changeset
150 .section .rodata.h1,"a",@progbits
anatofuz
parents:
diff changeset
151 .globl h1
anatofuz
parents:
diff changeset
152 .hidden h1
anatofuz
parents:
diff changeset
153 h1:
anatofuz
parents:
diff changeset
154 .byte 5
anatofuz
parents:
diff changeset
155
anatofuz
parents:
diff changeset
156 .section .rodata.h2,"a",@progbits
anatofuz
parents:
diff changeset
157 .globl h2
anatofuz
parents:
diff changeset
158 .hidden h2
anatofuz
parents:
diff changeset
159 h2:
anatofuz
parents:
diff changeset
160 .byte 5
anatofuz
parents:
diff changeset
161
anatofuz
parents:
diff changeset
162 .section .rodata.h3,"a",@progbits
anatofuz
parents:
diff changeset
163 .globl h3
anatofuz
parents:
diff changeset
164 .hidden h3
anatofuz
parents:
diff changeset
165 h3:
anatofuz
parents:
diff changeset
166 .byte 6
anatofuz
parents:
diff changeset
167
anatofuz
parents:
diff changeset
168 .section .rodata.h4,"a",@progbits
anatofuz
parents:
diff changeset
169 .globl h4
anatofuz
parents:
diff changeset
170 .hidden h4
anatofuz
parents:
diff changeset
171 h4:
anatofuz
parents:
diff changeset
172 .byte 6
anatofuz
parents:
diff changeset
173
anatofuz
parents:
diff changeset
174 .addrsig
anatofuz
parents:
diff changeset
175 .addrsig_sym f1
anatofuz
parents:
diff changeset
176 .addrsig_sym f2
anatofuz
parents:
diff changeset
177 .addrsig_sym g1
anatofuz
parents:
diff changeset
178 .addrsig_sym g2
anatofuz
parents:
diff changeset
179 .addrsig_sym l1
anatofuz
parents:
diff changeset
180 .addrsig_sym l2
anatofuz
parents:
diff changeset
181 .addrsig_sym h1
anatofuz
parents:
diff changeset
182 .addrsig_sym h2