内核源码树
内核开发的特点
- 内核编程时既不能访问C库也不能访问标准C头文件
- 内核编程时必须使用GNU C
- 内核编程时缺乏像用户空间哪有的内存保护机制
- 内核编程难以执行浮点数运算
- 内核给每个进程只有一个很小的定长堆栈
- 内核支持异步中断,抢占和SMP,因此必须时刻注意同步和并发
- 要考虑可移植性
GNU C
- 内联函数(inline)
- 内联函数的工作方式:函数会在他所调用的位置进行展开,这么做就消除了函数调用和返回所带来的的开销(寄存器的存储和恢复)。
- 但是这么做的话,函数的代码会变长,就可能占用更多的内存空间或者更多的指令缓存。内核开发者通常把那些对时间要求比较高,而本身长度有比较短的函数定义成内联函数。
//define inline function
static inline void wolf(unsigned long tail_size);
-
内联汇编
linux内核混合使用了C语言和汇编语言。在偏近体系结构的底层或对执时间要求严格的地方,一般使用汇编语言。而内核其他部分大部分使用C。 -
分支声明:
对于条件选择语句,gcc内建了一条指令用于优化,在一个条件经常出现或者很少出现的时候,编译器可以根据这条质量对条件分支选择进行优化。内核把这条指令封装成了宏,比如unlikely()和likely() ,这样使用起来较为方便。
内核没有内存保护机制
- 应用程序进行非法内存访问的时候,内核会发现这个错误,并且返回信号(SIGSEGV)----segmentation violation
- 内核没有对内存进行分页,所以,每次用掉一个字节,物理内存就减少一个字节