xref: /aosp_15_r20/external/bcc/libbpf-tools/drsnoop.bpf.c (revision 387f9dfdfa2baef462e92476d413c7bc2470293e)
1*387f9dfdSAndroid Build Coastguard Worker // SPDX-License-Identifier: GPL-2.0
2*387f9dfdSAndroid Build Coastguard Worker // Copyright (c) 2020 Wenbo Zhang
3*387f9dfdSAndroid Build Coastguard Worker #include <vmlinux.h>
4*387f9dfdSAndroid Build Coastguard Worker #include <bpf/bpf_helpers.h>
5*387f9dfdSAndroid Build Coastguard Worker #include <bpf/bpf_tracing.h>
6*387f9dfdSAndroid Build Coastguard Worker #include "drsnoop.h"
7*387f9dfdSAndroid Build Coastguard Worker 
8*387f9dfdSAndroid Build Coastguard Worker const volatile pid_t targ_pid = 0;
9*387f9dfdSAndroid Build Coastguard Worker const volatile pid_t targ_tgid = 0;
10*387f9dfdSAndroid Build Coastguard Worker const volatile __u64 vm_zone_stat_kaddr = 0;
11*387f9dfdSAndroid Build Coastguard Worker 
12*387f9dfdSAndroid Build Coastguard Worker struct piddata {
13*387f9dfdSAndroid Build Coastguard Worker 	u64 ts;
14*387f9dfdSAndroid Build Coastguard Worker 	u64 nr_free_pages;
15*387f9dfdSAndroid Build Coastguard Worker };
16*387f9dfdSAndroid Build Coastguard Worker 
17*387f9dfdSAndroid Build Coastguard Worker struct {
18*387f9dfdSAndroid Build Coastguard Worker 	__uint(type, BPF_MAP_TYPE_HASH);
19*387f9dfdSAndroid Build Coastguard Worker 	__uint(max_entries, 8192);
20*387f9dfdSAndroid Build Coastguard Worker 	__type(key, u32);
21*387f9dfdSAndroid Build Coastguard Worker 	__type(value, struct piddata);
22*387f9dfdSAndroid Build Coastguard Worker } start SEC(".maps");
23*387f9dfdSAndroid Build Coastguard Worker 
24*387f9dfdSAndroid Build Coastguard Worker struct {
25*387f9dfdSAndroid Build Coastguard Worker 	__uint(type, BPF_MAP_TYPE_PERF_EVENT_ARRAY);
26*387f9dfdSAndroid Build Coastguard Worker 	__uint(key_size, sizeof(u32));
27*387f9dfdSAndroid Build Coastguard Worker 	__uint(value_size, sizeof(u32));
28*387f9dfdSAndroid Build Coastguard Worker } events SEC(".maps");
29*387f9dfdSAndroid Build Coastguard Worker 
handle_direct_reclaim_begin()30*387f9dfdSAndroid Build Coastguard Worker static int handle_direct_reclaim_begin()
31*387f9dfdSAndroid Build Coastguard Worker {
32*387f9dfdSAndroid Build Coastguard Worker 	u64 *vm_zone_stat_kaddrp = (u64*)vm_zone_stat_kaddr;
33*387f9dfdSAndroid Build Coastguard Worker 	u64 id = bpf_get_current_pid_tgid();
34*387f9dfdSAndroid Build Coastguard Worker 	struct piddata piddata = {};
35*387f9dfdSAndroid Build Coastguard Worker 	u32 tgid = id >> 32;
36*387f9dfdSAndroid Build Coastguard Worker 	u32 pid = id;
37*387f9dfdSAndroid Build Coastguard Worker 
38*387f9dfdSAndroid Build Coastguard Worker 	if (targ_tgid && targ_tgid != tgid)
39*387f9dfdSAndroid Build Coastguard Worker 		return 0;
40*387f9dfdSAndroid Build Coastguard Worker 	if (targ_pid && targ_pid != pid)
41*387f9dfdSAndroid Build Coastguard Worker 		return 0;
42*387f9dfdSAndroid Build Coastguard Worker 
43*387f9dfdSAndroid Build Coastguard Worker 	piddata.ts = bpf_ktime_get_ns();
44*387f9dfdSAndroid Build Coastguard Worker 	if (vm_zone_stat_kaddrp) {
45*387f9dfdSAndroid Build Coastguard Worker 		bpf_probe_read_kernel(&piddata.nr_free_pages,
46*387f9dfdSAndroid Build Coastguard Worker 				      sizeof(*vm_zone_stat_kaddrp),
47*387f9dfdSAndroid Build Coastguard Worker 				      &vm_zone_stat_kaddrp[NR_FREE_PAGES]);
48*387f9dfdSAndroid Build Coastguard Worker 	}
49*387f9dfdSAndroid Build Coastguard Worker 
50*387f9dfdSAndroid Build Coastguard Worker 	bpf_map_update_elem(&start, &pid, &piddata, 0);
51*387f9dfdSAndroid Build Coastguard Worker 	return 0;
52*387f9dfdSAndroid Build Coastguard Worker }
53*387f9dfdSAndroid Build Coastguard Worker 
handle_direct_reclaim_end(void * ctx,unsigned long nr_reclaimed)54*387f9dfdSAndroid Build Coastguard Worker static int handle_direct_reclaim_end(void *ctx, unsigned long nr_reclaimed)
55*387f9dfdSAndroid Build Coastguard Worker {
56*387f9dfdSAndroid Build Coastguard Worker 	u64 id = bpf_get_current_pid_tgid();
57*387f9dfdSAndroid Build Coastguard Worker 	struct piddata *piddatap;
58*387f9dfdSAndroid Build Coastguard Worker 	struct event event = {};
59*387f9dfdSAndroid Build Coastguard Worker 	u32 tgid = id >> 32;
60*387f9dfdSAndroid Build Coastguard Worker 	u32 pid = id;
61*387f9dfdSAndroid Build Coastguard Worker 	s64 delta_ns;
62*387f9dfdSAndroid Build Coastguard Worker 
63*387f9dfdSAndroid Build Coastguard Worker 	if (targ_tgid && targ_tgid != tgid)
64*387f9dfdSAndroid Build Coastguard Worker 		return 0;
65*387f9dfdSAndroid Build Coastguard Worker 	if (targ_pid && targ_pid != pid)
66*387f9dfdSAndroid Build Coastguard Worker 		return 0;
67*387f9dfdSAndroid Build Coastguard Worker 
68*387f9dfdSAndroid Build Coastguard Worker 	/* fetch timestamp and calculate delta */
69*387f9dfdSAndroid Build Coastguard Worker 	piddatap = bpf_map_lookup_elem(&start, &pid);
70*387f9dfdSAndroid Build Coastguard Worker 	if (!piddatap)
71*387f9dfdSAndroid Build Coastguard Worker 		return 0;   /* missed entry */
72*387f9dfdSAndroid Build Coastguard Worker 
73*387f9dfdSAndroid Build Coastguard Worker 	delta_ns = bpf_ktime_get_ns() - piddatap->ts;
74*387f9dfdSAndroid Build Coastguard Worker 	if (delta_ns < 0)
75*387f9dfdSAndroid Build Coastguard Worker 		goto cleanup;
76*387f9dfdSAndroid Build Coastguard Worker 
77*387f9dfdSAndroid Build Coastguard Worker 	event.pid = pid;
78*387f9dfdSAndroid Build Coastguard Worker 	event.nr_reclaimed = nr_reclaimed;
79*387f9dfdSAndroid Build Coastguard Worker 	event.delta_ns = delta_ns;
80*387f9dfdSAndroid Build Coastguard Worker 	event.nr_free_pages = piddatap->nr_free_pages;
81*387f9dfdSAndroid Build Coastguard Worker 	bpf_get_current_comm(&event.task, TASK_COMM_LEN);
82*387f9dfdSAndroid Build Coastguard Worker 
83*387f9dfdSAndroid Build Coastguard Worker 	/* output */
84*387f9dfdSAndroid Build Coastguard Worker 	bpf_perf_event_output(ctx, &events, BPF_F_CURRENT_CPU,
85*387f9dfdSAndroid Build Coastguard Worker 			      &event, sizeof(event));
86*387f9dfdSAndroid Build Coastguard Worker 
87*387f9dfdSAndroid Build Coastguard Worker cleanup:
88*387f9dfdSAndroid Build Coastguard Worker 	bpf_map_delete_elem(&start, &pid);
89*387f9dfdSAndroid Build Coastguard Worker 	return 0;
90*387f9dfdSAndroid Build Coastguard Worker }
91*387f9dfdSAndroid Build Coastguard Worker 
92*387f9dfdSAndroid Build Coastguard Worker SEC("tp_btf/mm_vmscan_direct_reclaim_begin")
BPF_PROG(direct_reclaim_begin_btf)93*387f9dfdSAndroid Build Coastguard Worker int BPF_PROG(direct_reclaim_begin_btf)
94*387f9dfdSAndroid Build Coastguard Worker {
95*387f9dfdSAndroid Build Coastguard Worker 	return handle_direct_reclaim_begin();
96*387f9dfdSAndroid Build Coastguard Worker }
97*387f9dfdSAndroid Build Coastguard Worker 
98*387f9dfdSAndroid Build Coastguard Worker SEC("tp_btf/mm_vmscan_direct_reclaim_end")
BPF_PROG(direct_reclaim_end_btf,unsigned long nr_reclaimed)99*387f9dfdSAndroid Build Coastguard Worker int BPF_PROG(direct_reclaim_end_btf, unsigned long nr_reclaimed)
100*387f9dfdSAndroid Build Coastguard Worker {
101*387f9dfdSAndroid Build Coastguard Worker 	return handle_direct_reclaim_end(ctx, nr_reclaimed);
102*387f9dfdSAndroid Build Coastguard Worker }
103*387f9dfdSAndroid Build Coastguard Worker 
104*387f9dfdSAndroid Build Coastguard Worker SEC("raw_tp/mm_vmscan_direct_reclaim_begin")
BPF_PROG(direct_reclaim_begin)105*387f9dfdSAndroid Build Coastguard Worker int BPF_PROG(direct_reclaim_begin)
106*387f9dfdSAndroid Build Coastguard Worker {
107*387f9dfdSAndroid Build Coastguard Worker 	return handle_direct_reclaim_begin();
108*387f9dfdSAndroid Build Coastguard Worker }
109*387f9dfdSAndroid Build Coastguard Worker 
110*387f9dfdSAndroid Build Coastguard Worker SEC("raw_tp/mm_vmscan_direct_reclaim_end")
BPF_PROG(direct_reclaim_end,unsigned long nr_reclaimed)111*387f9dfdSAndroid Build Coastguard Worker int BPF_PROG(direct_reclaim_end, unsigned long nr_reclaimed)
112*387f9dfdSAndroid Build Coastguard Worker {
113*387f9dfdSAndroid Build Coastguard Worker 	return handle_direct_reclaim_end(ctx, nr_reclaimed);
114*387f9dfdSAndroid Build Coastguard Worker }
115*387f9dfdSAndroid Build Coastguard Worker 
116*387f9dfdSAndroid Build Coastguard Worker char LICENSE[] SEC("license") = "GPL";
117