diff options
Diffstat (limited to 'include/linux/rcupdate.h')
| -rw-r--r-- | include/linux/rcupdate.h | 19 | 
1 files changed, 11 insertions, 8 deletions
diff --git a/include/linux/rcupdate.h b/include/linux/rcupdate.h index 53ff1a752d7e..ed4f5939a452 100644 --- a/include/linux/rcupdate.h +++ b/include/linux/rcupdate.h @@ -57,7 +57,7 @@ enum rcutorture_type {  	INVALID_RCU_FLAVOR  }; -#if defined(CONFIG_TREE_RCU) || defined(CONFIG_TREE_PREEMPT_RCU) +#if defined(CONFIG_TREE_RCU) || defined(CONFIG_PREEMPT_RCU)  void rcutorture_get_gp_data(enum rcutorture_type test_type, int *flags,  			    unsigned long *gpnum, unsigned long *completed);  void rcutorture_record_test_transition(void); @@ -260,7 +260,7 @@ static inline int rcu_preempt_depth(void)  void rcu_init(void);  void rcu_sched_qs(void);  void rcu_bh_qs(void); -void rcu_check_callbacks(int cpu, int user); +void rcu_check_callbacks(int user);  struct notifier_block;  void rcu_idle_enter(void);  void rcu_idle_exit(void); @@ -348,8 +348,8 @@ extern struct srcu_struct tasks_rcu_exit_srcu;   */  #define cond_resched_rcu_qs() \  do { \ -	rcu_note_voluntary_context_switch(current); \ -	cond_resched(); \ +	if (!cond_resched()) \ +		rcu_note_voluntary_context_switch(current); \  } while (0)  #if defined(CONFIG_DEBUG_LOCK_ALLOC) || defined(CONFIG_RCU_TRACE) || defined(CONFIG_SMP) @@ -365,7 +365,7 @@ typedef void call_rcu_func_t(struct rcu_head *head,  			     void (*func)(struct rcu_head *head));  void wait_rcu_gp(call_rcu_func_t crf); -#if defined(CONFIG_TREE_RCU) || defined(CONFIG_TREE_PREEMPT_RCU) +#if defined(CONFIG_TREE_RCU) || defined(CONFIG_PREEMPT_RCU)  #include <linux/rcutree.h>  #elif defined(CONFIG_TINY_RCU)  #include <linux/rcutiny.h> @@ -867,7 +867,7 @@ static inline void rcu_preempt_sleep_check(void)   *   * In non-preemptible RCU implementations (TREE_RCU and TINY_RCU),   * it is illegal to block while in an RCU read-side critical section. - * In preemptible RCU implementations (TREE_PREEMPT_RCU) in CONFIG_PREEMPT + * In preemptible RCU implementations (PREEMPT_RCU) in CONFIG_PREEMPT   * kernel builds, RCU read-side critical sections may be preempted,   * but explicit blocking is illegal.  Finally, in preemptible RCU   * implementations in real-time (with -rt patchset) kernel builds, RCU @@ -902,7 +902,9 @@ static inline void rcu_read_lock(void)   * Unfortunately, this function acquires the scheduler's runqueue and   * priority-inheritance spinlocks.  This means that deadlock could result   * if the caller of rcu_read_unlock() already holds one of these locks or - * any lock that is ever acquired while holding them. + * any lock that is ever acquired while holding them; or any lock which + * can be taken from interrupt context because rcu_boost()->rt_mutex_lock() + * does not disable irqs while taking ->wait_lock.   *   * That said, RCU readers are never priority boosted unless they were   * preempted.  Therefore, one way to avoid deadlock is to make sure @@ -1062,6 +1064,7 @@ static inline notrace void rcu_read_unlock_sched_notrace(void)   */  #define RCU_INIT_POINTER(p, v) \  	do { \ +		rcu_dereference_sparse(p, __rcu); \  		p = RCU_INITIALIZER(v); \  	} while (0) @@ -1118,7 +1121,7 @@ static inline notrace void rcu_read_unlock_sched_notrace(void)  	__kfree_rcu(&((ptr)->rcu_head), offsetof(typeof(*(ptr)), rcu_head))  #if defined(CONFIG_TINY_RCU) || defined(CONFIG_RCU_NOCB_CPU_ALL) -static inline int rcu_needs_cpu(int cpu, unsigned long *delta_jiffies) +static inline int rcu_needs_cpu(unsigned long *delta_jiffies)  {  	*delta_jiffies = ULONG_MAX;  	return 0;  |