| // 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 |