提交 34a64b6b 编写于 作者: L Lai Jiangshan 提交者: Paul E. McKenney

srcu: Update synchronize_srcu()'s comments

The core of SRCU is changed, but synchronize_srcu()'s comments describe
the old algorithm.  This commit therefore updates them to match the
new algorithm.
Signed-off-by: NLai Jiangshan <laijs@cn.fujitsu.com>
Signed-off-by: NPaul E. McKenney <paulmck@linux.vnet.ibm.com>
上级 511a0868
...@@ -450,10 +450,12 @@ static void __synchronize_srcu(struct srcu_struct *sp, int trycount) ...@@ -450,10 +450,12 @@ static void __synchronize_srcu(struct srcu_struct *sp, int trycount)
* synchronize_srcu - wait for prior SRCU read-side critical-section completion * synchronize_srcu - wait for prior SRCU read-side critical-section completion
* @sp: srcu_struct with which to synchronize. * @sp: srcu_struct with which to synchronize.
* *
* Flip the completed counter, and wait for the old count to drain to zero. * Wait for the count to drain to zero of both indexes. To avoid the
* As with classic RCU, the updater must use some separate means of * possible starvation of synchronize_srcu(), it waits for the count of
* synchronizing concurrent updates. Can block; must be called from * the index=((->completed & 1) ^ 1) to drain to zero at first,
* process context. * and then flip the completed and wait for the count of the other index.
*
* Can block; must be called from process context.
* *
* Note that it is illegal to call synchronize_srcu() from the corresponding * Note that it is illegal to call synchronize_srcu() from the corresponding
* SRCU read-side critical section; doing so will result in deadlock. * SRCU read-side critical section; doing so will result in deadlock.
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册