1 // SPDX-License-Identifier: GPL-2.0-only
7 #include <bpf/libbpf.h>
9 static __u64
time_get_ns(void)
13 clock_gettime(CLOCK_MONOTONIC
, &ts
);
14 return ts
.tv_sec
* 1000000000ull + ts
.tv_nsec
;
17 static __u64 start_time
;
20 #define MAX_CNT 100000ll
22 static void print_bpf_output(void *ctx
, int cpu
, void *data
, __u32 size
)
29 if (e
->cookie
!= 0x12345678) {
30 printf("BUG pid %llx cookie %llx sized %d\n",
31 e
->pid
, e
->cookie
, size
);
38 printf("recv %lld events per sec\n",
39 MAX_CNT
* 1000000000ll / (time_get_ns() - start_time
));
44 int main(int argc
, char **argv
)
46 struct perf_buffer_opts pb_opts
= {};
47 struct bpf_link
*link
= NULL
;
48 struct bpf_program
*prog
;
49 struct perf_buffer
*pb
;
50 struct bpf_object
*obj
;
55 snprintf(filename
, sizeof(filename
), "%s_kern.o", argv
[0]);
56 obj
= bpf_object__open_file(filename
, NULL
);
57 if (libbpf_get_error(obj
)) {
58 fprintf(stderr
, "ERROR: opening BPF object file failed\n");
62 /* load BPF program */
63 if (bpf_object__load(obj
)) {
64 fprintf(stderr
, "ERROR: loading BPF object file failed\n");
68 map_fd
= bpf_object__find_map_fd_by_name(obj
, "my_map");
70 fprintf(stderr
, "ERROR: finding a map in obj file failed\n");
74 prog
= bpf_object__find_program_by_name(obj
, "bpf_prog1");
75 if (libbpf_get_error(prog
)) {
76 fprintf(stderr
, "ERROR: finding a prog in obj file failed\n");
80 link
= bpf_program__attach(prog
);
81 if (libbpf_get_error(link
)) {
82 fprintf(stderr
, "ERROR: bpf_program__attach failed\n");
87 pb_opts
.sample_cb
= print_bpf_output
;
88 pb
= perf_buffer__new(map_fd
, 8, &pb_opts
);
89 ret
= libbpf_get_error(pb
);
91 printf("failed to setup perf_buffer: %d\n", ret
);
95 f
= popen("taskset 1 dd if=/dev/zero of=/dev/null", "r");
98 start_time
= time_get_ns();
99 while ((ret
= perf_buffer__poll(pb
, 1000)) >= 0 && cnt
< MAX_CNT
) {
104 bpf_link__destroy(link
);
105 bpf_object__close(obj
);