annotate lld/test/COFF/associative-comdat-mingw.s @ 201:a96fbbdf2d0f

...
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Fri, 04 Jun 2021 21:07:06 +0900
parents 1d019706d866
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 # RUN: llvm-mc -triple=x86_64-windows-gnu %s -filetype=obj -o %t1.obj
anatofuz
parents:
diff changeset
4 # RUN: llvm-mc -triple=x86_64-windows-gnu %S/Inputs/associative-comdat-mingw-2.s -filetype=obj -o %t2.obj
anatofuz
parents:
diff changeset
5
anatofuz
parents:
diff changeset
6 # RUN: lld-link -lldmingw -entry:main %t1.obj %t2.obj -out:%t.gc.exe -verbose
anatofuz
parents:
diff changeset
7 # RUN: llvm-readobj --sections %t.gc.exe | FileCheck %s
anatofuz
parents:
diff changeset
8
anatofuz
parents:
diff changeset
9 # CHECK: Sections [
anatofuz
parents:
diff changeset
10 # CHECK: Section {
anatofuz
parents:
diff changeset
11 # CHECK: Number: 2
anatofuz
parents:
diff changeset
12 # CHECK-LABEL: Name: .rdata (2E 72 64 61 74 61 00 00)
anatofuz
parents:
diff changeset
13 # This is the critical check to show that only *one* definition of
anatofuz
parents:
diff changeset
14 # .xdata$foo was retained. This *must* be 0x24 (0x4 for the .xdata
anatofuz
parents:
diff changeset
15 # section and 0x20 for the .ctors/.dtors headers/ends).
anatofuz
parents:
diff changeset
16 # Make sure that no other .xdata sections get included, which would
anatofuz
parents:
diff changeset
17 # increase the size here.
anatofuz
parents:
diff changeset
18 # CHECK-NEXT: VirtualSize: 0x24
anatofuz
parents:
diff changeset
19
anatofuz
parents:
diff changeset
20 .text
anatofuz
parents:
diff changeset
21 .def main;
anatofuz
parents:
diff changeset
22 .scl 2;
anatofuz
parents:
diff changeset
23 .type 32;
anatofuz
parents:
diff changeset
24 .endef
anatofuz
parents:
diff changeset
25 .globl main
anatofuz
parents:
diff changeset
26 .p2align 4, 0x90
anatofuz
parents:
diff changeset
27 main:
anatofuz
parents:
diff changeset
28 call foo
anatofuz
parents:
diff changeset
29 retq
anatofuz
parents:
diff changeset
30
anatofuz
parents:
diff changeset
31 # Defines .text$foo (which has a leader symbol and is referenced like
anatofuz
parents:
diff changeset
32 # normally), and .xdata$foo (which lacks a leader symbol, which normally
anatofuz
parents:
diff changeset
33 # would be declared associative to the symbol foo).
anatofuz
parents:
diff changeset
34 # .xdata$foo should be implicitly treated as associative to foo and brought
anatofuz
parents:
diff changeset
35 # in, while .xdata$bar, implicitly associative to bar, not included, and
anatofuz
parents:
diff changeset
36 # .xdata$baz not included since there's no symbol baz.
anatofuz
parents:
diff changeset
37
anatofuz
parents:
diff changeset
38 # GNU binutils ld doesn't do this at all, but always includes all .xdata/.pdata
anatofuz
parents:
diff changeset
39 # comdat sections, even if --gc-sections is used.
anatofuz
parents:
diff changeset
40
anatofuz
parents:
diff changeset
41 .section .xdata$foo,"dr"
anatofuz
parents:
diff changeset
42 .linkonce discard
anatofuz
parents:
diff changeset
43 .p2align 3
anatofuz
parents:
diff changeset
44 .long 42
anatofuz
parents:
diff changeset
45
anatofuz
parents:
diff changeset
46 .section .xdata$bar,"dr"
anatofuz
parents:
diff changeset
47 .linkonce discard
anatofuz
parents:
diff changeset
48 .p2align 3
anatofuz
parents:
diff changeset
49 .long 43
anatofuz
parents:
diff changeset
50
anatofuz
parents:
diff changeset
51 .section .xdata$baz,"dr"
anatofuz
parents:
diff changeset
52 .linkonce discard
anatofuz
parents:
diff changeset
53 .p2align 3
anatofuz
parents:
diff changeset
54 .long 44
anatofuz
parents:
diff changeset
55
anatofuz
parents:
diff changeset
56 .def foo;
anatofuz
parents:
diff changeset
57 .scl 2;
anatofuz
parents:
diff changeset
58 .type 32;
anatofuz
parents:
diff changeset
59 .endef
anatofuz
parents:
diff changeset
60 .section .text$foo,"xr",discard,foo
anatofuz
parents:
diff changeset
61 .globl foo
anatofuz
parents:
diff changeset
62 .p2align 4
anatofuz
parents:
diff changeset
63 foo:
anatofuz
parents:
diff changeset
64 ret
anatofuz
parents:
diff changeset
65
anatofuz
parents:
diff changeset
66 .def bar;
anatofuz
parents:
diff changeset
67 .scl 2;
anatofuz
parents:
diff changeset
68 .type 32;
anatofuz
parents:
diff changeset
69 .endef
anatofuz
parents:
diff changeset
70 .section .text$bar,"xr",discard,bar
anatofuz
parents:
diff changeset
71 .globl bar
anatofuz
parents:
diff changeset
72 .p2align 4
anatofuz
parents:
diff changeset
73 bar:
anatofuz
parents:
diff changeset
74 ret