欢迎访问 生活随笔!

生活随笔

当前位置: 首页 > 运维知识 > linux >内容正文

linux

【Linux 内核 内存管理】Linux 内核堆内存管理 ③ ( CPU 计数器瓶颈 | per-CPU 计数器 | Linux 内核 percpu_counter 结构体源码 )

发布时间:2025/6/17 linux 58 豆豆
生活随笔 收集整理的这篇文章主要介绍了 【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 结构体源码 )的全部内容,希望文章能够帮你解决所遇到的问题。

如果觉得生活随笔网站内容还不错,欢迎将生活随笔推荐给好友。