|
@@ -1499,6 +1499,16 @@ static int __rcu_pending(struct rcu_state *rsp, struct rcu_data *rdp)
|
|
|
|
|
|
/* Is the RCU core waiting for a quiescent state from this CPU? */
|
|
|
if (rdp->qs_pending) {
|
|
|
+
|
|
|
+ /*
|
|
|
+ * If force_quiescent_state() coming soon and this CPU
|
|
|
+ * needs a quiescent state, and this is either RCU-sched
|
|
|
+ * or RCU-bh, force a local reschedule.
|
|
|
+ */
|
|
|
+ if (!rdp->preemptable &&
|
|
|
+ ULONG_CMP_LT(ACCESS_ONCE(rsp->jiffies_force_qs) - 1,
|
|
|
+ jiffies))
|
|
|
+ set_need_resched();
|
|
|
rdp->n_rp_qs_pending++;
|
|
|
return 1;
|
|
|
}
|