| # RUN: rm -rf %t && mkdir -p %t |
| # RUN: llvm-mc -triple=riscv64 -filetype=obj \ |
| # RUN: -o %t/elf_riscv64_branch.o %s |
| # RUN: llvm-mc -triple=riscv32 -filetype=obj \ |
| # RUN: -o %t/elf_riscv32_branch.o %s |
| # RUN: llvm-jitlink -noexec \ |
| # RUN: -slab-allocate 100Kb -slab-address 0xfff00ff4 -slab-page-size 4096 \ |
| # RUN: -abs external_func_positive_offset=0xfff00ffc -abs external_func_negative_offset=0xfff00000\ |
| # RUN: -check %s %t/elf_riscv64_branch.o |
| # RUN: llvm-jitlink -noexec \ |
| # RUN: -slab-allocate 100Kb -slab-address 0xfff00ff4 -slab-page-size 4096 \ |
| # RUN: -abs external_func_positive_offset=0xfff00ffc -abs external_func_negative_offset=0xfff00000 \ |
| # RUN: -check %s %t/elf_riscv32_branch.o |
| # |
| |
| .text |
| # Empty main entry point. |
| .globl main |
| .p2align 1 |
| .type main,@function |
| main: |
| ret |
| |
| .size main, .-main |
| |
| # Test R_RISCV_BRANCH |
| |
| # jitlink-check: decode_operand(test_branch, 2)[12:0] = (external_func_positive_offset - test_branch)[12:0] |
| # jitlink-check: decode_operand(test_branch+4, 2)[12:0] = (external_func_negative_offset - test_branch - 4)[12:0] |
| .globl test_branch |
| .p2align 1 |
| .type test_branch,@function |
| test_branch: |
| bge a0, a1, external_func_positive_offset |
| bge a0, a1, external_func_negative_offset |
| |
| .size test_branch, .-test_branch |