xref: /llvm-project/llvm/test/CodeGen/RISCV/kcfi-patchable-function-prefix.ll (revision afd20587f9952654a9a9ec427052220b5e3a6982)
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