Skip to content

Commit

Permalink
fileslower: try probing vfs_write if __vfs_write is missing
Browse files Browse the repository at this point in the history
  • Loading branch information
Mark Drayton committed Jul 13, 2016
1 parent 52cd371 commit 32a4fd3
Showing 1 changed file with 7 additions and 2 deletions.
9 changes: 7 additions & 2 deletions tools/fileslower.py
Original file line number Diff line number Diff line change
Expand Up @@ -187,9 +187,14 @@ def signal_ignore(signal, frame):
# the parent functions, at the cost of more overhead, instead.
# Ultimately, we should be using [V]FS tracepoints.
b.attach_kprobe(event="__vfs_read", fn_name="trace_read_entry")
b.attach_kprobe(event="__vfs_write", fn_name="trace_write_entry")
b.attach_kretprobe(event="__vfs_read", fn_name="trace_read_return")
b.attach_kretprobe(event="__vfs_write", fn_name="trace_write_return")
try:
b.attach_kprobe(event="__vfs_write", fn_name="trace_write_entry")
b.attach_kretprobe(event="__vfs_write", fn_name="trace_write_return")
except:
# older kernels don't have __vfs_write so try vfs_write instead
b.attach_kprobe(event="vfs_write", fn_name="trace_write_entry")
b.attach_kretprobe(event="vfs_write", fn_name="trace_write_return")

TASK_COMM_LEN = 16 # linux/sched.h
DNAME_INLINE_LEN = 32 # linux/dcache.h
Expand Down

0 comments on commit 32a4fd3

Please sign in to comment.