blob: d0cb5390e2476d525dde13f64ac92f963d94ea35 [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
Joe Lawrence93862e32017-10-13 15:08:41 -040010static inline bool klp_is_object_loaded(struct klp_object *obj)
11{
12 return !obj->name || obj->mod;
13}
14
15static inline int klp_pre_patch_callback(struct klp_object *obj)
16{
Petr Mladek5aaf1ab2017-10-20 16:56:50 +020017 int ret = 0;
Joe Lawrence93862e32017-10-13 15:08:41 -040018
Petr Mladek5aaf1ab2017-10-20 16:56:50 +020019 if (obj->callbacks.pre_patch)
20 ret = (*obj->callbacks.pre_patch)(obj);
Joe Lawrence93862e32017-10-13 15:08:41 -040021
22 obj->callbacks.post_unpatch_enabled = !ret;
23
24 return ret;
25}
26
27static inline void klp_post_patch_callback(struct klp_object *obj)
28{
29 if (obj->callbacks.post_patch)
30 (*obj->callbacks.post_patch)(obj);
31}
32
33static inline void klp_pre_unpatch_callback(struct klp_object *obj)
34{
35 if (obj->callbacks.pre_unpatch)
36 (*obj->callbacks.pre_unpatch)(obj);
37}
38
39static inline void klp_post_unpatch_callback(struct klp_object *obj)
40{
41 if (obj->callbacks.post_unpatch_enabled &&
42 obj->callbacks.post_unpatch)
43 (*obj->callbacks.post_unpatch)(obj);
Petr Mladek5aaf1ab2017-10-20 16:56:50 +020044
45 obj->callbacks.post_unpatch_enabled = false;
Joe Lawrence93862e32017-10-13 15:08:41 -040046}
47
Jiri Kosina10517422017-03-08 14:27:05 +010048#endif /* _LIVEPATCH_CORE_H */