# REQUIRES: loongarch # RUN: rm -rf %t && split-file %s %t # RUN: llvm-mc --filetype=obj --triple=loongarch32 %t/a.s -o %t/a.la32.o # RUN: llvm-mc --filetype=obj --triple=loongarch64 %t/a.s -o %t/a.la64.o # RUN: llvm-mc --filetype=obj --triple=loongarch64 %t/extreme.s -o %t/extreme.o # RUN: ld.lld %t/a.la32.o --section-start=.rodata=0x11000 --section-start=.text=0x11ffc -o %t/case1.la32 # RUN: ld.lld %t/a.la64.o --section-start=.rodata=0x11000 --section-start=.text=0x11ffc -o %t/case1.la64 # RUN: llvm-objdump -d --no-show-raw-insn %t/case1.la32 | FileCheck %s --check-prefix=CASE1 # RUN: llvm-objdump -d --no-show-raw-insn %t/case1.la64 | FileCheck %s --check-prefix=CASE1 # CASE1: pcalau12i $a0, 0 # CASE1-NEXT: ld.w $a0, $a0, 0 # RUN: ld.lld %t/a.la32.o --section-start=.rodata=0x11000 --section-start=.text=0x12000 -o %t/case2.la32 # RUN: ld.lld %t/a.la64.o --section-start=.rodata=0x11000 --section-start=.text=0x12000 -o %t/case2.la64 # RUN: llvm-objdump -d --no-show-raw-insn %t/case2.la32 | FileCheck %s --check-prefix=CASE2 # RUN: llvm-objdump -d --no-show-raw-insn %t/case2.la64 | FileCheck %s --check-prefix=CASE2 # CASE2: pcalau12i $a0, -1 # CASE2-NEXT: ld.w $a0, $a0, 0 # RUN: ld.lld %t/a.la32.o --section-start=.rodata=0x117ff --section-start=.text=0x12000 -o %t/case3.la32 # RUN: ld.lld %t/a.la64.o --section-start=.rodata=0x117ff --section-start=.text=0x12000 -o %t/case3.la64 # RUN: llvm-objdump -d --no-show-raw-insn %t/case3.la32 | FileCheck %s --check-prefix=CASE3 # RUN: llvm-objdump -d --no-show-raw-insn %t/case3.la64 | FileCheck %s --check-prefix=CASE3 # CASE3: pcalau12i $a0, -1 # CASE3-NEXT: ld.w $a0, $a0, 2047 # RUN: ld.lld %t/a.la32.o --section-start=.rodata=0x11800 --section-start=.text=0x12000 -o %t/case4.la32 # RUN: ld.lld %t/a.la64.o --section-start=.rodata=0x11800 --section-start=.text=0x12000 -o %t/case4.la64 # RUN: llvm-objdump -d --no-show-raw-insn %t/case4.la32 | FileCheck %s --check-prefix=CASE4 # RUN: llvm-objdump -d --no-show-raw-insn %t/case4.la64 | FileCheck %s --check-prefix=CASE4 # CASE4: pcalau12i $a0, 0 # CASE4-NEXT: ld.w $a0, $a0, -2048 # RUN: ld.lld %t/a.la32.o --section-start=.rodata=0x12004 --section-start=.text=0x11ffc -o %t/case5.la32 # RUN: ld.lld %t/a.la64.o --section-start=.rodata=0x12004 --section-start=.text=0x11ffc -o %t/case5.la64 # RUN: llvm-objdump -d --no-show-raw-insn %t/case5.la32 | FileCheck %s --check-prefix=CASE5 # RUN: llvm-objdump -d --no-show-raw-insn %t/case5.la64 | FileCheck %s --check-prefix=CASE5 # CASE5: pcalau12i $a0, 1 # CASE5-NEXT: ld.w $a0, $a0, 4 # RUN: ld.lld %t/a.la32.o --section-start=.rodata=0x12800 --section-start=.text=0x11ffc -o %t/case6.la32 # RUN: ld.lld %t/a.la64.o --section-start=.rodata=0x12800 --section-start=.text=0x11ffc -o %t/case6.la64 # RUN: llvm-objdump -d --no-show-raw-insn %t/case6.la32 | FileCheck %s --check-prefix=CASE6 # RUN: llvm-objdump -d --no-show-raw-insn %t/case6.la64 | FileCheck %s --check-prefix=CASE6 # CASE6: pcalau12i $a0, 2 # CASE6-NEXT: ld.w $a0, $a0, -2048 # RUN: ld.lld %t/a.la32.o --section-start=.rodata=0x7ffff123 --section-start=.text=0x0 -o %t/case7.la32 # RUN: ld.lld %t/a.la64.o --section-start=.rodata=0x7ffff123 --section-start=.text=0x0 -o %t/case7.la64 # RUN: llvm-objdump -d --no-show-raw-insn %t/case7.la32 | FileCheck %s --check-prefix=CASE7 # RUN: llvm-objdump -d --no-show-raw-insn %t/case7.la64 | FileCheck %s --check-prefix=CASE7 # CASE7: pcalau12i $a0, 524287 # CASE7-NEXT: ld.w $a0, $a0, 291 # RUN: ld.lld %t/a.la32.o --section-start=.rodata=0x7ffffabc --section-start=.text=0x0 -o %t/case8.la32 # RUN: ld.lld %t/a.la64.o --section-start=.rodata=0x7ffffabc --section-start=.text=0x0 -o %t/case8.la64 # RUN: llvm-objdump -d --no-show-raw-insn %t/case8.la32 | FileCheck %s --check-prefix=CASE8 # RUN: llvm-objdump -d --no-show-raw-insn %t/case8.la64 | FileCheck %s --check-prefix=CASE8 # CASE8: pcalau12i $a0, -524288 # CASE8-NEXT: ld.w $a0, $a0, -1348 # RUN: ld.lld %t/a.la32.o --section-start=.rodata=0x10123 --section-start=.text=0x80010000 -o %t/case9.la32 # RUN: ld.lld %t/a.la64.o --section-start=.rodata=0x10123 --section-start=.text=0x80010000 -o %t/case9.la64 # RUN: llvm-objdump -d --no-show-raw-insn %t/case9.la32 | FileCheck %s --check-prefix=CASE9 # RUN: llvm-objdump -d --no-show-raw-insn %t/case9.la64 | FileCheck %s --check-prefix=CASE9 # CASE9: pcalau12i $a0, -524288 # CASE9-NEXT: ld.w $a0, $a0, 291 ## page delta = 0x4443333322222000, page offset = 0x111 ## %pc_lo12 = 0x111 = 273 ## %pc_hi20 = 0x22222 = 139810 ## %pc64_lo20 = 0x33333 = 209715 ## %pc64_hi12 = 0x444 = 1092 # RUN: ld.lld %t/extreme.o --section-start=.rodata=0x4443333334567111 --section-start=.text=0x0000000012345678 -o %t/extreme0 # RUN: llvm-objdump -d --no-show-raw-insn %t/extreme0 | FileCheck %s --check-prefix=EXTREME0 # EXTREME0: pcalau12i $t1, 139810 # EXTREME0-NEXT: addi.d $t0, $zero, 273 # EXTREME0-NEXT: lu32i.d $t0, 209715 # EXTREME0-NEXT: lu52i.d $t0, $t0, 1092 ## page delta = 0x4443333222223000, page offset = 0x888 ## %pc_lo12 = 0x888 = -1912 ## %pc_hi20 = 0x22223 = 139811 ## %pc64_lo20 = 0x33332 = 209714 ## %pc64_hi12 = 0x444 = 1092 # RUN: ld.lld %t/extreme.o --section-start=.rodata=0x4443333334567888 --section-start=.text=0x0000000012345678 -o %t/extreme1 # RUN: llvm-objdump -d --no-show-raw-insn %t/extreme1 | FileCheck %s --check-prefix=EXTREME1 # EXTREME1: pcalau12i $t1, 139811 # EXTREME1-NEXT: addi.d $t0, $zero, -1912 # EXTREME1-NEXT: lu32i.d $t0, 209714 # EXTREME1-NEXT: lu52i.d $t0, $t0, 1092 ## page delta = 0x4443333499999000, page offset = 0x111 ## %pc_lo12 = 0x111 = 273 ## %pc_hi20 = 0x99999 = -419431 ## %pc64_lo20 = 0x33334 = 209716 ## %pc64_hi12 = 0x444 = 1092 # RUN: ld.lld %t/extreme.o --section-start=.rodata=0x44433333abcde111 --section-start=.text=0x0000000012345678 -o %t/extreme2 # RUN: llvm-objdump -d --no-show-raw-insn %t/extreme2 | FileCheck %s --check-prefix=EXTREME2 # EXTREME2: pcalau12i $t1, -419431 # EXTREME2-NEXT: addi.d $t0, $zero, 273 # EXTREME2-NEXT: lu32i.d $t0, 209716 # EXTREME2-NEXT: lu52i.d $t0, $t0, 1092 ## page delta = 0x444333339999a000, page offset = 0x888 ## %pc_lo12 = 0x888 = -1912 ## %pc_hi20 = 0x9999a = -419430 ## %pc64_lo20 = 0x33333 = 209715 ## %pc64_hi12 = 0x444 = 1092 # RUN: ld.lld %t/extreme.o --section-start=.rodata=0x44433333abcde888 --section-start=.text=0x0000000012345678 -o %t/extreme3 # RUN: llvm-objdump -d --no-show-raw-insn %t/extreme3 | FileCheck %s --check-prefix=EXTREME3 # EXTREME3: pcalau12i $t1, -419430 # EXTREME3-NEXT: addi.d $t0, $zero, -1912 # EXTREME3-NEXT: lu32i.d $t0, 209715 # EXTREME3-NEXT: lu52i.d $t0, $t0, 1092 ## page delta = 0x444aaaaa22222000, page offset = 0x111 ## %pc_lo12 = 0x111 = 273 ## %pc_hi20 = 0x22222 = 139810 ## %pc64_lo20 = 0xaaaaa = -349526 ## %pc64_hi12 = 0x444 = 1092 # RUN: ld.lld %t/extreme.o --section-start=.rodata=0x444aaaaa34567111 --section-start=.text=0x0000000012345678 -o %t/extreme4 # RUN: llvm-objdump -d --no-show-raw-insn %t/extreme4 | FileCheck %s --check-prefix=EXTREME4 # EXTREME4: pcalau12i $t1, 139810 # EXTREME4-NEXT: addi.d $t0, $zero, 273 # EXTREME4-NEXT: lu32i.d $t0, -349526 # EXTREME4-NEXT: lu52i.d $t0, $t0, 1092 ## page delta = 0x444aaaa922223000, page offset = 0x888 ## %pc_lo12 = 0x888 = -1912 ## %pc_hi20 = 0x22223 = 139811 ## %pc64_lo20 = 0xaaaa9 = -349527 ## %pc64_hi12 = 0x444 = 1092 # RUN: ld.lld %t/extreme.o --section-start=.rodata=0x444aaaaa34567888 --section-start=.text=0x0000000012345678 -o %t/extreme5 # RUN: llvm-objdump -d --no-show-raw-insn %t/extreme5 | FileCheck %s --check-prefix=EXTREME5 # EXTREME5: pcalau12i $t1, 139811 # EXTREME5-NEXT: addi.d $t0, $zero, -1912 # EXTREME5-NEXT: lu32i.d $t0, -349527 # EXTREME5-NEXT: lu52i.d $t0, $t0, 1092 ## page delta = 0x444aaaab99999000, page offset = 0x111 ## %pc_lo12 = 0x111 = 273 ## %pc_hi20 = 0x99999 = -419431 ## %pc64_lo20 = 0xaaaab = -349525 ## %pc64_hi12 = 0x444 = 1092 # RUN: ld.lld %t/extreme.o --section-start=.rodata=0x444aaaaaabcde111 --section-start=.text=0x0000000012345678 -o %t/extreme6 # RUN: llvm-objdump -d --no-show-raw-insn %t/extreme6 | FileCheck %s --check-prefix=EXTREME6 # EXTREME6: pcalau12i $t1, -419431 # EXTREME6-NEXT: addi.d $t0, $zero, 273 # EXTREME6-NEXT: lu32i.d $t0, -349525 # EXTREME6-NEXT: lu52i.d $t0, $t0, 1092 ## page delta = 0x444aaaaa9999a000, page offset = 0x888 ## %pc_lo12 = 0x888 = -1912 ## %pc_hi20 = 0x9999a = -419430 ## %pc64_lo20 = 0xaaaaa = -349526 ## %pc64_hi12 = 0x444 = 1092 # RUN: ld.lld %t/extreme.o --section-start=.rodata=0x444aaaaaabcde888 --section-start=.text=0x0000000012345678 -o %t/extreme7 # RUN: llvm-objdump -d --no-show-raw-insn %t/extreme7 | FileCheck %s --check-prefix=EXTREME7 # EXTREME7: pcalau12i $t1, -419430 # EXTREME7-NEXT: addi.d $t0, $zero, -1912 # EXTREME7-NEXT: lu32i.d $t0, -349526 # EXTREME7-NEXT: lu52i.d $t0, $t0, 1092 ## page delta = 0xbbb3333322222000, page offset = 0x111 ## %pc_lo12 = 0x111 = 273 ## %pc_hi20 = 0x22222 = 139810 ## %pc64_lo20 = 0x33333 = 209715 ## %pc64_hi12 = 0xbbb = -1093 # RUN: ld.lld %t/extreme.o --section-start=.rodata=0xbbb3333334567111 --section-start=.text=0x0000000012345678 -o %t/extreme8 # RUN: llvm-objdump -d --no-show-raw-insn %t/extreme8 | FileCheck %s --check-prefix=EXTREME8 # EXTREME8: pcalau12i $t1, 139810 # EXTREME8-NEXT: addi.d $t0, $zero, 273 # EXTREME8-NEXT: lu32i.d $t0, 209715 # EXTREME8-NEXT: lu52i.d $t0, $t0, -1093 ## page delta = 0xbbb3333222223000, page offset = 0x888 ## %pc_lo12 = 0x888 = -1912 ## %pc_hi20 = 0x22223 = 139811 ## %pc64_lo20 = 0x33332 = 209714 ## %pc64_hi12 = 0xbbb = -1093 # RUN: ld.lld %t/extreme.o --section-start=.rodata=0xbbb3333334567888 --section-start=.text=0x0000000012345678 -o %t/extreme9 # RUN: llvm-objdump -d --no-show-raw-insn %t/extreme9 | FileCheck %s --check-prefix=EXTREME9 # EXTREME9: pcalau12i $t1, 139811 # EXTREME9-NEXT: addi.d $t0, $zero, -1912 # EXTREME9-NEXT: lu32i.d $t0, 209714 # EXTREME9-NEXT: lu52i.d $t0, $t0, -1093 ## page delta = 0xbbb3333499999000, page offset = 0x111 ## %pc_lo12 = 0x111 = 273 ## %pc_hi20 = 0x99999 = -419431 ## %pc64_lo20 = 0x33334 = 209716 ## %pc64_hi12 = 0xbbb = -1093 # RUN: ld.lld %t/extreme.o --section-start=.rodata=0xbbb33333abcde111 --section-start=.text=0x0000000012345678 -o %t/extreme10 # RUN: llvm-objdump -d --no-show-raw-insn %t/extreme10 | FileCheck %s --check-prefix=EXTREME10 # EXTREME10: pcalau12i $t1, -419431 # EXTREME10-NEXT: addi.d $t0, $zero, 273 # EXTREME10-NEXT: lu32i.d $t0, 209716 # EXTREME10-NEXT: lu52i.d $t0, $t0, -1093 ## page delta = 0xbbb333339999a000, page offset = 0x888 ## %pc_lo12 = 0x888 = -1912 ## %pc_hi20 = 0x9999a = -419430 ## %pc64_lo20 = 0x33333 = 209715 ## %pc64_hi12 = 0xbbb = -1093 # RUN: ld.lld %t/extreme.o --section-start=.rodata=0xbbb33333abcde888 --section-start=.text=0x0000000012345678 -o %t/extreme11 # RUN: llvm-objdump -d --no-show-raw-insn %t/extreme11 | FileCheck %s --check-prefix=EXTREME11 # EXTREME11: pcalau12i $t1, -419430 # EXTREME11-NEXT: addi.d $t0, $zero, -1912 # EXTREME11-NEXT: lu32i.d $t0, 209715 # EXTREME11-NEXT: lu52i.d $t0, $t0, -1093 ## page delta = 0xbbbaaaaa22222000, page offset = 0x111 ## %pc_lo12 = 0x111 = 273 ## %pc_hi20 = 0x22222 = 139810 ## %pc64_lo20 = 0xaaaaa = -349526 ## %pc64_hi12 = 0xbbb = -1093 # RUN: ld.lld %t/extreme.o --section-start=.rodata=0xbbbaaaaa34567111 --section-start=.text=0x0000000012345678 -o %t/extreme12 # RUN: llvm-objdump -d --no-show-raw-insn %t/extreme12 | FileCheck %s --check-prefix=EXTREME12 # EXTREME12: pcalau12i $t1, 139810 # EXTREME12-NEXT: addi.d $t0, $zero, 273 # EXTREME12-NEXT: lu32i.d $t0, -349526 # EXTREME12-NEXT: lu52i.d $t0, $t0, -1093 ## page delta = 0xbbbaaaa922223000, page offset = 0x888 ## %pc_lo12 = 0x888 = -1912 ## %pc_hi20 = 0x22223 = 139811 ## %pc64_lo20 = 0xaaaa9 = -349527 ## %pc64_hi12 = 0xbbb = -1093 # RUN: ld.lld %t/extreme.o --section-start=.rodata=0xbbbaaaaa34567888 --section-start=.text=0x0000000012345678 -o %t/extreme13 # RUN: llvm-objdump -d --no-show-raw-insn %t/extreme13 | FileCheck %s --check-prefix=EXTREME13 # EXTREME13: pcalau12i $t1, 139811 # EXTREME13-NEXT: addi.d $t0, $zero, -1912 # EXTREME13-NEXT: lu32i.d $t0, -349527 # EXTREME13-NEXT: lu52i.d $t0, $t0, -1093 ## page delta = 0xbbbaaaab99999000, page offset = 0x111 ## %pc_lo12 = 0x111 = 273 ## %pc_hi20 = 0x99999 = -419431 ## %pc64_lo20 = 0xaaaab = -349525 ## %pc64_hi12 = 0xbbb = -1093 # RUN: ld.lld %t/extreme.o --section-start=.rodata=0xbbbaaaaaabcde111 --section-start=.text=0x0000000012345678 -o %t/extreme14 # RUN: llvm-objdump -d --no-show-raw-insn %t/extreme14 | FileCheck %s --check-prefix=EXTREME14 # EXTREME14: pcalau12i $t1, -419431 # EXTREME14-NEXT: addi.d $t0, $zero, 273 # EXTREME14-NEXT: lu32i.d $t0, -349525 # EXTREME14-NEXT: lu52i.d $t0, $t0, -1093 ## page delta = 0xbbbaaaaa9999a000, page offset = 0x888 ## %pc_lo12 = 0x888 = -1912 ## %pc_hi20 = 0x9999a = -419430 ## %pc64_lo20 = 0xaaaaa = -349526 ## %pc64_hi12 = 0xbbb = -1093 # RUN: ld.lld %t/extreme.o --section-start=.rodata=0xbbbaaaaaabcde888 --section-start=.text=0x0000000012345678 -o %t/extreme15 # RUN: llvm-objdump -d --no-show-raw-insn %t/extreme15 | FileCheck %s --check-prefix=EXTREME15 # EXTREME15: pcalau12i $t1, -419430 # EXTREME15-NEXT: addi.d $t0, $zero, -1912 # EXTREME15-NEXT: lu32i.d $t0, -349526 # EXTREME15-NEXT: lu52i.d $t0, $t0, -1093 ## page delta = 0xffffffff00000000, page offset = 0x888 ## %pc_lo12 = 0x888 = -1912 ## %pc_hi20 = 0x00000 = 0 ## %pc64_lo20 = 0xfffff = -1 ## %pc64_hi12 = 0xfff = -1 # RUN: ld.lld %t/extreme.o --section-start=.rodata=0x0000000012344888 --section-start=.text=0x0000000012345678 -o %t/extreme16 # RUN: llvm-objdump -d --no-show-raw-insn %t/extreme16 | FileCheck %s --check-prefix=EXTREME16 # EXTREME16: pcalau12i $t1, 0 # EXTREME16-NEXT: addi.d $t0, $zero, -1912 # EXTREME16-NEXT: lu32i.d $t0, -1 # EXTREME16-NEXT: lu52i.d $t0, $t0, -1 ## page delta = 0x0000000080000000, page offset = 0x888 ## %pc_lo12 = 0x888 = -1912 ## %pc_hi20 = 0x80000 = -524288 ## %pc64_lo20 = 0xfffff = 0 ## %pc64_hi12 = 0xfff = 0 # RUN: ld.lld %t/extreme.o --section-start=.rodata=0x000071238ffff888 --section-start=.text=0x0000712310000678 -o %t/extreme17 # RUN: llvm-objdump -d --no-show-raw-insn %t/extreme17 | FileCheck %s --check-prefix=EXTREME17 # EXTREME17: pcalau12i $t1, -524288 # EXTREME17-NEXT: addi.d $t0, $zero, -1912 # EXTREME17-NEXT: lu32i.d $t0, 0 # EXTREME17-NEXT: lu52i.d $t0, $t0, 0 ## A case that pcalau12i, lu32i.d and lu52i.d are in different pages. ## page delta = 0x0000000080000000, page offset = 0x123 ## %pc_lo12 = 0x111 = 273 ## %pc_hi20 = 0x80000 = -524288 ## %pc64_lo20 = 0x00001 = 1 ## %pc64_hi12 = 0x000 = 0 # RUN: ld.lld %t/extreme.o --section-start=.rodata=0x80000111 --section-start=.text=0xff8 -o %t/extreme18 # RUN: llvm-objdump -d --no-show-raw-insn %t/extreme18 | FileCheck %s --check-prefix=EXTREME18 # EXTREME18: pcalau12i $t1, -524288 # EXTREME18-NEXT: addi.d $t0, $zero, 273 # EXTREME18-NEXT: lu32i.d $t0, 1 # EXTREME18-NEXT: lu52i.d $t0, $t0, 0 #--- a.s .rodata x: .word 10 .text .global _start _start: pcalau12i $a0, %pc_hi20(x) ld.w $a0, $a0, %pc_lo12(x) #--- extreme.s .rodata x: .word 10 .text .global _start _start: pcalau12i $t1, %pc_hi20(x) addi.d $t0, $zero, %pc_lo12(x) lu32i.d $t0, %pc64_lo20(x) lu52i.d $t0, $t0, %pc64_hi12(x)