Linux 内核 SMP 代码追踪
来源:互联网 发布:apache评分与死亡率 编辑:程序博客网 时间:2024/05/20 13:06
init/main.c : kernel_init();
init/main.c : smp_init();
kernel/cpu.c cpu_up();
arch/x86/kernel/ smp_ops (结构体变量) 具体架构代码
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, 表示目前处于可工作状态的处理器个数。
setup_max_cpus
nr_cpu_ids
在默认情况下都表示CPUS数量。
- Linux 内核 SMP 代码追踪
- Linux 内核SMP 竞争问题
- linux内核死机2-smp
- 追踪Linux TCP/IP代码运行--基于2.6内核 (zz)
- linux内核SMP负载均衡浅析
- Linux内核学习笔记:SMP、UMA、NUMA
- Linux内核学习笔记:SMP、UMA、NUMA
- linux内核SMP负载均衡浅析
- linux内核SMP负载均衡浅析
- linux内核SMP负载均衡浅析
- linux内核SMP负载均衡浅析
- linux内核SMP负载均衡浅析
- linux内核SMP负载均衡浅析
- linux内核SMP负载均衡浅析
- linux内核SMP负载均衡浅析
- linux内核SMP负载均衡浅析
- linux内核SMP负载均衡浅析
- Linux内核SMP负载均衡浅析
- 2012年全球互联网数据一览:中国互联网用户全球第一
- babyos (十三) —— 运行在优先级0 的拼图游戏
- LCS(最长公共子序列)
- 回溯经典之素数环问题
- ZOJ Monthly, January 2013 记
- Linux 内核 SMP 代码追踪
- Android复制Assets目录下的文件到指定目录
- 如何保存成员变量animationManager?
- /etc/init.d/rcS内容分析
- springMVC教程
- 序
- 字母重排 stl
- HDU 2084(数塔)
- 字符设备 register_chrdev_region()、alloc_chrdev_region() 和 register_chrdev()函数的区别