rcu classic: update qlen when cpu offline
When callbacks are moved from offline cpu to this cpu, the qlen field of this rdp should be updated. [ Paul E. McKenney: ] The effect of this bug would be for force_quiescent_state() to be invoked when it should not and vice versa -- wasting cycles in the first case and letting RCU callbacks remain piled up in the second case. The bug is thus "benign" in that it does not result in premature grace-period termination, but should of course be fixed nonetheless. Preemption is disabled by the caller's get_cpu_var(), so we are guaranteed to remain on the same CPU, as required. The local_irq_disable() is indeed needed, otherwise, an interrupt might invoke call_rcu() or call_rcu_bh(), which could cause that interrupt's increment of ->qlen to be lost. Signed-off-by: Lai Jiangshan <laijs@cn.fujitsu.com> Cc: Andrew Morton <akpm@linux-foundation.org> Reviewed-by: Paul E. McKenney <paulmck@linux.vnet.ibm.com> Signed-off-by: Ingo Molnar <mingo@elte.hu>
This commit is contained in:
parent
0c81b2a144
commit
199a952876
|
@ -387,6 +387,10 @@ static void __rcu_offline_cpu(struct rcu_data *this_rdp,
|
||||||
rcu_move_batch(this_rdp, rdp->donelist, rdp->donetail);
|
rcu_move_batch(this_rdp, rdp->donelist, rdp->donetail);
|
||||||
rcu_move_batch(this_rdp, rdp->curlist, rdp->curtail);
|
rcu_move_batch(this_rdp, rdp->curlist, rdp->curtail);
|
||||||
rcu_move_batch(this_rdp, rdp->nxtlist, rdp->nxttail);
|
rcu_move_batch(this_rdp, rdp->nxtlist, rdp->nxttail);
|
||||||
|
|
||||||
|
local_irq_disable();
|
||||||
|
this_rdp->qlen += rdp->qlen;
|
||||||
|
local_irq_enable();
|
||||||
}
|
}
|
||||||
|
|
||||||
static void rcu_offline_cpu(int cpu)
|
static void rcu_offline_cpu(int cpu)
|
||||||
|
|
Loading…
Reference in New Issue