summaryrefslogtreecommitdiffstats
path: root/lld/test/ELF/linkerscript/compress-nonalloc-sections.s
blob: 74b93eef442980f3cff40409f83e32c96151b83e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
# REQUIRES: x86, zlib

# RUN: rm -rf %t && split-file %s %t && cd %t
# RUN: llvm-mc -filetype=obj -triple=x86_64 a.s -o a.o
# RUN: ld.lld -T a.lds a.o --compress-nonalloc-sections nonalloc=zlib --compress-nonalloc-sections str=zlib -o out
# RUN: llvm-readelf -SsXz -p str out | FileCheck %s

# CHECK:      Name     Type            Address   Off      Size     ES Flg  Lk Inf Al
# CHECK:      nonalloc PROGBITS 0000000000000000 [[#%x,]] [[#%x,]] 00   C   0   0  1
# CHECK-NEXT: str      PROGBITS 0000000000000000 [[#%x,]] [[#%x,]] 01 MSC   0   0  1

# CHECK:      0000000000000000  0 NOTYPE  GLOBAL DEFAULT [[#]] (nonalloc) nonalloc_start
# CHECK:      0000000000000023  0 NOTYPE  GLOBAL DEFAULT [[#]] (nonalloc) nonalloc_end
# CHECK:      String dump of section 'str':
# CHECK-NEXT: [     0] AAA
# CHECK-NEXT: [     4] BBB

## TODO The uncompressed size of 'nonalloc' is dependent on linker script
## commands, which is not handled. We should report an error.
# RUN: ld.lld -T b.lds a.o --compress-nonalloc-sections nonalloc=zlib

#--- a.s
.globl _start
_start:
  ret

.section nonalloc0,""
.balign 8
.quad .text
.quad .text
.section nonalloc1,""
.balign 8
.quad 42

.section str,"MS",@progbits,1
  .asciz "AAA"
  .asciz "BBB"

#--- a.lds
SECTIONS {
  .text : { *(.text) }
  c = SIZEOF(.text);
  b = c+1;
  a = b+1;
  nonalloc : {
    nonalloc_start = .;
## In general, using data commands is error-prone. This case is correct, though.
    *(nonalloc*) QUAD(SIZEOF(.text))
    . += a;
    nonalloc_end = .;
  }
  str : { *(str) }
}

#--- b.lds
SECTIONS {
  nonalloc : { *(nonalloc*) . += a; }
  .text : { *(.text) }
  a = b+1;
  b = c+1;
  c = SIZEOF(.text);
}