| 1 | /* SPDX-License-Identifier: GPL-2.0 */ | 
|---|
| 2 | /* | 
|---|
| 3 | * Clang Control Flow Integrity (CFI) type definitions. | 
|---|
| 4 | */ | 
|---|
| 5 | #ifndef _LINUX_CFI_TYPES_H | 
|---|
| 6 | #define _LINUX_CFI_TYPES_H | 
|---|
| 7 |  | 
|---|
| 8 | #ifdef __ASSEMBLY__ | 
|---|
| 9 | #include <linux/linkage.h> | 
|---|
| 10 |  | 
|---|
| 11 | #ifdef CONFIG_CFI | 
|---|
| 12 | /* | 
|---|
| 13 | * Use the __kcfi_typeid_<function> type identifier symbol to | 
|---|
| 14 | * annotate indirectly called assembly functions. The compiler emits | 
|---|
| 15 | * these symbols for all address-taken function declarations in C | 
|---|
| 16 | * code. | 
|---|
| 17 | */ | 
|---|
| 18 | #ifndef __CFI_TYPE | 
|---|
| 19 | #define __CFI_TYPE(name)				\ | 
|---|
| 20 | .4byte __kcfi_typeid_##name | 
|---|
| 21 | #endif | 
|---|
| 22 |  | 
|---|
| 23 | #define SYM_TYPED_ENTRY(name, linkage, align...)	\ | 
|---|
| 24 | linkage(name) ASM_NL				\ | 
|---|
| 25 | align ASM_NL					\ | 
|---|
| 26 | __CFI_TYPE(name) ASM_NL				\ | 
|---|
| 27 | name: | 
|---|
| 28 |  | 
|---|
| 29 | #define SYM_TYPED_START(name, linkage, align...)	\ | 
|---|
| 30 | SYM_TYPED_ENTRY(name, linkage, align) | 
|---|
| 31 |  | 
|---|
| 32 | #else /* CONFIG_CFI */ | 
|---|
| 33 |  | 
|---|
| 34 | #define SYM_TYPED_START(name, linkage, align...)	\ | 
|---|
| 35 | SYM_START(name, linkage, align) | 
|---|
| 36 |  | 
|---|
| 37 | #endif /* CONFIG_CFI */ | 
|---|
| 38 |  | 
|---|
| 39 | #ifndef SYM_TYPED_FUNC_START | 
|---|
| 40 | #define SYM_TYPED_FUNC_START(name) 			\ | 
|---|
| 41 | SYM_TYPED_START(name, SYM_L_GLOBAL, SYM_A_ALIGN) | 
|---|
| 42 | #endif | 
|---|
| 43 |  | 
|---|
| 44 | #else /* __ASSEMBLY__ */ | 
|---|
| 45 |  | 
|---|
| 46 | #ifdef CONFIG_CFI | 
|---|
| 47 | #define DEFINE_CFI_TYPE(name, func)						\ | 
|---|
| 48 | /*									\ | 
|---|
| 49 | * Force a reference to the function so the compiler generates		\ | 
|---|
| 50 | * __kcfi_typeid_<func>.						\ | 
|---|
| 51 | */									\ | 
|---|
| 52 | __ADDRESSABLE(func);							\ | 
|---|
| 53 | /* u32 name __ro_after_init = __kcfi_typeid_<func> */			\ | 
|---|
| 54 | extern u32 name;							\ | 
|---|
| 55 | asm (									\ | 
|---|
| 56 | "	.pushsection	.data..ro_after_init,\"aw\",\%progbits	\n"	\ | 
|---|
| 57 | "	.type	" #name ",\%object				\n"	\ | 
|---|
| 58 | "	.globl	" #name "					\n"	\ | 
|---|
| 59 | "	.p2align	2, 0x0					\n"	\ | 
|---|
| 60 | #name ":							\n"	\ | 
|---|
| 61 | "	.4byte	__kcfi_typeid_" #func "				\n"	\ | 
|---|
| 62 | "	.size	" #name ", 4					\n"	\ | 
|---|
| 63 | "	.popsection						\n"	\ | 
|---|
| 64 | ); | 
|---|
| 65 | #endif | 
|---|
| 66 |  | 
|---|
| 67 | #endif /* __ASSEMBLY__ */ | 
|---|
| 68 | #endif /* _LINUX_CFI_TYPES_H */ | 
|---|
| 69 |  | 
|---|