Re: [PATCH] trace-cmd: Do not print stacks after stacks

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On 5/28/24 5:31 PM, Steven Rostedt wrote:
> From: "Steven Rostedt (Google)" <rostedt@xxxxxxxxxxx>
> 
> When a filter is in place, the stack trace for the events that are
> printed by the filter should also be printed. Stack traces for events
> that are filtered out, should also be filtered out. But there was a bug
> in the logic that checked if the last event was printed or not to know
> to print the stack, and that is, the stack from the printed event was
> considered a printed event itself. So a stack trace coming from another
> event could be considered "printed" if two stacks came back to back
> (which can happen because of interrupts.
> 
> Note, this does mean that logic should be added to test for interrupts.
> But that's another story.
> 
> Reported-by: Vlastimil Babka <vbabka@xxxxxxx>
> Fixes: 82ed4a937 ("trace-cmd library: Add filtering logic for iterating events")
> Signed-off-by: Steven Rostedt (Google) <rostedt@xxxxxxxxxxx>

Seems to work as intended now. Thanks!
Tested-by: Vlastimil Babka <vbabka@xxxxxxx>

> ---
>  lib/trace-cmd/trace-filter.c | 5 ++++-
>  1 file changed, 4 insertions(+), 1 deletion(-)
> 
> diff --git a/lib/trace-cmd/trace-filter.c b/lib/trace-cmd/trace-filter.c
> index 1c8c07fc..99423223 100644
> --- a/lib/trace-cmd/trace-filter.c
> +++ b/lib/trace-cmd/trace-filter.c
> @@ -47,6 +47,7 @@ static bool test_stacktraces(struct tracecmd_filter *filter, struct tep_record *
>  __hidden enum tracecmd_filters tracecmd_filter_match(struct tracecmd_filter *filter,
>  						     struct tep_record *record)
>  {
> +	bool is_stack = false;
>  	bool found = false;
>  	int ret;
>  	int i;
> @@ -94,6 +95,8 @@ __hidden enum tracecmd_filters tracecmd_filter_match(struct tracecmd_filter *fil
>  		/* If this is a stack trace and the last event was printed continue */
>  		if (!test_stacktraces(filter, record))
>  			return TRACECMD_FILTER_MISS;
> +
> +		is_stack = true;
>  	}
>  
>  	found = false;
> @@ -110,7 +113,7 @@ __hidden enum tracecmd_filters tracecmd_filter_match(struct tracecmd_filter *fil
>  	}
>  
>  	if (filter->last_printed)
> -		filter->last_printed[record->cpu] = !found;
> +		filter->last_printed[record->cpu] = !is_stack && !found;
>  
>  	return found ? TRACECMD_FILTER_MISS : TRACECMD_FILTER_MATCH;
>  }





[Index of Archives]     [Linux USB Development]     [Linux USB Development]     [Linux Audio Users]     [Yosemite Hiking]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux