Skip to content

Commit 86155d6

Browse files
committed
Merge tag 'trace-v5.16-rc2-2' of git://git.kernel.org/pub/scm/linux/kernel/git/rostedt/linux-trace
Pull tracing fixes from Steven Rostedt: "Two fixes to event pid filtering: - Make sure newly created events reflect the current state of pid filtering - Take pid filtering into account when recording trigger events. (Also clean up the if statement to be cleaner)" * tag 'trace-v5.16-rc2-2' of git://git.kernel.org/pub/scm/linux/kernel/git/rostedt/linux-trace: tracing: Fix pid filtering when triggers are attached tracing: Check pid filtering when creating events
2 parents 86799cd + a55f224 commit 86155d6

File tree

2 files changed

+30
-6
lines changed

2 files changed

+30
-6
lines changed

kernel/trace/trace.h

Lines changed: 18 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -1366,14 +1366,26 @@ __event_trigger_test_discard(struct trace_event_file *file,
13661366
if (eflags & EVENT_FILE_FL_TRIGGER_COND)
13671367
*tt = event_triggers_call(file, buffer, entry, event);
13681368

1369-
if (test_bit(EVENT_FILE_FL_SOFT_DISABLED_BIT, &file->flags) ||
1370-
(unlikely(file->flags & EVENT_FILE_FL_FILTERED) &&
1371-
!filter_match_preds(file->filter, entry))) {
1372-
__trace_event_discard_commit(buffer, event);
1373-
return true;
1374-
}
1369+
if (likely(!(file->flags & (EVENT_FILE_FL_SOFT_DISABLED |
1370+
EVENT_FILE_FL_FILTERED |
1371+
EVENT_FILE_FL_PID_FILTER))))
1372+
return false;
1373+
1374+
if (file->flags & EVENT_FILE_FL_SOFT_DISABLED)
1375+
goto discard;
1376+
1377+
if (file->flags & EVENT_FILE_FL_FILTERED &&
1378+
!filter_match_preds(file->filter, entry))
1379+
goto discard;
1380+
1381+
if ((file->flags & EVENT_FILE_FL_PID_FILTER) &&
1382+
trace_event_ignore_this_pid(file))
1383+
goto discard;
13751384

13761385
return false;
1386+
discard:
1387+
__trace_event_discard_commit(buffer, event);
1388+
return true;
13771389
}
13781390

13791391
/**

kernel/trace/trace_events.c

Lines changed: 12 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -2678,12 +2678,24 @@ static struct trace_event_file *
26782678
trace_create_new_event(struct trace_event_call *call,
26792679
struct trace_array *tr)
26802680
{
2681+
struct trace_pid_list *no_pid_list;
2682+
struct trace_pid_list *pid_list;
26812683
struct trace_event_file *file;
2684+
unsigned int first;
26822685

26832686
file = kmem_cache_alloc(file_cachep, GFP_TRACE);
26842687
if (!file)
26852688
return NULL;
26862689

2690+
pid_list = rcu_dereference_protected(tr->filtered_pids,
2691+
lockdep_is_held(&event_mutex));
2692+
no_pid_list = rcu_dereference_protected(tr->filtered_no_pids,
2693+
lockdep_is_held(&event_mutex));
2694+
2695+
if (!trace_pid_list_first(pid_list, &first) ||
2696+
!trace_pid_list_first(pid_list, &first))
2697+
file->flags |= EVENT_FILE_FL_PID_FILTER;
2698+
26872699
file->event_call = call;
26882700
file->tr = tr;
26892701
atomic_set(&file->sm_ref, 0);

0 commit comments

Comments
 (0)