Loading...
1/* SPDX-License-Identifier: GPL-2.0 */
2#ifndef __LKDTM_H
3#define __LKDTM_H
4
5#define pr_fmt(fmt) "lkdtm: " fmt
6
7#include <linux/kernel.h>
8
9extern char *lkdtm_kernel_info;
10
11#define pr_expected_config(kconfig) \
12do { \
13 if (IS_ENABLED(kconfig)) \
14 pr_err("Unexpected! This %s was built with " #kconfig "=y\n", \
15 lkdtm_kernel_info); \
16 else \
17 pr_warn("This is probably expected, since this %s was built *without* " #kconfig "=y\n", \
18 lkdtm_kernel_info); \
19} while (0)
20
21#ifndef MODULE
22int lkdtm_check_bool_cmdline(const char *param);
23#define pr_expected_config_param(kconfig, param) \
24do { \
25 if (IS_ENABLED(kconfig)) { \
26 switch (lkdtm_check_bool_cmdline(param)) { \
27 case 0: \
28 pr_warn("This is probably expected, since this %s was built with " #kconfig "=y but booted with '" param "=N'\n", \
29 lkdtm_kernel_info); \
30 break; \
31 case 1: \
32 pr_err("Unexpected! This %s was built with " #kconfig "=y and booted with '" param "=Y'\n", \
33 lkdtm_kernel_info); \
34 break; \
35 default: \
36 pr_err("Unexpected! This %s was built with " #kconfig "=y (and booted without '" param "' specified)\n", \
37 lkdtm_kernel_info); \
38 } \
39 } else { \
40 switch (lkdtm_check_bool_cmdline(param)) { \
41 case 0: \
42 pr_warn("This is probably expected, as this %s was built *without* " #kconfig "=y and booted with '" param "=N'\n", \
43 lkdtm_kernel_info); \
44 break; \
45 case 1: \
46 pr_err("Unexpected! This %s was built *without* " #kconfig "=y but booted with '" param "=Y'\n", \
47 lkdtm_kernel_info); \
48 break; \
49 default: \
50 pr_err("This is probably expected, since this %s was built *without* " #kconfig "=y (and booted without '" param "' specified)\n", \
51 lkdtm_kernel_info); \
52 break; \
53 } \
54 } \
55} while (0)
56#else
57#define pr_expected_config_param(kconfig, param) pr_expected_config(kconfig)
58#endif
59
60/* Crash types. */
61struct crashtype {
62 const char *name;
63 void (*func)(void);
64};
65
66#define CRASHTYPE(_name) \
67 { \
68 .name = __stringify(_name), \
69 .func = lkdtm_ ## _name, \
70 }
71
72/* Category's collection of crashtypes. */
73struct crashtype_category {
74 struct crashtype *crashtypes;
75 size_t len;
76};
77
78/* Each category's crashtypes list. */
79extern struct crashtype_category bugs_crashtypes;
80extern struct crashtype_category heap_crashtypes;
81extern struct crashtype_category perms_crashtypes;
82extern struct crashtype_category refcount_crashtypes;
83extern struct crashtype_category usercopy_crashtypes;
84extern struct crashtype_category stackleak_crashtypes;
85extern struct crashtype_category cfi_crashtypes;
86extern struct crashtype_category fortify_crashtypes;
87extern struct crashtype_category powerpc_crashtypes;
88
89/* Each category's init/exit routines. */
90void __init lkdtm_bugs_init(int *recur_param);
91void __init lkdtm_heap_init(void);
92void __exit lkdtm_heap_exit(void);
93void __init lkdtm_perms_init(void);
94void __init lkdtm_usercopy_init(void);
95void __exit lkdtm_usercopy_exit(void);
96
97/* Special declaration for function-in-rodata. */
98void lkdtm_rodata_do_nothing(void);
99
100#endif
1/* SPDX-License-Identifier: GPL-2.0 */
2#ifndef __LKDTM_H
3#define __LKDTM_H
4
5#define pr_fmt(fmt) "lkdtm: " fmt
6
7#include <linux/kernel.h>
8
9/* lkdtm_bugs.c */
10void __init lkdtm_bugs_init(int *recur_param);
11void lkdtm_PANIC(void);
12void lkdtm_BUG(void);
13void lkdtm_WARNING(void);
14void lkdtm_WARNING_MESSAGE(void);
15void lkdtm_EXCEPTION(void);
16void lkdtm_LOOP(void);
17void lkdtm_EXHAUST_STACK(void);
18void lkdtm_CORRUPT_STACK(void);
19void lkdtm_CORRUPT_STACK_STRONG(void);
20void lkdtm_UNALIGNED_LOAD_STORE_WRITE(void);
21void lkdtm_SOFTLOCKUP(void);
22void lkdtm_HARDLOCKUP(void);
23void lkdtm_SPINLOCKUP(void);
24void lkdtm_HUNG_TASK(void);
25void lkdtm_OVERFLOW_SIGNED(void);
26void lkdtm_OVERFLOW_UNSIGNED(void);
27void lkdtm_ARRAY_BOUNDS(void);
28void lkdtm_CORRUPT_LIST_ADD(void);
29void lkdtm_CORRUPT_LIST_DEL(void);
30void lkdtm_CORRUPT_USER_DS(void);
31void lkdtm_STACK_GUARD_PAGE_LEADING(void);
32void lkdtm_STACK_GUARD_PAGE_TRAILING(void);
33void lkdtm_UNSET_SMEP(void);
34void lkdtm_DOUBLE_FAULT(void);
35void lkdtm_CORRUPT_PAC(void);
36
37/* lkdtm_heap.c */
38void __init lkdtm_heap_init(void);
39void __exit lkdtm_heap_exit(void);
40void lkdtm_OVERWRITE_ALLOCATION(void);
41void lkdtm_WRITE_AFTER_FREE(void);
42void lkdtm_READ_AFTER_FREE(void);
43void lkdtm_WRITE_BUDDY_AFTER_FREE(void);
44void lkdtm_READ_BUDDY_AFTER_FREE(void);
45void lkdtm_SLAB_FREE_DOUBLE(void);
46void lkdtm_SLAB_FREE_CROSS(void);
47void lkdtm_SLAB_FREE_PAGE(void);
48
49/* lkdtm_perms.c */
50void __init lkdtm_perms_init(void);
51void lkdtm_WRITE_RO(void);
52void lkdtm_WRITE_RO_AFTER_INIT(void);
53void lkdtm_WRITE_KERN(void);
54void lkdtm_EXEC_DATA(void);
55void lkdtm_EXEC_STACK(void);
56void lkdtm_EXEC_KMALLOC(void);
57void lkdtm_EXEC_VMALLOC(void);
58void lkdtm_EXEC_RODATA(void);
59void lkdtm_EXEC_USERSPACE(void);
60void lkdtm_EXEC_NULL(void);
61void lkdtm_ACCESS_USERSPACE(void);
62void lkdtm_ACCESS_NULL(void);
63
64/* lkdtm_refcount.c */
65void lkdtm_REFCOUNT_INC_OVERFLOW(void);
66void lkdtm_REFCOUNT_ADD_OVERFLOW(void);
67void lkdtm_REFCOUNT_INC_NOT_ZERO_OVERFLOW(void);
68void lkdtm_REFCOUNT_ADD_NOT_ZERO_OVERFLOW(void);
69void lkdtm_REFCOUNT_DEC_ZERO(void);
70void lkdtm_REFCOUNT_DEC_NEGATIVE(void);
71void lkdtm_REFCOUNT_DEC_AND_TEST_NEGATIVE(void);
72void lkdtm_REFCOUNT_SUB_AND_TEST_NEGATIVE(void);
73void lkdtm_REFCOUNT_INC_ZERO(void);
74void lkdtm_REFCOUNT_ADD_ZERO(void);
75void lkdtm_REFCOUNT_INC_SATURATED(void);
76void lkdtm_REFCOUNT_DEC_SATURATED(void);
77void lkdtm_REFCOUNT_ADD_SATURATED(void);
78void lkdtm_REFCOUNT_INC_NOT_ZERO_SATURATED(void);
79void lkdtm_REFCOUNT_ADD_NOT_ZERO_SATURATED(void);
80void lkdtm_REFCOUNT_DEC_AND_TEST_SATURATED(void);
81void lkdtm_REFCOUNT_SUB_AND_TEST_SATURATED(void);
82void lkdtm_REFCOUNT_TIMING(void);
83void lkdtm_ATOMIC_TIMING(void);
84
85/* lkdtm_rodata.c */
86void lkdtm_rodata_do_nothing(void);
87
88/* lkdtm_usercopy.c */
89void __init lkdtm_usercopy_init(void);
90void __exit lkdtm_usercopy_exit(void);
91void lkdtm_USERCOPY_HEAP_SIZE_TO(void);
92void lkdtm_USERCOPY_HEAP_SIZE_FROM(void);
93void lkdtm_USERCOPY_HEAP_WHITELIST_TO(void);
94void lkdtm_USERCOPY_HEAP_WHITELIST_FROM(void);
95void lkdtm_USERCOPY_STACK_FRAME_TO(void);
96void lkdtm_USERCOPY_STACK_FRAME_FROM(void);
97void lkdtm_USERCOPY_STACK_BEYOND(void);
98void lkdtm_USERCOPY_KERNEL(void);
99void lkdtm_USERCOPY_KERNEL_DS(void);
100
101/* lkdtm_stackleak.c */
102void lkdtm_STACKLEAK_ERASING(void);
103
104/* cfi.c */
105void lkdtm_CFI_FORWARD_PROTO(void);
106
107#endif