diff options
Diffstat (limited to 'kernel')
-rw-r--r-- | kernel/bpf/core.c | 3 | ||||
-rw-r--r-- | kernel/bpf/helpers.c | 24 |
2 files changed, 27 insertions, 0 deletions
diff --git a/kernel/bpf/core.c b/kernel/bpf/core.c index 50603aec766a..4139a0f8b558 100644 --- a/kernel/bpf/core.c +++ b/kernel/bpf/core.c | |||
@@ -661,6 +661,9 @@ const struct bpf_func_proto bpf_map_lookup_elem_proto __weak; | |||
661 | const struct bpf_func_proto bpf_map_update_elem_proto __weak; | 661 | const struct bpf_func_proto bpf_map_update_elem_proto __weak; |
662 | const struct bpf_func_proto bpf_map_delete_elem_proto __weak; | 662 | const struct bpf_func_proto bpf_map_delete_elem_proto __weak; |
663 | 663 | ||
664 | const struct bpf_func_proto bpf_get_prandom_u32_proto __weak; | ||
665 | const struct bpf_func_proto bpf_get_smp_processor_id_proto __weak; | ||
666 | |||
664 | /* To execute LD_ABS/LD_IND instructions __bpf_prog_run() may call | 667 | /* To execute LD_ABS/LD_IND instructions __bpf_prog_run() may call |
665 | * skb_copy_bits(), so provide a weak definition of it for NET-less config. | 668 | * skb_copy_bits(), so provide a weak definition of it for NET-less config. |
666 | */ | 669 | */ |
diff --git a/kernel/bpf/helpers.c b/kernel/bpf/helpers.c index a3c7701a8b5e..bd7f5988ed9c 100644 --- a/kernel/bpf/helpers.c +++ b/kernel/bpf/helpers.c | |||
@@ -11,6 +11,8 @@ | |||
11 | */ | 11 | */ |
12 | #include <linux/bpf.h> | 12 | #include <linux/bpf.h> |
13 | #include <linux/rcupdate.h> | 13 | #include <linux/rcupdate.h> |
14 | #include <linux/random.h> | ||
15 | #include <linux/smp.h> | ||
14 | 16 | ||
15 | /* If kernel subsystem is allowing eBPF programs to call this function, | 17 | /* If kernel subsystem is allowing eBPF programs to call this function, |
16 | * inside its own verifier_ops->get_func_proto() callback it should return | 18 | * inside its own verifier_ops->get_func_proto() callback it should return |
@@ -87,3 +89,25 @@ const struct bpf_func_proto bpf_map_delete_elem_proto = { | |||
87 | .arg1_type = ARG_CONST_MAP_PTR, | 89 | .arg1_type = ARG_CONST_MAP_PTR, |
88 | .arg2_type = ARG_PTR_TO_MAP_KEY, | 90 | .arg2_type = ARG_PTR_TO_MAP_KEY, |
89 | }; | 91 | }; |
92 | |||
93 | static u64 bpf_get_prandom_u32(u64 r1, u64 r2, u64 r3, u64 r4, u64 r5) | ||
94 | { | ||
95 | return prandom_u32(); | ||
96 | } | ||
97 | |||
98 | const struct bpf_func_proto bpf_get_prandom_u32_proto = { | ||
99 | .func = bpf_get_prandom_u32, | ||
100 | .gpl_only = false, | ||
101 | .ret_type = RET_INTEGER, | ||
102 | }; | ||
103 | |||
104 | static u64 bpf_get_smp_processor_id(u64 r1, u64 r2, u64 r3, u64 r4, u64 r5) | ||
105 | { | ||
106 | return raw_smp_processor_id(); | ||
107 | } | ||
108 | |||
109 | const struct bpf_func_proto bpf_get_smp_processor_id_proto = { | ||
110 | .func = bpf_get_smp_processor_id, | ||
111 | .gpl_only = false, | ||
112 | .ret_type = RET_INTEGER, | ||
113 | }; | ||