llvm/llvm/test/CodeGen/RISCV/kcfi.ll

; RUN: llc -mtriple=riscv32 -verify-machineinstrs -riscv-no-aliases < %s \
; RUN:      | FileCheck %s --check-prefixes=CHECK,RV32
; RUN: llc -mtriple=riscv64 -verify-machineinstrs -riscv-no-aliases < %s \
; RUN:      | FileCheck %s --check-prefixes=CHECK,RV64

; CHECK:       .word 12345678
define void @f1(ptr noundef %x) !kcfi_type !1 {
; CHECK-LABEL: f1:
; CHECK:       # %bb.0:
; CHECK:         lw t1, -4(a0)
; CHECK-NEXT:    lui t2, 3014
; RV32-NEXT:     addi t2, t2, 334
; RV64-NEXT:     addiw t2, t2, 334
; CHECK-NEXT:    beq t1, t2, .Ltmp0
; CHECK-NEXT:  .Ltmp1:
; CHECK-NEXT:    ebreak
; CHECK-NEXT:    .section .kcfi_traps,"ao",@progbits,.text
; CHECK-NEXT:  .Ltmp2:
; CHECK-NEXT:    .word .Ltmp1-.Ltmp2
; CHECK-NEXT:    .text
; CHECK-NEXT:  .Ltmp0:
; CHECK-NEXT:    jalr ra, 0(a0)
  call void %x() [ "kcfi"(i32 12345678) ]
; CHECK:         lw t1, -4(s0)
; CHECK-NEXT:    addi t2, t2, 1234
; CHECK-NEXT:    beq t1, t2, .Ltmp3
; CHECK-NEXT:  .Ltmp4:
; CHECK-NEXT:    ebreak
; CHECK-NEXT:    .section .kcfi_traps,"ao",@progbits,.text
; CHECK-NEXT:  .Ltmp5:
; CHECK-NEXT:    .word .Ltmp4-.Ltmp5
; CHECK-NEXT:    .text
; CHECK-NEXT:  .Ltmp3:
; CHECK-NEXT:    jalr ra, 0(s0)
  call void %x() [ "kcfi"(i32 1234) ]
  ret void
}

; CHECK-NOT:   .word:
define void @f2(ptr noundef %x) #0 {
; CHECK-LABEL: f2:
; CHECK:       # %bb.0:
; CHECK-NEXT:    addi zero, zero, 0
; CHECK-NEXT:    addi zero, zero, 0
; CHECK-NEXT:    lw t1, -4(a0)
; CHECK-NEXT:    lui t2, 3014
; RV32-NEXT:     addi t2, t2, 334
; RV64-NEXT:     addiw t2, t2, 334
; CHECK-NEXT:    beq t1, t2, .Ltmp6
; CHECK-NEXT:  .Ltmp7:
; CHECK-NEXT:    ebreak
; CHECK-NEXT:    .section .kcfi_traps,"ao",@progbits,.text
; CHECK-NEXT:  .Ltmp8:
; CHECK-NEXT:    .word .Ltmp7-.Ltmp8
; CHECK-NEXT:    .text
; CHECK-NEXT:  .Ltmp6:
; CHECK-NEXT:    jalr zero, 0(a0)
  tail call void %x() [ "kcfi"(i32 12345678) ]
  ret void
}

attributes #0 = { "patchable-function-entry"="2" }

!llvm.module.flags = !{!0}
!0 = !{i32 4, !"kcfi", i32 1}
!1 = !{i32 12345678}