annotate lld/test/ELF/pack-dyn-relocs-relr-loop.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: aarch64
anatofuz
parents:
diff changeset
2 # RUN: llvm-mc -filetype=obj -triple=aarch64 %s -o %t.o
anatofuz
parents:
diff changeset
3 # RUN: ld.lld -pie --pack-dyn-relocs=relr -z max-page-size=4096 --verbose %t.o -o %t 2>&1 | FileCheck %s
anatofuz
parents:
diff changeset
4 # RUN: llvm-readobj -r %t | FileCheck --check-prefix=RELR %s
anatofuz
parents:
diff changeset
5
anatofuz
parents:
diff changeset
6 ## This test makes sure we don't shrink .relr.dyn, otherwise its size may
anatofuz
parents:
diff changeset
7 ## oscillate between 2 words and 3 words.
anatofuz
parents:
diff changeset
8
anatofuz
parents:
diff changeset
9 ## The test is very sensitive to the exact section sizes and offsets,
anatofuz
parents:
diff changeset
10 ## make sure .data is located at a page boundary.
anatofuz
parents:
diff changeset
11
anatofuz
parents:
diff changeset
12 # CHECK: .relr.dyn needs 1 padding word(s)
anatofuz
parents:
diff changeset
13
anatofuz
parents:
diff changeset
14 # RELR: .relr.dyn {
anatofuz
parents:
diff changeset
15 # RELR-NEXT: 0x2F40 R_AARCH64_RELATIVE - 0x0
anatofuz
parents:
diff changeset
16 # RELR-NEXT: 0x2F48 R_AARCH64_RELATIVE - 0x0
anatofuz
parents:
diff changeset
17 # RELR-NEXT: 0x3000 R_AARCH64_RELATIVE - 0x0
anatofuz
parents:
diff changeset
18 # RELR-NEXT: }
anatofuz
parents:
diff changeset
19
anatofuz
parents:
diff changeset
20 .section .data.rel.ro
anatofuz
parents:
diff changeset
21 .align 3
anatofuz
parents:
diff changeset
22 .space 0xce0
anatofuz
parents:
diff changeset
23 foo:
anatofuz
parents:
diff changeset
24 ## Encoded by the first word of .relr.dyn
anatofuz
parents:
diff changeset
25 .quad foo
anatofuz
parents:
diff changeset
26
anatofuz
parents:
diff changeset
27 ## Encoded by the second word of .relr.dyn
anatofuz
parents:
diff changeset
28 .quad foo
anatofuz
parents:
diff changeset
29
anatofuz
parents:
diff changeset
30 .section .data
anatofuz
parents:
diff changeset
31 .align 3
anatofuz
parents:
diff changeset
32 ## If .data is at 0x3000, the relocation will be encoded by the second word.
anatofuz
parents:
diff changeset
33 ## If we shrink .relr.dyn, the end of .dynamic will be at 0x2ff8 and .data
anatofuz
parents:
diff changeset
34 ## will be at 0x3ff8, we will need the third word to encode this relocation,
anatofuz
parents:
diff changeset
35 ## which will cause .relr.dyn to expand again.
anatofuz
parents:
diff changeset
36 .quad foo