Linux 内核 SMP 代码追踪 --- cpumask

for_each_present_cpu(cpu); 遍历全部可用的CPU。这里对CPU的状态进行区分主要是为了动态管理CPU ,进一步实现虚拟化。
#define for_each_present_cpu(cpu) for_each_cpu((cpu), cpu_present_mask)

for_each_cpu () 函数内核实现了两个版本,一个是单处理器版本,一个是多处理器版本,
其中他还用到了cpu_present_mask 宏。
系统中有四种这类的变量分别叫,cpu_present_mask,cpu_online_mask,cpu_active_mask , cpu_possible_mask;
在Linux内核中默认的SMP是最大支持8CPU,当然你可以加大这个数值。这可以在make menuconfig 中找到相关设置 “CPUS”.
这四个变量来源于四个属性,
cpu_all_bits ,用以表示在 menuconfig 中设置的NR_CPUS的值是多少。
cpu_possible_bits,表示实际在运行时处理器的CPU个数是多少?
cpu_online_bits, 用以表示系统真正在工作的处理器个数/状态。当内核管理处理器时主要是通过这个来进行的,
cpu_present_bits:用以表示系统中present的处理器数量,不一定所有都是Online的,在支持处理器热插拔的系统中,possible与present的关系为“cpu_possible_map = cpu_present_map + additional_cpus” ,present处理器是指系统固有的处理器个数不是外部插入的。
cpu_active_bits, 表示目前处于可工作状态的处理器个数。


在代码中如何获取上述的几个变量呢,如下:

printk("%s,possible bits is %lu\n",__func__,cpu_possible_mask->bits[0]);
printk("%s,online bits is %lu\n",__func__,cpu_online_mask->bits[0]);
printk("%s,present bits is %lu\n",__func__,cpu_present_mask->bits[0]);
printk("%s,active bits is %lu\n",__func__,cpu_active_mask->bits[0]);

Log打印如下:

work_demo_func,possible bits is 15      ------ 1111,cpu0,1,2,3
work_demo_func,online bits is 1            -----0001, cpu0
work_demo_func,present bits is 15        ------1111,cpu0,1,2,3
work_demo_func,active bits is 1             -----0001,cpu0

猜你喜欢

转载自blog.csdn.net/zhuyong006/article/details/82997422