forked from OSchip/llvm-project
32 lines
1.0 KiB
Plaintext
32 lines
1.0 KiB
Plaintext
# REQUIRES: x86
|
|
# RUN: llvm-mc -filetype=obj -triple=x86_64-pc-linux %p/Inputs/at3.s -o %t.o
|
|
# RUN: ld.lld %t.o --script %s -o %t
|
|
# RUN: llvm-readelf -S -l %t | FileCheck %s
|
|
|
|
MEMORY {
|
|
FOO (ax) : ORIGIN = 0x1000, LENGTH = 0x100
|
|
BAR (ax) : ORIGIN = 0x2000, LENGTH = 0x100
|
|
ZED (ax) : ORIGIN = 0x3000, LENGTH = 0x100
|
|
FLASH (ax) : ORIGIN = 0x6000, LENGTH = 0x200
|
|
}
|
|
|
|
SECTIONS {
|
|
.foo1 : { *(.foo1) } > FOO AT>FLASH
|
|
.foo2 : { *(.foo2) BYTE(0x42) } > BAR AT>FLASH
|
|
.foo3 : { *(.foo3) } > ZED AT>FLASH
|
|
}
|
|
|
|
# CHECK: .foo1 PROGBITS 0000000000001000 001000
|
|
# CHECK: .foo2 PROGBITS 0000000000002000 002000
|
|
# CHECK: .foo3 PROGBITS 0000000000003000 003000
|
|
|
|
# CHECK: Program Headers:
|
|
# CHECK-NOT: LOAD
|
|
|
|
# CHECK: Type Offset VirtAddr PhysAddr
|
|
# CHECK-NEXT: LOAD 0x001000 0x0000000000001000 0x0000000000006000
|
|
# CHECK-NEXT: LOAD 0x002000 0x0000000000002000 0x0000000000006008
|
|
# CHECK-NEXT: LOAD 0x003000 0x0000000000003000 0x0000000000006011
|
|
|
|
# CHECK-NOT: LOAD
|