llvm/lld/test/ELF/riscv-relax-call2.s

# REQUIRES: riscv
# RUN: rm -rf %t && split-file %s %t && cd %t
# RUN: llvm-mc -filetype=obj -triple=riscv64 -mattr=+c,+relax a.s -o a.o

# RUN: ld.lld -T lds a.o -o a
# RUN: llvm-objdump -d --no-show-raw-insn -M no-aliases a | FileCheck %s

## Unsure whether this needs a diagnostic. GNU ld allows this.
# RUN: ld.lld -T lds -pie a.o -o a.pie
# RUN: llvm-objdump -d --no-show-raw-insn -M no-aliases a.pie | FileCheck %s

# RUN: ld.lld -T lds -pie -z notext -z ifunc-noplt a.o -o a.ifunc-noplt
# RUN: llvm-objdump -d --no-show-raw-insn -M no-aliases a.ifunc-noplt | FileCheck %s --check-prefix=CHECK2

# CHECK-LABEL:  <_start>:
# CHECK-NEXT:             jal    zero, 0x8 <abs>
# CHECK-NEXT:             jal    zero, 0x8 <abs>
# CHECK-NEXT:             jal    ra, 0x8 <abs>
# CHECK-NEXT:             auipc  t1, 0xfff00
# CHECK-NEXT:             jalr   zero, -0x4(t1)
# CHECK-EMPTY:

# CHECK-LABEL:  <.mid>:
# CHECK-NEXT:             jal    zero, 0x101000
# CHECK-NEXT:             c.j    0x101000
# CHECK-EMPTY:

# CHECK2-LABEL: <.mid>:
# CHECK2-NEXT:            auipc  t1, 0x0
# CHECK2-NEXT:            jalr   zero, 0x0(t1)
# CHECK2-NEXT:            auipc  t1, 0x0
# CHECK2-NEXT:            jalr   zero, 0x0(t1)
# CHECK2-EMPTY:

#--- a.s
.global _start, ifunc
_start:
  jump abs, t2
  jump abs, t3
  call abs
  tail abs       # not relaxed

.section .mid,"ax",@progbits
.balign 16
  tail ifunc@plt # not relaxed
  tail ifunc@plt

.type ifunc, @gnu_indirect_function
ifunc:
  ret

#--- lds
SECTIONS {
  .text 0x100000 : { *(.text) }
  .mid 0x100800 : { *(.mid) }
  .iplt 0x101000 : { *(.iplt) }
}
abs = 8;