aboutsummaryrefslogtreecommitdiff
path: root/test/ELF/linkerscript/section-include.test
blob: 9b6dfa0dcc4eb7371df3d3329c65e94f929f1439 (plain) (blame)
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
# REQUIRES: x86

# RUN: echo '.section .text,"ax"; .global _start; nop' > %t.s
# RUN: echo '.section .data,"aw"; .quad 0' >> %t.s
# RUN: llvm-mc -filetype=obj -triple=x86_64-unknown-linux %t.s -o %t.o

## Empty include file.
# RUN: echo "" > %t.inc
# RUN: ld.lld -o %t.elf --script %s %t.o -L %T
# RUN: llvm-objdump -section-headers %t.elf | FileCheck %s --check-prefix=CHECK1
# CHECK1:      .data         00000008 0000000000002000 DATA
# CHECK1-NEXT: .data3        00000008 0000000000002008 DATA

## Non-empty include file.
# RUN: echo ".data2 : { QUAD(0) } > RAM" > %t.inc
# RUN: ld.lld -o %t.elf --script %s %t.o -L %T
# RUN: llvm-objdump -section-headers %t.elf | FileCheck %s --check-prefix=CHECK2
# CHECK2:      .data         00000008 0000000000002000 DATA
# CHECK2-NEXT: .data2        00000008 0000000000002008 DATA
# CHECK2-NEXT: .data3        00000008 0000000000002010 DATA

MEMORY {
  ROM (rwx): ORIGIN = 0x1000, LENGTH = 0x100
  RAM (rwx): ORIGIN = 0x2000, LENGTH = 0x100
}

SECTIONS {
  .text : { *(.text*) } > ROM
  .data : { *(.data*) } > RAM
  INCLUDE "section-include.test.tmp.inc"
  .data3 : { QUAD(0) } > RAM
}