
Fix https://github.com/llvm/llvm-project/issues/63579 ``` % cat a.c void foo() {} % clang --target=arm-none-eabi -mthumb -mno-unaligned-access -fsanitize=kcfi a.c -S -o - | grep p2align .p2align 1 % clang --target=armv6m-none-eabi -fsanitize=function a.c -S -o - | grep p2align .p2align 1 ``` Ensure that -fsanitize={function,kcfi} instrumented functions are aligned by at least 4, so that loading the type hash before the function label will not cause a misaligned access. This is especially important for -mno-unaligned-access configurations that don't set `setMinFunctionAlignment` to 4 or greater. With this patch, the generated assembly for the examples above will contain `.p2align 2` before the type hash. If `__attribute__((aligned(N)))` or `-falign-functions=N` is specified, the larger alignment will be used. Reviewed By: simon_tatham, samitolvanen Differential Revision: https://reviews.llvm.org/D154125
59 lines
1.6 KiB
LLVM
59 lines
1.6 KiB
LLVM
; 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}
|