blob: fa78b76863732fc516e107a8db1dd737f9127d5e [file] [log] [blame]
// REQUIRES: riscv
// RUN: rm -rf %t && split-file %s %t && cd %t
// RUN: llvm-mc -filetype=obj -triple=riscv64 a.s -o a.o
// RUN: ld.lld a.o -T eh-frame-non-zero-offset.t -o non-zero
// RUN: llvm-readelf --program-headers --unwind --symbols -x .eh_frame non-zero | FileCheck --check-prefix=NONZERO %s
// RUN: ld.lld a.o -T eh-frame-zero-offset.t -o zero
// RUN: llvm-readelf --program-headers --unwind --symbols -x .eh_frame zero | FileCheck --check-prefix=ZERO %s
// NONZERO: {{[0-9]+}}: 0000000000000088 {{.*}} __eh_frame_start
// NONZERO-NEXT: {{[0-9]+}}: 00000000000000b4 {{.*}} __eh_frame_end
// NONZERO: 0x00000088 10000000 00000000 017a5200 01780101 .
// NONZERO-NEXT: 0x00000098 1b0c0200 10000000 18000000 5cffffff .
// NONZERO-NEXT: 0x000000a8 04000000 00000000 00000000 .
// ZERO: {{[0-9]+}}: 0000000000000008 {{.*}} __eh_frame_start
// ZERO-NEXT: {{[0-9]+}}: 0000000000000034 {{.*}} __eh_frame_end
// ZERO: 0x00000008 10000000 00000000 017a5200 01780101 .
// ZERO-NEXT: 0x00000018 1b0c0200 10000000 18000000 dcffffff .
// ZERO-NEXT: 0x00000028 04000000 00000000 00000000 .
//--- eh-frame-non-zero-offset.t
SECTIONS {
.text : { *(.text .text.*) }
.eh_frame : {
/* Padding within .eh_frame */
. += 128;
__eh_frame_start = .;
*(.eh_frame) ;
__eh_frame_end = .;
}
}
//--- eh-frame-zero-offset.t
SECTIONS {
.text : { *(.text .text.*) }
.eh_frame : {
__eh_frame_start = .;
*(.eh_frame) ;
__eh_frame_end = .;
}
}
//--- a.s
.section .text.01, "ax",%progbits
.global f1
.type f1, %function
f1:
.cfi_startproc
.space 4
.cfi_endproc