提交 d117a154 编写于 作者: K Kees Cook

capability: Initialize as LSM_ORDER_FIRST

This converts capabilities to use the new LSM_ORDER_FIRST position.
Signed-off-by: NKees Cook <keescook@chromium.org>
Reviewed-by: NCasey Schaufler <casey@schaufler-ca.com>
上级 e2bc445b
...@@ -2095,6 +2095,4 @@ static inline void security_delete_hooks(struct security_hook_list *hooks, ...@@ -2095,6 +2095,4 @@ static inline void security_delete_hooks(struct security_hook_list *hooks,
#define __lsm_ro_after_init __ro_after_init #define __lsm_ro_after_init __ro_after_init
#endif /* CONFIG_SECURITY_WRITABLE_HOOKS */ #endif /* CONFIG_SECURITY_WRITABLE_HOOKS */
extern void __init capability_add_hooks(void);
#endif /* ! __LINUX_LSM_HOOKS_H */ #endif /* ! __LINUX_LSM_HOOKS_H */
...@@ -1362,10 +1362,17 @@ struct security_hook_list capability_hooks[] __lsm_ro_after_init = { ...@@ -1362,10 +1362,17 @@ struct security_hook_list capability_hooks[] __lsm_ro_after_init = {
LSM_HOOK_INIT(vm_enough_memory, cap_vm_enough_memory), LSM_HOOK_INIT(vm_enough_memory, cap_vm_enough_memory),
}; };
void __init capability_add_hooks(void) static int __init capability_init(void)
{ {
security_add_hooks(capability_hooks, ARRAY_SIZE(capability_hooks), security_add_hooks(capability_hooks, ARRAY_SIZE(capability_hooks),
"capability"); "capability");
return 0;
} }
DEFINE_LSM(capability) = {
.name = "capability",
.order = LSM_ORDER_FIRST,
.init = capability_init,
};
#endif /* CONFIG_SECURITY */ #endif /* CONFIG_SECURITY */
...@@ -277,11 +277,6 @@ int __init security_init(void) ...@@ -277,11 +277,6 @@ int __init security_init(void)
i++) i++)
INIT_HLIST_HEAD(&list[i]); INIT_HLIST_HEAD(&list[i]);
/*
* Load minor LSMs, with the capability module always first.
*/
capability_add_hooks();
/* Load LSMs in specified order. */ /* Load LSMs in specified order. */
ordered_lsm_init(); ordered_lsm_init();
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册