mirror of
https://github.com/varun-r-mallya/Python-BPF.git
synced 2025-12-31 21:06:25 +00:00
45 lines
1.1 KiB
Python
45 lines
1.1 KiB
Python
from pythonbpf import bpf, map, section, bpfglobal, compile
|
|
from pythonbpf.helpers import ktime
|
|
from pythonbpf.maps import HashMap
|
|
|
|
from ctypes import c_void_p, c_int64, c_uint64
|
|
|
|
# Instructions to how to run this program
|
|
# 1. Install PythonBPF: pip install pythonbpf
|
|
# 2. Run the program: python examples/sys_sync.py
|
|
# 3. Run the program with sudo: sudo tools/check.sh run examples/sys_sync.o
|
|
# 4. Start a Python repl and `import os` and then keep entering `os.sync()` to see reponses.
|
|
|
|
|
|
@bpf
|
|
@map
|
|
def last() -> HashMap:
|
|
return HashMap(key=c_uint64, value=c_uint64, max_entries=3)
|
|
|
|
|
|
@bpf
|
|
@section("tracepoint/syscalls/sys_enter_sync")
|
|
def do_trace(ctx: c_void_p) -> c_int64:
|
|
key = 0
|
|
tsp = last().lookup(key)
|
|
if tsp:
|
|
kt = ktime()
|
|
delta = kt - tsp
|
|
if delta < 1000000000:
|
|
time_ms = delta // 1000000
|
|
print(f"sync called within last second, last {time_ms} ms ago")
|
|
last().delete(key)
|
|
else:
|
|
kt = ktime()
|
|
last().update(key, kt)
|
|
return c_int64(0)
|
|
|
|
|
|
@bpf
|
|
@bpfglobal
|
|
def LICENSE() -> str:
|
|
return "GPL"
|
|
|
|
|
|
compile()
|