Commit 6ed4a496 authored by Brendan Gregg's avatar Brendan Gregg

accomodate mq block device I/O

parent 5be5194f
...@@ -38,7 +38,7 @@ static unsigned int log2l(unsigned long v) ...@@ -38,7 +38,7 @@ static unsigned int log2l(unsigned long v)
return log2(v) + 1; return log2(v) + 1;
} }
int kprobe__blk_start_request(struct pt_regs *ctx, struct request *req) int kprobe__blk_account_io_completion(struct pt_regs *ctx, struct request *req)
{ {
int index = log2l(req->__data_len / 1024); int index = log2l(req->__data_len / 1024);
u64 *leaf = dist.lookup(&index); u64 *leaf = dist.lookup(&index);
......
...@@ -15,14 +15,14 @@ ...@@ -15,14 +15,14 @@
BPF_HASH(start, struct request *); BPF_HASH(start, struct request *);
void kprobe__blk_start_request(struct pt_regs *ctx, struct request *req) { void trace_start(struct pt_regs *ctx, struct request *req) {
// stash start timestamp by request ptr // stash start timestamp by request ptr
u64 ts = bpf_ktime_get_ns(); u64 ts = bpf_ktime_get_ns();
start.update(&req, &ts); start.update(&req, &ts);
} }
void kprobe__blk_update_request(struct pt_regs *ctx, struct request *req) { void trace_completion(struct pt_regs *ctx, struct request *req) {
u64 *tsp, delta; u64 *tsp, delta;
tsp = start.lookup(&req); tsp = start.lookup(&req);
......
...@@ -17,6 +17,9 @@ REQ_WRITE = 1 # from include/linux/blk_types.h ...@@ -17,6 +17,9 @@ REQ_WRITE = 1 # from include/linux/blk_types.h
# load BPF program # load BPF program
b = BPF(src_file="disksnoop.c") b = BPF(src_file="disksnoop.c")
b.attach_kprobe(event="blk_start_request", fn_name="trace_start")
b.attach_kprobe(event="blk_mq_start_request", fn_name="trace_start")
b.attach_kprobe(event="blk_account_io_completion", fn_name="trace_completion")
# header # header
print("%-18s %-2s %-7s %8s" % ("TIME(s)", "T", "BYTES", "LAT(ms)")) print("%-18s %-2s %-7s %8s" % ("TIME(s)", "T", "BYTES", "LAT(ms)"))
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment