void serial_test_perf_buffer(void)
 {
        int err, on_len, nr_on_cpus = 0, nr_cpus, i, j;
+       int zero = 0, my_pid = getpid();
        struct perf_buffer_opts pb_opts = {};
        struct test_perf_buffer *skel;
        cpu_set_t cpu_seen;
        if (CHECK(!skel, "skel_load", "skeleton open/load failed\n"))
                goto out_close;
 
+       err = bpf_map_update_elem(bpf_map__fd(skel->maps.my_pid_map), &zero, &my_pid, 0);
+       if (!ASSERT_OK(err, "my_pid_update"))
+               goto out_close;
+
        /* attach probe */
        err = test_perf_buffer__attach(skel);
        if (CHECK(err, "attach_kprobe", "err %d\n", err))
 
 #include <bpf/bpf_helpers.h>
 #include <bpf/bpf_tracing.h>
 
+struct {
+       __uint(type, BPF_MAP_TYPE_ARRAY);
+       __type(key, int);
+       __type(value, int);
+       __uint(max_entries, 1);
+} my_pid_map SEC(".maps");
+
 struct {
        __uint(type, BPF_MAP_TYPE_PERF_EVENT_ARRAY);
        __type(key, int);
        __type(value, int);
 } perf_buf_map SEC(".maps");
 
-SEC("tp/syscalls/sys_enter_nanosleep")
+SEC("tp/raw_syscalls/sys_enter")
 int handle_sys_enter(void *ctx)
 {
+       int zero = 0, *my_pid, cur_pid;
        int cpu = bpf_get_smp_processor_id();
 
+       my_pid = bpf_map_lookup_elem(&my_pid_map, &zero);
+       if (!my_pid)
+               return 1;
+
+       cur_pid = bpf_get_current_pid_tgid() >> 32;
+       if (cur_pid != *my_pid)
+               return 1;
+
        bpf_perf_event_output(ctx, &perf_buf_map, BPF_F_CURRENT_CPU,
                              &cpu, sizeof(cpu));
-       return 0;
+       return 1;
 }
 
 char _license[] SEC("license") = "GPL";