diff options
author | Alexei Starovoitov <ast@fb.com> | 2016-03-08 18:07:53 -0500 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2016-03-08 23:22:02 -0500 |
commit | 7dcc42b685b4acf7b2f3f08d157f1574e1bec7f7 (patch) | |
tree | 7893ae0c100e957d8a172551c2d07c8e1eba48ac /samples/bpf | |
parent | 9d8b612d88e81c2cf7dbc0d4a827da6ca0d848e0 (diff) |
samples/bpf: stress test bpf_get_stackid
increase stress by also calling bpf_get_stackid() from
various *spin* functions
Signed-off-by: Alexei Starovoitov <ast@kernel.org>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'samples/bpf')
-rw-r--r-- | samples/bpf/spintest_kern.c | 9 |
1 files changed, 9 insertions, 0 deletions
diff --git a/samples/bpf/spintest_kern.c b/samples/bpf/spintest_kern.c index ef8ac33bb2e9..4b27619d91a4 100644 --- a/samples/bpf/spintest_kern.c +++ b/samples/bpf/spintest_kern.c | |||
@@ -8,6 +8,7 @@ | |||
8 | #include <linux/netdevice.h> | 8 | #include <linux/netdevice.h> |
9 | #include <linux/version.h> | 9 | #include <linux/version.h> |
10 | #include <uapi/linux/bpf.h> | 10 | #include <uapi/linux/bpf.h> |
11 | #include <uapi/linux/perf_event.h> | ||
11 | #include "bpf_helpers.h" | 12 | #include "bpf_helpers.h" |
12 | 13 | ||
13 | struct bpf_map_def SEC("maps") my_map = { | 14 | struct bpf_map_def SEC("maps") my_map = { |
@@ -23,6 +24,13 @@ struct bpf_map_def SEC("maps") my_map2 = { | |||
23 | .max_entries = 1024, | 24 | .max_entries = 1024, |
24 | }; | 25 | }; |
25 | 26 | ||
27 | struct bpf_map_def SEC("maps") stackmap = { | ||
28 | .type = BPF_MAP_TYPE_STACK_TRACE, | ||
29 | .key_size = sizeof(u32), | ||
30 | .value_size = PERF_MAX_STACK_DEPTH * sizeof(u64), | ||
31 | .max_entries = 10000, | ||
32 | }; | ||
33 | |||
26 | #define PROG(foo) \ | 34 | #define PROG(foo) \ |
27 | int foo(struct pt_regs *ctx) \ | 35 | int foo(struct pt_regs *ctx) \ |
28 | { \ | 36 | { \ |
@@ -32,6 +40,7 @@ int foo(struct pt_regs *ctx) \ | |||
32 | bpf_map_update_elem(&my_map, &v, &v, BPF_ANY); \ | 40 | bpf_map_update_elem(&my_map, &v, &v, BPF_ANY); \ |
33 | bpf_map_update_elem(&my_map2, &v, &v, BPF_ANY); \ | 41 | bpf_map_update_elem(&my_map2, &v, &v, BPF_ANY); \ |
34 | bpf_map_delete_elem(&my_map2, &v); \ | 42 | bpf_map_delete_elem(&my_map2, &v); \ |
43 | bpf_get_stackid(ctx, &stackmap, BPF_F_REUSE_STACKID); \ | ||
35 | return 0; \ | 44 | return 0; \ |
36 | } | 45 | } |
37 | 46 | ||