1ee5cf82cSAndrii Nakryiko // SPDX-License-Identifier: GPL-2.0 2ee5cf82cSAndrii Nakryiko // Copyright (c) 2019 Facebook 3ee5cf82cSAndrii Nakryiko 4ee5cf82cSAndrii Nakryiko #include <linux/ptrace.h> 5ee5cf82cSAndrii Nakryiko #include <linux/bpf.h> 63e689141SToke Høiland-Jørgensen #include <bpf/bpf_helpers.h> 7df8ff353SAndrii Nakryiko #include <bpf/bpf_tracing.h> 8ee5cf82cSAndrii Nakryiko 9ee5cf82cSAndrii Nakryiko struct { 10ee5cf82cSAndrii Nakryiko __uint(type, BPF_MAP_TYPE_PERF_EVENT_ARRAY); 11ee5cf82cSAndrii Nakryiko __uint(key_size, sizeof(int)); 12ee5cf82cSAndrii Nakryiko __uint(value_size, sizeof(int)); 13ee5cf82cSAndrii Nakryiko } perf_buf_map SEC(".maps"); 14ee5cf82cSAndrii Nakryiko 15ee5cf82cSAndrii Nakryiko SEC("kprobe/sys_nanosleep") 16ac065870SAndrii Nakryiko int BPF_KPROBE(handle_sys_nanosleep_entry) 17ee5cf82cSAndrii Nakryiko { 18ee5cf82cSAndrii Nakryiko int cpu = bpf_get_smp_processor_id(); 19ee5cf82cSAndrii Nakryiko 20ee5cf82cSAndrii Nakryiko bpf_perf_event_output(ctx, &perf_buf_map, BPF_F_CURRENT_CPU, 21ee5cf82cSAndrii Nakryiko &cpu, sizeof(cpu)); 22ee5cf82cSAndrii Nakryiko return 0; 23ee5cf82cSAndrii Nakryiko } 24ee5cf82cSAndrii Nakryiko 25ee5cf82cSAndrii Nakryiko char _license[] SEC("license") = "GPL"; 26