forked from OSchip/llvm-project
38 lines
1.1 KiB
Plaintext
38 lines
1.1 KiB
Plaintext
# REQUIRES: x86
|
|
|
|
# RUN: echo ".section .foo,\"a\"" > %t.s
|
|
# RUN: echo ".quad 1" >> %t.s
|
|
# RUN: echo ".section .bar,\"a\"" >> %t.s
|
|
# RUN: echo ".quad 1" >> %t.s
|
|
# RUN: llvm-mc -filetype=obj -triple=x86_64-unknown-linux %t.s -o %t.o
|
|
|
|
# RUN: ld.lld -o %t %t.o --script %s
|
|
# RUN: llvm-readelf -sections -program-headers %t | FileCheck %s
|
|
|
|
## Check that we can produce output without errors,
|
|
## and .foo section has proper size.
|
|
# CHECK: Section Headers:
|
|
# CHECK-NEXT: [Nr] Name Type Address Off Size
|
|
# CHECK-NEXT: [ 0] NULL 0000000000000000 000000 000000
|
|
# CHECK-NEXT: [ 1] .foo PROGBITS 0000000000001000 001000 000108
|
|
# CHECK-NEXT: [ 2] .bar PROGBITS 0000000000001108 001108 000008
|
|
|
|
## Check that load address is correct.
|
|
# CHECK: Program Headers:
|
|
# CHECK-NEXT: Type Offset VirtAddr PhysAddr FileSiz MemSiz
|
|
# CHECK-NEXT: LOAD 0x001000 0x0000000000001000 0x0000000000002000 0x000110 0x000110
|
|
|
|
MEMORY {
|
|
ram (rwx) : org = 0x1000, len = 0x200
|
|
flash (rwx) : org = 0x2000, len = 0x200
|
|
}
|
|
SECTIONS {
|
|
.foo : {
|
|
*(.foo)
|
|
. += 0x100;
|
|
} > ram AT>flash
|
|
.bar : {
|
|
*(.bar)
|
|
} > ram AT>flash
|
|
}
|