| # REQUIRES: loongarch |
| |
| # RUN: llvm-mc --filetype=obj --triple=loongarch64-unknown-elf %s -o %t.la64.o |
| |
| # RUN: ld.lld --section-start=.text=0x1234567890 --section-start=.rodata=0x9876543210 %t.la64.o -o %t.la64 |
| # RUN: llvm-readelf -x .rodata %t.la64 | FileCheck --check-prefix=CHECK %s |
| # CHECK: section '.rodata': |
| # CHECK-NEXT: 0x9876543210 10325476 98badcfe 804602be 79ffffff |
| # CHECK-NEXT: 0x9876543220 804602be 80468097 |
| |
| .text |
| .global _start |
| _start: |
| 1: |
| break 0 |
| |
| .rodata |
| 2: |
| .dword 0xfedcba9876543210 |
| |
| foo: |
| .dword 0 |
| .reloc foo, R_LARCH_ADD64, 1b |
| .reloc foo, R_LARCH_SUB64, 2b |
| bar: |
| .word 0 |
| .reloc bar, R_LARCH_ADD32, 1b |
| .reloc bar, R_LARCH_SUB32, 2b |
| baz: |
| .short 0 |
| .reloc baz, R_LARCH_ADD16, 1b |
| .reloc baz, R_LARCH_SUB16, 2b |
| quux: |
| .byte 0 |
| .reloc quux, R_LARCH_ADD8, 1b |
| .reloc quux, R_LARCH_SUB8, 2b |
| qux: |
| .byte 0b10000000 |
| .reloc qux, R_LARCH_ADD6, qux |
| .reloc qux, R_LARCH_SUB6, 2b |