diff options
| author | KP Singh <[email protected]> | 2020-03-29 00:43:53 +0000 |
|---|---|---|
| committer | Daniel Borkmann <[email protected]> | 2020-03-29 23:34:00 +0000 |
| commit | 520b7aa00d8cd8e411ecc09f63a2acd90feb6d29 (patch) | |
| tree | 226910e9b7b3b6778dbe962e611b4c6059601b7b /security/bpf/hooks.c | |
| parent | bpf: lsm: Implement attach, detach and execution (diff) | |
| download | kernel-520b7aa00d8cd8e411ecc09f63a2acd90feb6d29.tar.gz kernel-520b7aa00d8cd8e411ecc09f63a2acd90feb6d29.zip | |
bpf: lsm: Initialize the BPF LSM hooks
* The hooks are initialized using the definitions in
include/linux/lsm_hook_defs.h.
* The LSM can be enabled / disabled with CONFIG_BPF_LSM.
Signed-off-by: KP Singh <[email protected]>
Signed-off-by: Daniel Borkmann <[email protected]>
Reviewed-by: Brendan Jackman <[email protected]>
Reviewed-by: Florent Revest <[email protected]>
Acked-by: Kees Cook <[email protected]>
Acked-by: James Morris <[email protected]>
Link: https://lore.kernel.org/bpf/[email protected]
Diffstat (limited to 'security/bpf/hooks.c')
| -rw-r--r-- | security/bpf/hooks.c | 26 |
1 files changed, 26 insertions, 0 deletions
diff --git a/security/bpf/hooks.c b/security/bpf/hooks.c new file mode 100644 index 000000000000..32d32d485451 --- /dev/null +++ b/security/bpf/hooks.c @@ -0,0 +1,26 @@ +// SPDX-License-Identifier: GPL-2.0 + +/* + * Copyright (C) 2020 Google LLC. + */ +#include <linux/lsm_hooks.h> +#include <linux/bpf_lsm.h> + +static struct security_hook_list bpf_lsm_hooks[] __lsm_ro_after_init = { + #define LSM_HOOK(RET, DEFAULT, NAME, ...) \ + LSM_HOOK_INIT(NAME, bpf_lsm_##NAME), + #include <linux/lsm_hook_defs.h> + #undef LSM_HOOK +}; + +static int __init bpf_lsm_init(void) +{ + security_add_hooks(bpf_lsm_hooks, ARRAY_SIZE(bpf_lsm_hooks), "bpf"); + pr_info("LSM support for eBPF active\n"); + return 0; +} + +DEFINE_LSM(bpf) = { + .name = "bpf", + .init = bpf_lsm_init, +}; |
