读 Linux内核设计与实现 有感


看到Linux内核设计与实现已经第三版了,翻开看看发现增加一章专门描述内核数据结构,详细描述中断处理程序和下半部机制。

Linux内核设计与实现(第三版)PDF 下载地址

一、温故而知新篇

1、fork和vfork

进程创建,在unix系统中,进程创建比较特别,分解为两个函数,分别为 fork和exec。首先,fork通过拷贝当前进程创建一个子进程,子进程与父进程区别仅仅在于一个pid,和某县资源和统计量,例如挂起的信号,它没有必要继承。exec函数负责读取可执行文件并将其载入地址空间运行。

写时拷贝,linux的fork使用的是写时拷贝,内核不复制地址空间,仅仅是共享同一个拷贝,在需要写的时候才被复制,例如fork后直接exec则无需复制了。

fork和vfork功能相同,都是创建一个进程,但是子进程作为父进程的一个单独线程在它的地址空间运行,父进程被阻塞,知道子进程退出或者执行exec,子进程不能想地址空间写入。linux的fork引入了写时拷贝技术, 并明确了子进程先执行,vfork的仅限于不用拷贝父进程的页表项了。

2、内存管理

区,由于硬件的限制,内核不能对所有页一视同仁,所以内核把页划分为不同的区,一些硬件只能用某些特定的内存地址来执行DMA;一些体系结构其内存的物理寻址范围比虚拟地址范围大得多,有些内存不能永久的映射到内核地址空间。

ZONE_DMA ZONE_NORMAL ZONE_HIGHMEM

对于区这部分,并不是非常理解,

3、per cpu变量,突然发现内核是有专门的api的,例如DEFINE_PER_CPU

总结一下,面试的时候发现很多东西都是一知半解,希望以后可以深入研究。

二、深入学习

1、内核数据结构

2、中断处理程序和下半部机制

相关内容