blob: ec43a40b853fc6c478b0280c030ca37944becdf2 [file] [log] [blame]
Greg Kroah-Hartmanb2441312017-11-01 15:07:57 +01001/* SPDX-License-Identifier: GPL-2.0 */
Jiri Kosina10517422017-03-08 14:27:05 +01002#ifndef _LIVEPATCH_CORE_H
3#define _LIVEPATCH_CORE_H
4
Joe Lawrence93862e32017-10-13 15:08:41 -04005#include <linux/livepatch.h>
6
Jiri Kosina10517422017-03-08 14:27:05 +01007extern struct mutex klp_mutex;
Petr Mladek68007282019-01-09 13:43:22 +01008extern struct list_head klp_patches;
Jiri Kosina10517422017-03-08 14:27:05 +01009
Petr Mladekecba29f2019-02-04 14:56:50 +010010#define klp_for_each_patch_safe(patch, tmp_patch) \
11 list_for_each_entry_safe(patch, tmp_patch, &klp_patches, list)
12
13#define klp_for_each_patch(patch) \
14 list_for_each_entry(patch, &klp_patches, list)
15
Petr Mladek958ef1e2019-01-09 13:43:23 +010016void klp_free_patch_start(struct klp_patch *patch);
Jason Barone1452b62019-01-09 13:43:25 +010017void klp_discard_replaced_patches(struct klp_patch *new_patch);
Petr Mladekd697bad2019-01-09 13:43:26 +010018void klp_discard_nops(struct klp_patch *new_patch);
Petr Mladek958ef1e2019-01-09 13:43:23 +010019
Joe Lawrence93862e32017-10-13 15:08:41 -040020static inline bool klp_is_object_loaded(struct klp_object *obj)
21{
22 return !obj->name || obj->mod;
23}
24
25static inline int klp_pre_patch_callback(struct klp_object *obj)
26{
Petr Mladek5aaf1ab2017-10-20 16:56:50 +020027 int ret = 0;
Joe Lawrence93862e32017-10-13 15:08:41 -040028
Petr Mladek5aaf1ab2017-10-20 16:56:50 +020029 if (obj->callbacks.pre_patch)
30 ret = (*obj->callbacks.pre_patch)(obj);
Joe Lawrence93862e32017-10-13 15:08:41 -040031
32 obj->callbacks.post_unpatch_enabled = !ret;
33
34 return ret;
35}
36
37static inline void klp_post_patch_callback(struct klp_object *obj)
38{
39 if (obj->callbacks.post_patch)
40 (*obj->callbacks.post_patch)(obj);
41}
42
43static inline void klp_pre_unpatch_callback(struct klp_object *obj)
44{
45 if (obj->callbacks.pre_unpatch)
46 (*obj->callbacks.pre_unpatch)(obj);
47}
48
49static inline void klp_post_unpatch_callback(struct klp_object *obj)
50{
51 if (obj->callbacks.post_unpatch_enabled &&
52 obj->callbacks.post_unpatch)
53 (*obj->callbacks.post_unpatch)(obj);
Petr Mladek5aaf1ab2017-10-20 16:56:50 +020054
55 obj->callbacks.post_unpatch_enabled = false;
Joe Lawrence93862e32017-10-13 15:08:41 -040056}
57
Jiri Kosina10517422017-03-08 14:27:05 +010058#endif /* _LIVEPATCH_CORE_H */