1. 程式人生 > >Linux 核心 SMP 程式碼追蹤 --- cpumask

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