# 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