diff options
| author | Dmitry Torokhov <dmitry.torokhov@gmail.com> | 2023-08-30 16:06:38 -0700 | 
|---|---|---|
| committer | Dmitry Torokhov <dmitry.torokhov@gmail.com> | 2023-08-30 16:06:38 -0700 | 
| commit | 1ac731c529cd4d6adbce134754b51ff7d822b145 (patch) | |
| tree | 143ab3f35ca5f3b69f583c84e6964b17139c2ec1 /include/linux/tracepoint.h | |
| parent | 07b4c950f27bef0362dc6ad7ee713aab61d58149 (diff) | |
| parent | 54116d442e001e1b6bd482122043b1870998a1f3 (diff) | |
Merge branch 'next' into for-linus
Prepare input updates for 6.6 merge window.
Diffstat (limited to 'include/linux/tracepoint.h')
| -rw-r--r-- | include/linux/tracepoint.h | 15 | 
1 files changed, 6 insertions, 9 deletions
| diff --git a/include/linux/tracepoint.h b/include/linux/tracepoint.h index e299f29375bb..6811e43c1b5c 100644 --- a/include/linux/tracepoint.h +++ b/include/linux/tracepoint.h @@ -242,12 +242,11 @@ static inline struct tracepoint *tracepoint_ptr_deref(tracepoint_ptr_t *p)   * not add unwanted padding between the beginning of the section and the   * structure. Force alignment to the same alignment as the section start.   * - * When lockdep is enabled, we make sure to always do the RCU portions of - * the tracepoint code, regardless of whether tracing is on. However, - * don't check if the condition is false, due to interaction with idle - * instrumentation. This lets us find RCU issues triggered with tracepoints - * even when this tracepoint is off. This code has no purpose other than - * poking RCU a bit. + * When lockdep is enabled, we make sure to always test if RCU is + * "watching" regardless if the tracepoint is enabled or not. Tracepoints + * require RCU to be active, and it should always warn at the tracepoint + * site if it is not watching, as it will need to be active when the + * tracepoint is enabled.   */  #define __DECLARE_TRACE(name, proto, args, cond, data_proto)		\  	extern int __traceiter_##name(data_proto);			\ @@ -260,9 +259,7 @@ static inline struct tracepoint *tracepoint_ptr_deref(tracepoint_ptr_t *p)  				TP_ARGS(args),				\  				TP_CONDITION(cond), 0);			\  		if (IS_ENABLED(CONFIG_LOCKDEP) && (cond)) {		\ -			rcu_read_lock_sched_notrace();			\ -			rcu_dereference_sched(__tracepoint_##name.funcs);\ -			rcu_read_unlock_sched_notrace();		\ +			WARN_ON_ONCE(!rcu_is_watching());		\  		}							\  	}								\  	__DECLARE_TRACE_RCU(name, PARAMS(proto), PARAMS(args),		\ | 
