183835e22SSami Tolvanen; RUN: llc -mtriple=riscv64 -verify-machineinstrs < %s | FileCheck %s --check-prefixes=CHECK,NOC 283835e22SSami Tolvanen; RUN: llc -mtriple=riscv64 -mattr=+c -verify-machineinstrs < %s | FileCheck %s --check-prefixes=CHECK,C 383835e22SSami Tolvanen 4*afd20587SFangrui Song;; The alignment is at least 4 to avoid unaligned type hash loads when this 5*afd20587SFangrui Song;; instrumented function is indirectly called. 6*afd20587SFangrui Song; CHECK-LABEL: .globl f1 7*afd20587SFangrui Song; CHECK: .p2align 2 883835e22SSami Tolvanen; CHECK-NOT: nop 983835e22SSami Tolvanen; CHECK: .word 12345678 1083835e22SSami Tolvanen; CHECK-LABEL: f1: 1183835e22SSami Tolvanendefine void @f1(ptr noundef %x) !kcfi_type !1 { 1283835e22SSami Tolvanen; CHECK: lw t1, -4(a0) 1383835e22SSami Tolvanen call void %x() [ "kcfi"(i32 12345678) ] 1483835e22SSami Tolvanen ret void 1583835e22SSami Tolvanen} 1683835e22SSami Tolvanen 17*afd20587SFangrui Song; CHECK-LABEL: .globl f2 1883835e22SSami Tolvanen; NOC: .p2align 2 1983835e22SSami Tolvanen; C: .p2align 1 2083835e22SSami Tolvanen; CHECK-NOT: .word 2183835e22SSami Tolvanen; CHECK-NOT: nop 2283835e22SSami Tolvanen; CHECK-LABEL: f2: 2383835e22SSami Tolvanendefine void @f2(ptr noundef %x) { 2483835e22SSami Tolvanen; CHECK: lw t1, -4(a0) 2583835e22SSami Tolvanen call void %x() [ "kcfi"(i32 12345678) ] 2683835e22SSami Tolvanen ret void 2783835e22SSami Tolvanen} 2883835e22SSami Tolvanen 29*afd20587SFangrui Song; CHECK-LABEL: .globl f3 30*afd20587SFangrui Song; CHECK: .p2align 2 3183835e22SSami Tolvanen; CHECK: .word 12345678 3283835e22SSami Tolvanen; CHECK-COUNT-11: nop 3383835e22SSami Tolvanen; CHECK-LABEL: f3: 3483835e22SSami Tolvanendefine void @f3(ptr noundef %x) #0 !kcfi_type !1 { 3583835e22SSami Tolvanen; NOC: lw t1, -48(a0) 3683835e22SSami Tolvanen; C: lw t1, -26(a0) 3783835e22SSami Tolvanen call void %x() [ "kcfi"(i32 12345678) ] 3883835e22SSami Tolvanen ret void 3983835e22SSami Tolvanen} 4083835e22SSami Tolvanen 41*afd20587SFangrui Song; CHECK-LABEL: .globl f4 4283835e22SSami Tolvanen; NOC: .p2align 2 4383835e22SSami Tolvanen; C: .p2align 1 4483835e22SSami Tolvanen; CHECK-NOT: .word 4583835e22SSami Tolvanen; CHECK-COUNT-11: nop 4683835e22SSami Tolvanen; CHECK-LABEL: f4: 4783835e22SSami Tolvanendefine void @f4(ptr noundef %x) #0 { 4883835e22SSami Tolvanen; NOC: lw t1, -48(a0) 4983835e22SSami Tolvanen; C: lw t1, -26(a0) 5083835e22SSami Tolvanen call void %x() [ "kcfi"(i32 12345678) ] 5183835e22SSami Tolvanen ret void 5283835e22SSami Tolvanen} 5383835e22SSami Tolvanen 5483835e22SSami Tolvanenattributes #0 = { "patchable-function-prefix"="11" } 5583835e22SSami Tolvanen 5683835e22SSami Tolvanen!llvm.module.flags = !{!0} 5783835e22SSami Tolvanen!0 = !{i32 4, !"kcfi", i32 1} 5883835e22SSami Tolvanen!1 = !{i32 12345678} 59