73、深入理解 Linux 内核中的每 CPU 变量

深入理解 Linux 内核中的每 CPU 变量

1. 引言

在大型 NUMA 系统中,处理每 CPU(per-CPU)数据能确保数据安全和良好的性能,因为缓存效应不再是需要关注的问题。本文将详细介绍每 CPU 变量的使用,包括分配、初始化、释放以及读写操作,还会通过示例和内核中的实际用例来加深理解。

2. 每 CPU 变量的基本操作
2.1 工作原则

在使用每 CPU 变量时,必须使用内核提供的辅助方法(宏和 API),而不要直接访问它们,这与引用计数和原子操作符的使用类似。

2.2 分配、初始化和释放

每 CPU 变量大致分为静态分配和动态分配两种类型:
- 静态分配 :通常通过 DEFINE_PER_CPU() DECLARE_PER_CPU() 宏在编译时分配内存。使用 DEFINE_PER_CPU() 可以一次性完成变量的分配和初始化。例如:

#include <linux/percpu.h>
DEFINE_PER_CPU(int, pcpa);      // signature: DEFINE_PER_CPU(type, name)

在一个有四个 CPU 核心的系统中,初始化后这个每 CPU 变量在概念上会有四个实例。
- 动态分配 :可以通过 alloc_percpu() <

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值