blob: b64815af0943bbe34a019eb2c6a9130743f8ebbf [file] [log] [blame]
Alexei Starovoitov39111692015-10-20 20:02:35 -07001#include <linux/ptrace.h>
2#include <linux/version.h>
3#include <uapi/linux/bpf.h>
Toke Høiland-Jørgensen7cf245a2020-01-20 14:06:49 +01004#include <bpf/bpf_helpers.h>
Daniel T. Lee3677d0a2020-08-23 17:53:33 +09005#include "trace_common.h"
Alexei Starovoitov39111692015-10-20 20:02:35 -07006
Daniel T. Lee3677d0a2020-08-23 17:53:33 +09007struct {
8 __uint(type, BPF_MAP_TYPE_PERF_EVENT_ARRAY);
9 __uint(key_size, sizeof(int));
10 __uint(value_size, sizeof(u32));
11 __uint(max_entries, 2);
12} my_map SEC(".maps");
Alexei Starovoitov39111692015-10-20 20:02:35 -070013
Daniel T. Lee3677d0a2020-08-23 17:53:33 +090014SEC("kprobe/" SYSCALL(sys_write))
Alexei Starovoitov39111692015-10-20 20:02:35 -070015int bpf_prog1(struct pt_regs *ctx)
16{
17 struct S {
18 u64 pid;
19 u64 cookie;
20 } data;
21
Alexei Starovoitov39111692015-10-20 20:02:35 -070022 data.pid = bpf_get_current_pid_tgid();
23 data.cookie = 0x12345678;
24
25 bpf_perf_event_output(ctx, &my_map, 0, &data, sizeof(data));
26
27 return 0;
28}
29
30char _license[] SEC("license") = "GPL";
31u32 _version SEC("version") = LINUX_VERSION_CODE;