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

Posted 韩曙亮

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Linux 内核 内存管理Linux 内核堆内存管理 ③ ( CPU 计数器瓶颈 | per-CPU 计数器 | Linux 内核 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_CPU
	struct list_head list;	/* All percpu_counters are on a list */
#endif
	s32 __percpu *counters;
;

源码路径 : linux-5.6.18\\include\\linux\\percpu_counter.h#20

以上是关于Linux 内核 内存管理Linux 内核堆内存管理 ③ ( CPU 计数器瓶颈 | per-CPU 计数器 | Linux 内核 percpu_counter 结构体源码 )的主要内容,如果未能解决你的问题,请参考以下文章

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

Linux 内核 内存管理内存管理架构 ④ ( 内存分配系统调用过程 | 用户层 malloc free | 系统调用层 brk mmap | 内核层 kmalloc | 内存管理流程 )

程序员必读:Linux内存管理剖析

linux内存管理--linux内核高端内存

Linux 内核 内存管理Linux 内核内存布局 ③ ( Linux 内核 动态分配内存 系统接口函数 | 统计输出 vmalloc 分配的内存 )

Linux 内核的内存管理 - 概念