; RUN: llc -mtriple=riscv64 -verify-machineinstrs < %s | FileCheck %s --check-prefixes=CHECK,NOC ; RUN: llc -mtriple=riscv64 -mattr=+c -verify-machineinstrs < %s | FileCheck %s --check-prefixes=CHECK,C ;; The alignment is at least 4 to avoid unaligned type hash loads when this ;; instrumented function is indirectly called. ; CHECK-LABEL: .globl f1 ; CHECK: .p2align 2 ; CHECK-NOT: nop ; CHECK: .word 12345678 ; CHECK-LABEL: f1: define void @f1(ptr noundef %x) !kcfi_type !1 { ; CHECK: lw t1, -4(a0) call void %x() [ "kcfi"(i32 12345678) ] ret void } ; CHECK-LABEL: .globl f2 ; NOC: .p2align 2 ; C: .p2align 1 ; CHECK-NOT: .word ; CHECK-NOT: nop ; CHECK-LABEL: f2: define void @f2(ptr noundef %x) { ; CHECK: lw t1, -4(a0) call void %x() [ "kcfi"(i32 12345678) ] ret void } ; CHECK-LABEL: .globl f3 ; CHECK: .p2align 2 ; CHECK: .word 12345678 ; CHECK-COUNT-11: nop ; CHECK-LABEL: f3: define void @f3(ptr noundef %x) #0 !kcfi_type !1 { ; NOC: lw t1, -48(a0) ; C: lw t1, -26(a0) call void %x() [ "kcfi"(i32 12345678) ] ret void } ; CHECK-LABEL: .globl f4 ; NOC: .p2align 2 ; C: .p2align 1 ; CHECK-NOT: .word ; CHECK-COUNT-11: nop ; CHECK-LABEL: f4: define void @f4(ptr noundef %x) #0 { ; NOC: lw t1, -48(a0) ; C: lw t1, -26(a0) call void %x() [ "kcfi"(i32 12345678) ] ret void } attributes #0 = { "patchable-function-prefix"="11" } !llvm.module.flags = !{!0} !0 = !{i32 4, !"kcfi", i32 1} !1 = !{i32 12345678}