| # RUN: rm -rf %t && mkdir -p %t |
| # RUN: llvm-mc -triple=riscv64 -filetype=obj -o %t/riscv64_reloc_set.o %s |
| # RUN: llvm-mc -triple=riscv32 -filetype=obj -o %t/riscv32_reloc_set.o %s |
| # RUN: llvm-jitlink -noexec \ |
| # RUN: -slab-allocate 100Kb -slab-address 0xfff0f0f0 -slab-page-size 4096 \ |
| # RUN: -check %s %t/riscv64_reloc_set.o |
| # RUN: llvm-jitlink -noexec \ |
| # RUN: -slab-allocate 100Kb -slab-address 0xfff0f0f0 -slab-page-size 4096 \ |
| # RUN: -check %s %t/riscv32_reloc_set.o |
| |
| # jitlink-check: *{4}(foo) = foo |
| # jitlink-check: *{2}(foo+4) = foo[15:0] |
| # jitlink-check: *{1}(foo+6) = foo[7:0] |
| # jitlink-check: *{1}(foo+7) = foo[5:0] |
| |
| .global main |
| main: |
| lw a0, foo |
| |
| .section ".rodata","",@progbits |
| .type foo,@object |
| foo: |
| .reloc foo, R_RISCV_SET32, foo |
| .reloc foo+4, R_RISCV_SET16, foo |
| .reloc foo+6, R_RISCV_SET8, foo |
| .reloc foo+7, R_RISCV_SET6, foo |
| .word 0 |
| .half 0 |
| .byte 0 |
| .byte 0 |
| .size foo, 8 |