Skip to content

Commit ce61a87

Browse files
Yang Jihonggregkh
authored andcommitted
blktrace: Fix output non-blktrace event when blk_classic option enabled
[ Upstream commit f596da3 ] When the blk_classic option is enabled, non-blktrace events must be filtered out. Otherwise, events of other types are output in the blktrace classic format, which is unexpected. The problem can be triggered in the following ways: # echo 1 > /sys/kernel/debug/tracing/options/blk_classic # echo 1 > /sys/kernel/debug/tracing/events/enable # echo blk > /sys/kernel/debug/tracing/current_tracer # cat /sys/kernel/debug/tracing/trace_pipe Fixes: c71a896 ("blktrace: add ftrace plugin") Signed-off-by: Yang Jihong <yangjihong1@huawei.com> Link: https://lore.kernel.org/r/20221122040410.85113-1-yangjihong1@huawei.com Signed-off-by: Jens Axboe <axboe@kernel.dk> Signed-off-by: Sasha Levin <sashal@kernel.org>
1 parent f2ae56f commit ce61a87

File tree

1 file changed

+2
-1
lines changed

1 file changed

+2
-1
lines changed

kernel/trace/blktrace.c

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1547,7 +1547,8 @@ blk_trace_event_print_binary(struct trace_iterator *iter, int flags,
15471547

15481548
static enum print_line_t blk_tracer_print_line(struct trace_iterator *iter)
15491549
{
1550-
if (!(blk_tracer_flags.val & TRACE_BLK_OPT_CLASSIC))
1550+
if ((iter->ent->type != TRACE_BLK) ||
1551+
!(blk_tracer_flags.val & TRACE_BLK_OPT_CLASSIC))
15511552
return TRACE_TYPE_UNHANDLED;
15521553

15531554
return print_one_line(iter, true);

0 commit comments

Comments
 (0)