RCU writer方在釋放元素時(shí)的三種調(diào)用方式原文:Paul McKenney, "RCU and Unloadable Modules", http:///Articles/217119/, January 14, 2007.
RCU writer方在釋放元素時(shí)有三種調(diào)用方式:
1. 調(diào)用synchronize_rcu()——同步方式 調(diào)用舉例:從一個(gè)鏈表中刪除元素p list_del_rcu(p); synchronize_rcu(); kfree(p); 2. 在IRQ中調(diào)用call_rcv()——異步方式 調(diào)用舉例: 從一個(gè)鏈表中刪除元素p list_del_rcu(p); call_rcu(&p->rcu, p_callback); static void p_callback(struct rcu_head *rp)
{ struct pstruct *p = container_of(rp, struct pstruct, rcu); kfree(p); } 3. 模塊或文件系統(tǒng)卸載時(shí)調(diào)用rcu_barrier()
這里不能在卸載代碼中簡(jiǎn)單調(diào)用synchronize_rcu(). 因?yàn)閟ynchronize_rcu()雖然要等待一段grace period時(shí)間過(guò)去, 但它并不等待回調(diào)函數(shù)完成. 所以需要調(diào)用rcu_barrier(),以等待所有的rcu回調(diào)函數(shù)完成. 調(diào)用舉例:模塊卸載
(1) Prevent any new RCU callbacks from being posted. (2) Execute rcu_barrier(). (3) Allow the module to be unloaded. |
|