【Linux 内核 内存管理】Linux 内核堆内存管理 ③ ( CPU 计数器瓶颈 | per-CPU 计数器 | Linux 内核 percpu_counter 结构体源码 )
生活随笔
收集整理的這篇文章主要介紹了
【Linux 内核 内存管理】Linux 内核堆内存管理 ③ ( CPU 计数器瓶颈 | per-CPU 计数器 | Linux 内核 percpu_counter 结构体源码 )
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
文章目錄
- 一、CPU 計數器瓶頸
- 二、per-CPU 計數器及 percpu_counter 結構體源碼
一、CPU 計數器瓶頸
如果 操作系統 中有 多個 CPU , 假設只有一個 CPU 計數器工作 , 如果 某個 CPU 正在訪問計數器 , 其它 CPU 需要等待計數器釋放 , 才能訪問 CPU 計數器 , 這里 CPU 計數器會出現瓶頸 , 影響系統性能 ;
二、per-CPU 計數器及 percpu_counter 結構體源碼
Linux 內核中 , 引入了 " per-CPU 計數器 “ , 用于加速 ” SMP 系統 " 的計數器操作 ;
" per-CPU 計數器 " 在 Linux 內核中被定義為 percpu_counter 結構體 , 該 結構體 定義在 Linux 內核源碼 的 linux-5.6.18\include\linux\percpu_counter.h#20 中 ;
raw_spinlock_t lock 字段是一個 自旋鎖 ;
s64 count 字段是 計數器的值 ;
struct percpu_counter {raw_spinlock_t lock;s64 count; #ifdef CONFIG_HOTPLUG_CPUstruct list_head list; /* All percpu_counters are on a list */ #endifs32 __percpu *counters; };源碼路徑 : linux-5.6.18\include\linux\percpu_counter.h#20
總結
以上是生活随笔為你收集整理的【Linux 内核 内存管理】Linux 内核堆内存管理 ③ ( CPU 计数器瓶颈 | per-CPU 计数器 | Linux 内核 percpu_counter 结构体源码 )的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 【Linux 内核 内存管理】Linux
- 下一篇: 【Linux 内核 内存管理】内存管理架