llvm/lld/test/ELF/loongarch-reloc-leb128.s

# REQUIRES: loongarch
# RUN: rm -rf %t && split-file %s %t && cd %t

# RUN: llvm-mc --filetype=obj --triple=loongarch64 --mattr=+relax a.s -o a.o
# RUN: llvm-readobj -r -x .gcc_except_table -x .debug_rnglists -x .debug_loclists a.o | FileCheck %s --check-prefix=REL
# RUN: ld.lld -shared --gc-sections a.o -o a.so
# RUN: llvm-readelf -x .gcc_except_table -x .debug_rnglists -x .debug_loclists a.so | FileCheck %s

# RUN: llvm-mc --filetype=obj --triple=loongarch32 --mattr=+relax a.s -o a32.o
# RUN: llvm-readobj -r -x .gcc_except_table -x .debug_rnglists -x .debug_loclists a32.o | FileCheck %s --check-prefix=REL
# RUN: ld.lld -shared --gc-sections a32.o -o a32.so
# RUN: llvm-readelf -x .gcc_except_table -x .debug_rnglists -x .debug_loclists a32.so | FileCheck %s

# RUN: llvm-mc --filetype=obj --triple=loongarch32 --mattr=+relax extraspace.s -o extraspace32.o
# RUN: llvm-mc --filetype=obj --triple=loongarch64 --mattr=+relax extraspace.s -o extraspace64.o
# RUN: not ld.lld -shared extraspace32.o 2>&1 | FileCheck %s --check-prefix=ERROR
# RUN: not ld.lld -shared extraspace64.o 2>&1 | FileCheck %s --check-prefix=ERROR
# ERROR: error: extraspace{{.*}}.o:(.rodata+0x0): extra space for uleb128

#--- a.s
.cfi_startproc
.cfi_lsda 0x1b,.LLSDA0
.cfi_endproc

.section .text.w,"axR"
break 0; break 0; break 0; w1:
  .p2align 4    # 4 bytes after relaxation
w2: break 0

.section .text.x,"ax"
break 0; break 0; break 0; x1:
  .p2align 4    # 4 bytes after relaxation
x2: break 0

.section .gcc_except_table,"a"
.LLSDA0:
.uleb128 w2-w1+116                   # initial value: 0x0080
.uleb128 w1-w2+141                   # initial value: 0x0080
.uleb128 w2-w1+16372                 # initial value: 0x008080
.uleb128 w1-w2+16397                 # initial value: 0x008080
.uleb128 w2-w1+2097140               # initial value: 0x00808080
.uleb128 w1-w2+2097165               # initial value: 0x00808080

.section .debug_rnglists
.uleb128 w2-w1+116                   # initial value: 0x0080
.uleb128 w1-w2+141                   # initial value: 0x0080
.uleb128 w2-w1+16372                 # initial value: 0x008080
.uleb128 w1-w2+16397                 # initial value: 0x008080
.uleb128 w2-w1+2097140               # initial value: 0x00808080
.uleb128 w1-w2+2097165               # initial value: 0x00808080

.section .debug_loclists
.uleb128 x2-x1                       # references discarded symbols

# REL:      Section ({{.*}}) .rela.debug_rnglists {
# REL-NEXT:   0x0 R_LARCH_ADD_ULEB128 w2 0x74
# REL-NEXT:   0x0 R_LARCH_SUB_ULEB128 w1 0x0
# REL-NEXT:   0x2 R_LARCH_ADD_ULEB128 w1 0x8D
# REL-NEXT:   0x2 R_LARCH_SUB_ULEB128 w2 0x0
# REL-NEXT:   0x4 R_LARCH_ADD_ULEB128 w2 0x3FF4
# REL-NEXT:   0x4 R_LARCH_SUB_ULEB128 w1 0x0
# REL-NEXT:   0x7 R_LARCH_ADD_ULEB128 w1 0x400D
# REL-NEXT:   0x7 R_LARCH_SUB_ULEB128 w2 0x0
# REL-NEXT:   0xA R_LARCH_ADD_ULEB128 w2 0x1FFFF4
# REL-NEXT:   0xA R_LARCH_SUB_ULEB128 w1 0x0
# REL-NEXT:   0xE R_LARCH_ADD_ULEB128 w1 0x20000D
# REL-NEXT:   0xE R_LARCH_SUB_ULEB128 w2 0x0
# REL-NEXT: }
# REL:      Section ({{.*}}) .rela.debug_loclists {
# REL-NEXT:   0x0 R_LARCH_ADD_ULEB128 x2 0x0
# REL-NEXT:   0x0 R_LARCH_SUB_ULEB128 x1 0x0
# REL-NEXT: }

# REL:      Hex dump of section '.gcc_except_table':
# REL-NEXT: 0x00000000 80008000 80800080 80008080 80008080 .
# REL-NEXT: 0x00000010 8000                                .
# REL:      Hex dump of section '.debug_rnglists':
# REL-NEXT: 0x00000000 80008000 80800080 80008080 80008080 .
# REL-NEXT: 0x00000010 8000                                .
# REL:      Hex dump of section '.debug_loclists':
# REL-NEXT: 0x00000000 00                                  .

# CHECK:      Hex dump of section '.gcc_except_table':
# CHECK-NEXT: 0x[[#%x,]] f8008901 f8ff0089 8001f8ff ff008980 .
# CHECK-NEXT: 0x[[#%x,]] 8001                                .
# CHECK:      Hex dump of section '.debug_rnglists':
# CHECK-NEXT: 0x00000000 f8008901 f8ff0089 8001f8ff ff008980 .
# CHECK-NEXT: 0x00000010 8001                                .
# CHECK:      Hex dump of section '.debug_loclists':
# CHECK-NEXT: 0x00000000 00                                  .

#--- extraspace.s
.text
w1:
  la.pcrel $t0, w1
w2:

.rodata
.reloc ., R_LARCH_ADD_ULEB128, w2
.reloc ., R_LARCH_SUB_ULEB128, w1
.fill 10, 1, 0x80
.byte 1