blob: 38209c7361b65b9549bff0ea93bf9c45cc29db45 [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 Mladek7e35e4e2019-10-30 16:43:09 +010016void klp_free_patch_async(struct klp_patch *patch);
17void klp_free_replaced_patches_async(struct klp_patch *new_patch);
18void klp_unpatch_replaced_patches(struct klp_patch *new_patch);
Petr Mladekd697bad2019-01-09 13:43:26 +010019void klp_discard_nops(struct klp_patch *new_patch);
Petr Mladek958ef1e2019-01-09 13:43:23 +010020
Joe Lawrence93862e32017-10-13 15:08:41 -040021static inline bool klp_is_object_loaded(struct klp_object *obj)
22{
23 return !obj->name || obj->mod;
24}
25
26static inline int klp_pre_patch_callback(struct klp_object *obj)
27{
Petr Mladek5aaf1ab2017-10-20 16:56:50 +020028 int ret = 0;
Joe Lawrence93862e32017-10-13 15:08:41 -040029
Petr Mladek5aaf1ab2017-10-20 16:56:50 +020030 if (obj->callbacks.pre_patch)
31 ret = (*obj->callbacks.pre_patch)(obj);
Joe Lawrence93862e32017-10-13 15:08:41 -040032
33 obj->callbacks.post_unpatch_enabled = !ret;
34
35 return ret;
36}
37
38static inline void klp_post_patch_callback(struct klp_object *obj)
39{
40 if (obj->callbacks.post_patch)
41 (*obj->callbacks.post_patch)(obj);
42}
43
44static inline void klp_pre_unpatch_callback(struct klp_object *obj)
45{
46 if (obj->callbacks.pre_unpatch)
47 (*obj->callbacks.pre_unpatch)(obj);
48}
49
50static inline void klp_post_unpatch_callback(struct klp_object *obj)
51{
52 if (obj->callbacks.post_unpatch_enabled &&
53 obj->callbacks.post_unpatch)
54 (*obj->callbacks.post_unpatch)(obj);
Petr Mladek5aaf1ab2017-10-20 16:56:50 +020055
56 obj->callbacks.post_unpatch_enabled = false;
Joe Lawrence93862e32017-10-13 15:08:41 -040057}
58
Jiri Kosina10517422017-03-08 14:27:05 +010059#endif /* _LIVEPATCH_CORE_H */