【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 内核 内存管理】内存管理架