Commit be294db8 authored by Brendan Gregg's avatar Brendan Gregg Committed by 4ast

fix junk filenames (#775)

parent 0ef9ec43
...@@ -211,19 +211,24 @@ static int trace_return(struct pt_regs *ctx, int type) ...@@ -211,19 +211,24 @@ static int trace_return(struct pt_regs *ctx, int type)
if (FILTER_US) if (FILTER_US)
return 0; return 0;
// workaround (rewriter should handle file to d_iname in one step):
struct dentry *de = NULL;
bpf_probe_read(&de, sizeof(de), &valp->fp->f_path.dentry);
// populate output struct // populate output struct
u32 size = PT_REGS_RC(ctx); u32 size = PT_REGS_RC(ctx);
struct data_t data = {.type = type, .size = size, .delta_us = delta_us, struct data_t data = {.type = type, .size = size, .delta_us = delta_us,
.pid = pid}; .pid = pid};
data.ts_us = ts / 1000; data.ts_us = ts / 1000;
data.offset = valp->offset; data.offset = valp->offset;
bpf_probe_read(&data.file, sizeof(data.file), de->d_iname);
bpf_get_current_comm(&data.task, sizeof(data.task)); bpf_get_current_comm(&data.task, sizeof(data.task));
// workaround (rewriter should handle file to d_name in one step):
struct dentry *de = NULL;
struct qstr qs = {};
bpf_probe_read(&de, sizeof(de), &valp->fp->f_path.dentry);
bpf_probe_read(&qs, sizeof(qs), (void *)&de->d_name);
if (qs.len == 0)
return 0;
bpf_probe_read(&data.file, sizeof(data.file), (void *)qs.name);
// output
events.perf_submit(ctx, &data, sizeof(data)); events.perf_submit(ctx, &data, sizeof(data));
return 0; return 0;
......
...@@ -206,19 +206,24 @@ static int trace_return(struct pt_regs *ctx, int type) ...@@ -206,19 +206,24 @@ static int trace_return(struct pt_regs *ctx, int type)
if (FILTER_US) if (FILTER_US)
return 0; return 0;
// workaround (rewriter should handle file to d_iname in one step):
struct dentry *de = NULL;
bpf_probe_read(&de, sizeof(de), &valp->fp->f_path.dentry);
// populate output struct // populate output struct
u32 size = PT_REGS_RC(ctx); u32 size = PT_REGS_RC(ctx);
struct data_t data = {.type = type, .size = size, .delta_us = delta_us, struct data_t data = {.type = type, .size = size, .delta_us = delta_us,
.pid = pid}; .pid = pid};
data.ts_us = ts / 1000; data.ts_us = ts / 1000;
data.offset = valp->offset; data.offset = valp->offset;
bpf_probe_read(&data.file, sizeof(data.file), de->d_iname);
bpf_get_current_comm(&data.task, sizeof(data.task)); bpf_get_current_comm(&data.task, sizeof(data.task));
// workaround (rewriter should handle file to d_name in one step):
struct dentry *de = NULL;
struct qstr qs = {};
bpf_probe_read(&de, sizeof(de), &valp->fp->f_path.dentry);
bpf_probe_read(&qs, sizeof(qs), (void *)&de->d_name);
if (qs.len == 0)
return 0;
bpf_probe_read(&data.file, sizeof(data.file), (void *)qs.name);
// output
events.perf_submit(ctx, &data, sizeof(data)); events.perf_submit(ctx, &data, sizeof(data));
return 0; return 0;
......
...@@ -176,19 +176,24 @@ static int trace_return(struct pt_regs *ctx, int type) ...@@ -176,19 +176,24 @@ static int trace_return(struct pt_regs *ctx, int type)
if (FILTER_US) if (FILTER_US)
return 0; return 0;
// workaround (rewriter should handle file to d_iname in one step):
struct dentry *de = NULL;
bpf_probe_read(&de, sizeof(de), &valp->fp->f_path.dentry);
// populate output struct // populate output struct
u32 size = PT_REGS_RC(ctx); u32 size = PT_REGS_RC(ctx);
struct data_t data = {.type = type, .size = size, .delta_us = delta_us, struct data_t data = {.type = type, .size = size, .delta_us = delta_us,
.pid = pid}; .pid = pid};
data.ts_us = ts / 1000; data.ts_us = ts / 1000;
data.offset = valp->offset; data.offset = valp->offset;
bpf_probe_read(&data.file, sizeof(data.file), de->d_iname);
bpf_get_current_comm(&data.task, sizeof(data.task)); bpf_get_current_comm(&data.task, sizeof(data.task));
// workaround (rewriter should handle file to d_name in one step):
struct dentry *de = NULL;
struct qstr qs = {};
bpf_probe_read(&de, sizeof(de), &valp->fp->f_path.dentry);
bpf_probe_read(&qs, sizeof(qs), (void *)&de->d_name);
if (qs.len == 0)
return 0;
bpf_probe_read(&data.file, sizeof(data.file), (void *)qs.name);
// output
events.perf_submit(ctx, &data, sizeof(data)); events.perf_submit(ctx, &data, sizeof(data));
return 0; return 0;
......
...@@ -180,19 +180,24 @@ static int trace_return(struct pt_regs *ctx, int type) ...@@ -180,19 +180,24 @@ static int trace_return(struct pt_regs *ctx, int type)
if (FILTER_US) if (FILTER_US)
return 0; return 0;
// workaround (rewriter should handle file to d_iname in one step):
struct dentry *de = NULL;
bpf_probe_read(&de, sizeof(de), &valp->fp->f_path.dentry);
// populate output struct // populate output struct
u32 size = PT_REGS_RC(ctx); u32 size = PT_REGS_RC(ctx);
struct data_t data = {.type = type, .size = size, .delta_us = delta_us, struct data_t data = {.type = type, .size = size, .delta_us = delta_us,
.pid = pid}; .pid = pid};
data.ts_us = ts / 1000; data.ts_us = ts / 1000;
data.offset = valp->offset; data.offset = valp->offset;
bpf_probe_read(&data.file, sizeof(data.file), de->d_iname);
bpf_get_current_comm(&data.task, sizeof(data.task)); bpf_get_current_comm(&data.task, sizeof(data.task));
// workaround (rewriter should handle file to d_name in one step):
struct dentry *de = NULL;
struct qstr qs = {};
bpf_probe_read(&de, sizeof(de), &valp->fp->f_path.dentry);
bpf_probe_read(&qs, sizeof(qs), (void *)&de->d_name);
if (qs.len == 0)
return 0;
bpf_probe_read(&data.file, sizeof(data.file), (void *)qs.name);
// output
events.perf_submit(ctx, &data, sizeof(data)); events.perf_submit(ctx, &data, sizeof(data));
return 0; return 0;
......
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