On Mon, 2 Oct 2023 16:25:27 -0400 Mathieu Desnoyers <mathieu.desnoyers@xxxxxxxxxxxx> wrote: > @@ -202,8 +198,12 @@ static inline struct tracepoint *tracepoint_ptr_deref(tracepoint_ptr_t *p) > if (WARN_ON_ONCE(RCUIDLE_COND(rcuidle))) \ > return; \ > \ > - /* keep srcu and sched-rcu usage consistent */ \ > - preempt_disable_notrace(); \ > + if (mayfault) { \ > + rcu_read_lock_trace(); \ I thought rcu_trace was for the case that a task can not voluntarily call schedule. If this tracepoint tries to read user space memory that isn't paged in, and faults, can't the faulting logic call schedule and break this requirement? -- Steve > + } else { \ > + /* keep srcu and sched-rcu usage consistent */ \ > + preempt_disable_notrace(); \ > + } \ > \ > /* \ > * For rcuidle callers, use srcu since sched-rcu \