1*387f9dfdSAndroid Build Coastguard Worker // SPDX-License-Identifier: GPL-2.0
2*387f9dfdSAndroid Build Coastguard Worker // Copyright (c) 2021 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
7*387f9dfdSAndroid Build Coastguard Worker __s64 total = 0; /* total cache accesses without counting dirties */
8*387f9dfdSAndroid Build Coastguard Worker __s64 misses = 0; /* total of add to lru because of read misses */
9*387f9dfdSAndroid Build Coastguard Worker __u64 mbd = 0; /* total of mark_buffer_dirty events */
10*387f9dfdSAndroid Build Coastguard Worker
11*387f9dfdSAndroid Build Coastguard Worker SEC("fentry/add_to_page_cache_lru")
BPF_PROG(fentry_add_to_page_cache_lru)12*387f9dfdSAndroid Build Coastguard Worker int BPF_PROG(fentry_add_to_page_cache_lru)
13*387f9dfdSAndroid Build Coastguard Worker {
14*387f9dfdSAndroid Build Coastguard Worker __sync_fetch_and_add(&misses, 1);
15*387f9dfdSAndroid Build Coastguard Worker return 0;
16*387f9dfdSAndroid Build Coastguard Worker }
17*387f9dfdSAndroid Build Coastguard Worker
18*387f9dfdSAndroid Build Coastguard Worker SEC("fentry/mark_page_accessed")
BPF_PROG(fentry_mark_page_accessed)19*387f9dfdSAndroid Build Coastguard Worker int BPF_PROG(fentry_mark_page_accessed)
20*387f9dfdSAndroid Build Coastguard Worker {
21*387f9dfdSAndroid Build Coastguard Worker __sync_fetch_and_add(&total, 1);
22*387f9dfdSAndroid Build Coastguard Worker return 0;
23*387f9dfdSAndroid Build Coastguard Worker }
24*387f9dfdSAndroid Build Coastguard Worker
25*387f9dfdSAndroid Build Coastguard Worker SEC("fentry/account_page_dirtied")
BPF_PROG(fentry_account_page_dirtied)26*387f9dfdSAndroid Build Coastguard Worker int BPF_PROG(fentry_account_page_dirtied)
27*387f9dfdSAndroid Build Coastguard Worker {
28*387f9dfdSAndroid Build Coastguard Worker __sync_fetch_and_add(&misses, -1);
29*387f9dfdSAndroid Build Coastguard Worker return 0;
30*387f9dfdSAndroid Build Coastguard Worker }
31*387f9dfdSAndroid Build Coastguard Worker
32*387f9dfdSAndroid Build Coastguard Worker SEC("fentry/mark_buffer_dirty")
BPF_PROG(fentry_mark_buffer_dirty)33*387f9dfdSAndroid Build Coastguard Worker int BPF_PROG(fentry_mark_buffer_dirty)
34*387f9dfdSAndroid Build Coastguard Worker {
35*387f9dfdSAndroid Build Coastguard Worker __sync_fetch_and_add(&total, -1);
36*387f9dfdSAndroid Build Coastguard Worker __sync_fetch_and_add(&mbd, 1);
37*387f9dfdSAndroid Build Coastguard Worker return 0;
38*387f9dfdSAndroid Build Coastguard Worker }
39*387f9dfdSAndroid Build Coastguard Worker
40*387f9dfdSAndroid Build Coastguard Worker SEC("kprobe/add_to_page_cache_lru")
BPF_KPROBE(kprobe_add_to_page_cache_lru)41*387f9dfdSAndroid Build Coastguard Worker int BPF_KPROBE(kprobe_add_to_page_cache_lru)
42*387f9dfdSAndroid Build Coastguard Worker {
43*387f9dfdSAndroid Build Coastguard Worker __sync_fetch_and_add(&misses, 1);
44*387f9dfdSAndroid Build Coastguard Worker return 0;
45*387f9dfdSAndroid Build Coastguard Worker }
46*387f9dfdSAndroid Build Coastguard Worker
47*387f9dfdSAndroid Build Coastguard Worker SEC("kprobe/mark_page_accessed")
BPF_KPROBE(kprobe_mark_page_accessed)48*387f9dfdSAndroid Build Coastguard Worker int BPF_KPROBE(kprobe_mark_page_accessed)
49*387f9dfdSAndroid Build Coastguard Worker {
50*387f9dfdSAndroid Build Coastguard Worker __sync_fetch_and_add(&total, 1);
51*387f9dfdSAndroid Build Coastguard Worker return 0;
52*387f9dfdSAndroid Build Coastguard Worker }
53*387f9dfdSAndroid Build Coastguard Worker
54*387f9dfdSAndroid Build Coastguard Worker SEC("kprobe/account_page_dirtied")
BPF_KPROBE(kprobe_account_page_dirtied)55*387f9dfdSAndroid Build Coastguard Worker int BPF_KPROBE(kprobe_account_page_dirtied)
56*387f9dfdSAndroid Build Coastguard Worker {
57*387f9dfdSAndroid Build Coastguard Worker __sync_fetch_and_add(&misses, -1);
58*387f9dfdSAndroid Build Coastguard Worker return 0;
59*387f9dfdSAndroid Build Coastguard Worker }
60*387f9dfdSAndroid Build Coastguard Worker
61*387f9dfdSAndroid Build Coastguard Worker SEC("kprobe/folio_account_dirtied")
BPF_KPROBE(kprobe_folio_account_dirtied)62*387f9dfdSAndroid Build Coastguard Worker int BPF_KPROBE(kprobe_folio_account_dirtied)
63*387f9dfdSAndroid Build Coastguard Worker {
64*387f9dfdSAndroid Build Coastguard Worker __sync_fetch_and_add(&misses, -1);
65*387f9dfdSAndroid Build Coastguard Worker return 0;
66*387f9dfdSAndroid Build Coastguard Worker }
67*387f9dfdSAndroid Build Coastguard Worker
68*387f9dfdSAndroid Build Coastguard Worker SEC("kprobe/mark_buffer_dirty")
BPF_KPROBE(kprobe_mark_buffer_dirty)69*387f9dfdSAndroid Build Coastguard Worker int BPF_KPROBE(kprobe_mark_buffer_dirty)
70*387f9dfdSAndroid Build Coastguard Worker {
71*387f9dfdSAndroid Build Coastguard Worker __sync_fetch_and_add(&total, -1);
72*387f9dfdSAndroid Build Coastguard Worker __sync_fetch_and_add(&mbd, 1);
73*387f9dfdSAndroid Build Coastguard Worker return 0;
74*387f9dfdSAndroid Build Coastguard Worker }
75*387f9dfdSAndroid Build Coastguard Worker
76*387f9dfdSAndroid Build Coastguard Worker SEC("tracepoint/writeback/writeback_dirty_folio")
tracepoint__writeback_dirty_folio(struct trace_event_raw_sys_enter * ctx)77*387f9dfdSAndroid Build Coastguard Worker int tracepoint__writeback_dirty_folio(struct trace_event_raw_sys_enter* ctx)
78*387f9dfdSAndroid Build Coastguard Worker {
79*387f9dfdSAndroid Build Coastguard Worker __sync_fetch_and_add(&misses, -1);
80*387f9dfdSAndroid Build Coastguard Worker return 0;
81*387f9dfdSAndroid Build Coastguard Worker }
82*387f9dfdSAndroid Build Coastguard Worker
83*387f9dfdSAndroid Build Coastguard Worker SEC("tracepoint/writeback/writeback_dirty_page")
tracepoint__writeback_dirty_page(struct trace_event_raw_sys_enter * ctx)84*387f9dfdSAndroid Build Coastguard Worker int tracepoint__writeback_dirty_page(struct trace_event_raw_sys_enter* ctx)
85*387f9dfdSAndroid Build Coastguard Worker {
86*387f9dfdSAndroid Build Coastguard Worker __sync_fetch_and_add(&misses, -1);
87*387f9dfdSAndroid Build Coastguard Worker return 0;
88*387f9dfdSAndroid Build Coastguard Worker }
89*387f9dfdSAndroid Build Coastguard Worker
90*387f9dfdSAndroid Build Coastguard Worker char LICENSE[] SEC("license") = "GPL";
91