/// Test that annotations are properly carried over to fixed calls.
/// Note that --enable-bat is used to force offsets to be kept.
// RUN: llvm-mc -triple riscv64 -mattr=+c -filetype obj -o %t.o %s
// RUN: ld.lld --emit-relocs -o %t %t.o
// RUN: llvm-bolt --enable-bat --print-cfg --print-fix-riscv-calls \
// RUN: -o %t.null %t | FileCheck %s
.text
.option norvc
.global f
.p2align 1
f:
ret
.size f, .-f
// CHECK-LABEL: Binary Function "_start" after building cfg {
// CHECK: auipc ra, f
// CHECK-NEXT: jalr ra, -0x4(ra) # Offset: 4
// CHECK-NEXT: jal ra, f # Offset: 8
// CHECK-NEXT: jal zero, f # TAILCALL # Offset: 12
// CHECK-LABEL: Binary Function "long_tail" after building cfg {
// CHECK: auipc t1, f
// CHECK-NEXT: jalr zero, -0x18(t1) # TAILCALL # Offset: 8
// CHECK-LABEL: Binary Function "compressed_tail" after building cfg {
// CHECK: jr a0 # TAILCALL # Offset: 0
// CHECK-LABEL: Binary Function "_start" after fix-riscv-calls {
// CHECK: call f # Offset: 0
// CHECK-NEXT: call f # Offset: 8
// CHECK-NEXT: tail f # TAILCALL # Offset: 12
// CHECK-LABEL: Binary Function "long_tail" after fix-riscv-calls {
// CHECK: tail f # TAILCALL # Offset: 4
// CHECK-LABEL: Binary Function "compressed_tail" after fix-riscv-calls {
// CHECK: jr a0 # TAILCALL # Offset: 0
.globl _start
.p2align 1
_start:
call f
jal f
jal zero, f
.size _start, .-_start
.globl long_tail
.p2align 1
long_tail:
// NOTE: BOLT assumes indirect calls in single-BB functions are tail calls
// so artificially introduce a second BB to force RISC-V-specific analysis
// to get triggered.
beq a0, a1, 1f
1:
tail f
.size long_tail, .-long_tail
.globl compressed_tail
.p2align 1
.option rvc
compressed_tail:
c.jr a0
.size compressed_tail, .-compressed_tail