【Linux 内核 内存管理】RCU 机制 ④ ( RCU 模式下更新链表项 list_replace_rcu 函数 | 链表操作时使用 smp_wmb() 函数保证代码执行顺序 )
生活随笔
收集整理的這篇文章主要介紹了
【Linux 内核 内存管理】RCU 机制 ④ ( RCU 模式下更新链表项 list_replace_rcu 函数 | 链表操作时使用 smp_wmb() 函数保证代码执行顺序 )
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
文章目錄
- 一、RCU 模式下更新鏈表項 list_replace_rcu 函數
- 二、鏈表操作時使用 smp_wmb() 函數保證代碼執行順序
一、RCU 模式下更新鏈表項 list_replace_rcu 函數
在 Linux 源碼 linux-5.6.18\include\linux\rculist.h 頭文件中定義的就是 RCU 鏈表的操作 ,
其中定義的
static inline void list_replace_rcu(struct list_head *old,struct list_head *new)函數 , 就是 更新 鏈表元素 的 函數 ;
list_replace_rcu 函數中 , 更新鏈表元素的核心操作就是將 被更新的 鏈表元素 , 前后指針指向新的元素即可 ;
new->next = old->next;new->prev = old->prev;rcu_assign_pointer(list_next_rcu(new->prev), new);new->next->prev = new;old->prev = LIST_POISON2;list_replace_rcu 函數原型 :
/*** list_replace_rcu - replace old entry by new one* @old : the element to be replaced* @new : the new element to insert** The @old entry will be replaced with the @new entry atomically.* Note: @old should not be empty.*/ static inline void list_replace_rcu(struct list_head *old,struct list_head *new) {new->next = old->next;new->prev = old->prev;rcu_assign_pointer(list_next_rcu(new->prev), new);new->next->prev = new;old->prev = LIST_POISON2; }源碼路徑 : linux-5.6.18\include\linux\rculist.h#198
二、鏈表操作時使用 smp_wmb() 函數保證代碼執行順序
編譯器 和 CPU 優化 代碼時 , 有時會將 代碼執行順序改變 ,
在鏈表操作時 , 代碼的執行順序必須得到保證 , 否則會得到不可預知的結果 ;
使用 smp_wmb() 函數 , 可以保證該函數 前兩行 的代碼 執行完畢后 , 再執行后兩行的代碼 ;
總結
以上是生活随笔為你收集整理的【Linux 内核 内存管理】RCU 机制 ④ ( RCU 模式下更新链表项 list_replace_rcu 函数 | 链表操作时使用 smp_wmb() 函数保证代码执行顺序 )的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 【Linux 内核 内存管理】RCU 机
- 下一篇: 【Linux 内核 内存管理】优化内存屏