Linux内核完全剖析:基于0.12内核
更新日期:2024-07-11 00:59:58
出版时间:2009-01
浏览量:1099
价格:0.0¥

书籍下载

内容介绍

内容简介

  本书对早期Linux内核(v0.12)全部代码文件进行了详细、全面的注释和说明,旨在帮助读者用较短的时间对Linux的工作机理获得全面而深刻的理解,为进一步学习和研究Linux打下坚实的基础。虽然选择的版本较低,但该内核已能够正常编译运行,并且其中已包括了Linux工作原理的精髓。书中首先以Linux源代码版本的变迁为主线,介绍了Linux的历史,同时着重说明了各个内核版本的主要区别和改进,给出了选择0.12版内核源代码作为研究对象的原因。在正式描述内核源代码之前,概要介绍了运行Linux的PC的硬件组成结构、编制内核使用的汇编语言和C语言扩展部分,并且重点说明了80x86处理器在保护模式下运行的编程方法。接着详细介绍了Linux内核源代码目录树组织结构,并依据该结构对所有内核程序和文件进行了注释和详细说明。有关代码注释的章节安排基本上都分为具体研究对象的概述、每个文件的功能介绍、代码内注释、代码中难点及相关资料介绍等部分。为了加深读者对内核工作原理的理解,书中最后一章给出了围绕Linux 0.12系统的多个试验。
  本书适合Linux爱好者作为学习内核工作原理的自学参考书籍,也适合作为高校计算机专业学生学习操作系统课程的辅助和实践教材,还可供一般技术人员作为开发嵌入式系统的参考书使用。

目录


第1章 概述
1.1 Linux的诞生和发展
1.1.1 UNIX操作系统的诞生
1.1.2 MINIX操作系统
1.1.3 GNU计划
1.1.4 POSIX标准
1.1.5 Linux操作系统的诞生
1.1.6 Linux操作系统版本的变迁
1.1.7 Linux名称的由来
1.1.8 早期Linux系统开发的主要贡献者
1.2 内容综述
1.3 本章小结

第2章 微型计算机组成结构
2.1 微型计算机组成原理
2.2 I/O端口寻址和访问控制方式
2.2.1 I/O端口和寻址
2.2.2 接口访问控制
2.3 主存储器、BIOS和CMOS存储器
2.3.1 主存储器
2.3.2 基本输入/输出程序BIOS
2.3.3 CMOS存储器
2.4 控制器和控制卡
2.4.1 中断控制器
2.4.2 DMA控制器
2.4.3 定时/计数器
2.4.4 键盘控制器
2.4.5 串行控制卡
2.4.6 显示控制
2.4.7 软盘和硬盘控制器
2.5 本章小结

第3章 内核编程语言和环境
3.1 as86汇编器
3.1.1 as86汇编语言语法
3.1.2 as86汇编语言程序
3.1.3 as86汇编语言程序的编译和链接
3.1.4 as86和1d86使用方法和选项
3.2 CNU as汇编
3.2.1 编译as汇编语言程序
3.2.2 as汇编语法
3.2.3 指令语句、操作数和寻址
3.2.4 区与重定位
3.2.5 符号
3.2.6 as汇编命令
3.2.7 编写16位代码
3.2.8 AS汇编器命令行选项
3.3 C语言程序
3.3.1 C程序编译和链接
3.3.2 嵌入汇编
3.3.3 圆括号中的组合语句
3.3.4 寄存器变量
3.3.5 内联函数
3.4 C与汇编程序的相互调用
3.4.1 C函数调用机制
3.4.2 在汇编程序中调用C函数
3.4.3 在C程序中调用汇编函数
3.5 Linux 0.12目标文件格式
3.5.1 目标文件格式
3.5.2 Linux0.12中的目标文件格式
3.5.3 链接程序输出
3.5.4 链接程序预定义变量一
3.5.5 System.map文件
3.6 Make程序和Makefile文件
3.6.1 Makefite文件内容
3.6.2 Makefile文件中的规则
3.6.3 Makefile文件示例
3.6.4 make处理Makefile文件的方式
3.6.5 Makefile中的变量
3.6.6 让make自动推断命令
3.6.7 隐含规则中的自动变量
3.7本章 小结

第4章 80x86保护模式及其编程
4.1 80x86系统寄存器和系统指令
4.1.1 标志寄存器
4.1.2 内存管理寄存器
4.1.3 控制寄存器
4.1.4 系统指令
4.2 保护模式内存管理
4.2.1 内存寻址
4.2.2 地址变换
4.2.3 保护
4.3 分段机制
4.3.1 段的定义
4.3.2 段描述符表
4.3.3 段选择符
4.3.4 段描述符
4.3.5 代码和数据段描述符类型
4.3.6 系统描述符类型
4.4 分页机制
4.4.1 页表结构
4.4.2 页表项格式
4.4.3 虚拟存储
4.5 保护
4.5.1 段级保护
4.5.2 访问数据段时的特权级检查
4.5.3 代码段之间转移控制时的特权级检查
4.5.4 页级保护
4.5.5 组合页级和段级保护
4.6 中断和异常处理
4.6.1 异常和中断向量
4.6.2 中断源和异常源
4.6.3 异常分类
4.6.4 程序或任务的重新执行
4.6.5 开启和禁止中断
4.6.6 异常和中断的优先级
4.6.7 中断描述符表
4.6.8 IDT描述符
4.6.9 异常与中断处理
4.6.10 中断处理任务
4.6.11 错误码
4.7 任务管理
4.7.1 任务的结构和状态
4.7.2 任务的执行
4.7.3 任务管理数据结构
4.7.4 任务切换
4.7.5 任务链
4.7.6 任务地址空间
4.8 保护模式编程初始化
4.8.1 进入保护模式时的初始化操作
4.8.2 模式切换
4.9 一个简单的多任务内核实例
4.9.1 多任务程序结构和工作原理
4.9.2 引导启动程序boot.s
4.9.3 多任务内核程序head.s

第5章 Linux内核体系结构
5.1 Linux内核模式
5.2 Linux内核系统体系结构
5.3 Linux内核对内存的管理和使用
5.3.1 物理内存
5.3.2 内存地址空间概念
5.3.3 内存分段机制
5.3.4 内存分页管理
5.3.5 CPu多任务和保护方式
5.3.6 虚拟地址、线性地址和物理地址之间的关系
5.3.7 用户申请内存的动态分配
5.4 中断机制
5.4.1 中断操作原理
5.4.2 80x86微机的中断子系统
5.4.3 中断向量表
5.4.4 I.inux内核的中断处理
5.4.5 标志寄存器的中断标志
5.5 Linux的系统调用
5.5.1 系统调用接口
5.5.2 系统调用处理过程
5.5.3 Linux系统调用的参数传递方式
5.6 系统时间和定时
5.6.1 系统时间
5.6.2 系统定时
5.7 Linux进程控制
5.7.1 任务数据结构
5.7.2 进程运行状态
5.7.3 进程初始化
5.7.4 创建新进程
5.7.5 进程调度
5.7.6 终止进程
5.8 Linux系统中堆栈的使用方法
5.8.1 初始化阶段
5.8.2 任务的堆栈
5.8.3 任务内核态堆栈与用户态堆栈之间的切换
5.9 Linux0.12采用的文件系统
5.10 Linux内核源代码的目录结构
5.10.1 内核主目录linux
5.10.2 引导启动程序目录boot
5.10.3 文件系统目录fs
5.10.4 头文件主目录include
5.10.5 内核初始化程序目录init
5.10.6 内核程序主目录kernel
5.10.7 内核库函数目录lib
5.10.8 内存管理程序目录mm
5.10.9 编译内核工具程序目录tools
5.1l 内核系统与应用程序的关系
5.12 linux/MakeftIe文件
5.12.1 功能描述
5.12.2 代码注释
5.13 本章 小结

第6章 引导启动程序
6.1 总体功能
6.2 bootsect.S程序
6.2.1 功能描述
6.2.2 代码注释
6.2.3 其他信息
6.3 setup.S程序
6.3.1 功能描述
6.3.2 代码注释
6.3.3 其他信息
6.4 lead.s程序
6.4.1 功能描述
6.4.2 代码注释
6.4.3 其他信息
6.5 本章 小结

第7章 初始化程序
7.1 main.c程序
7.1.1 功能描述
7.1.2 代码注释
7.1.3 其他信息
7.2 环境初始化工作
7.3 本章 小结

第8章 内核代码
8.1 总体功能
8.1.1 中断处理程序
8.1.2 系统调用处理相关程序
8.1.3 其他通用类程序
8.2 asm.s程序
8.2.1 功能描述
8.2.2 代码注释
8.2.3 Intel保留中断向量的定义
8.3 traps.c程序
8.3.1 功能描述
8.3.2 代码注释
8.4 syscall.s程序
8.4.1 功能描述
8.4.2 代码注释
8.4.3 其他信息
8.5 mktime.c程序
8.5.1 功能描述
8.5.2 代码注释
8.5.3 闰年的计算方法
8.6 sched.c程序
8.6.1 功能描述
8.6.2 代码注释
8.6.3 其他信息
8.7 signal.c程序
8.7.1 功能描述
8.7.2 代码注释
8.7.3 进程信号说明
8.8 exit.c程序
8.8.1 功能描述
8.8.2 代码注释
8.9 fork.c程序
8.9.1 功能描述
8.9.2 代码注释
8.9.3 任务状态段信息
8.10 sys.c程序
8.10.1 功能描述
8.10.2 代码注释
8.1l vsprimtfc程序
8.11.1 功能描述
8.11.2 代码注释
8.11.3 vsprintf的格式字符串
8.11.4 与当前版本的区别
8.12 printk.c程序
8.12.1 功能描述
8.12.2 代码注释
8.13 panic.c程序
8.13.1 功能描述
8.13.2 代码注释
8.14 本章 小结

第9章 块设备驱动程序
9.1 总体功能
9.1.1 块设备请求项和请求队列
9.1.2 块设备访问调度处理
9.1.3 块设备操作方式
9.2 blk.h文件
9.2.1 功能描述
9.2.2 代码注释
9.3 hd.c程序
9.3.1 功能描述
9.3.2 代码注释
9.3.3 其他信息
9.4 nrwblk.c程序
9.4.1 功能描述
9.4.2 代码注释
9.5 ramdisk.c程序
9.5.1 功能描述
9.5.2 代码注释
9.6 floppy.c程序
9.6.1 功能描述
9.6.2 代码注释
9.6.3 其他信息

第10章 字符设备驱动程序
10.1 总体功能
10.1.1 终端驱动程序基本原理
10.1.2 Linux支持的终端设备类型
10.1.3 终端基本数据结构
lO.1.4 规范模式和非规范模式
10.1.5 控制台终端和串行终端设备
10.1.6 终端驱动程序接口
10.2 keyboard.S程序
10.2.1 功能描述
10.2.2 代码注释
10.2.3 其他信息
10.3 console.c程序
10.3.1 功能描述
10.3.2 代码注释
10.3.3 其他信息
10.4 serial.c程序
10.4.l 功能描述
10.4.2 代码注释
lO.4.3 异步串行通信控制器UART
10.5 rsio.s程序
10.5.1 功能描述
10.5.2 代码注释
10.6 ttyi0.c程序
10.6.1 功能描述
10.6.2 代码注释
10.6.3 控制字符vnME、VMlN
10.7 ttyjoctl.c程序
10.7.1 功能描述
10.7.2 代码注释
第11章 数学协处理器
第12章 文件系统
第13章 内存管理
第14章 头文件
第15章 库文件
第16章 建造工具
第17章 实验环境设置与使用方法
附录
参考文献

精彩书摘

  第1章 概述
  本章首先回顾了Linux操作系统的诞生、开发和成长过程,由此读者可以理解本书选择Linux系统早期版本作为学习对象的一些原因;然后具体说明了选择早期Linux内核版本进行学习的优点和不足之处以及如何开始进一步学习;最后对各章的内容进行了简要介绍。
  1.1 Linux的诞生和发展
  Linux操作系统是UNIX操作系统的一种克隆系统。它诞生于1991年10月5日(这是第一次正式向外公布的时间)。此后借助于Internet网络,经过全世界计算机爱好者的共同努力,现已成为当今使用最多的一种UNIX类操作系统,并且使用人数还在迅猛增长。
  Linux操作系统的诞生、发展和成长过程依赖于以下五个重要支柱:UNIX操作系统、MINIX操作系统、GNU计划、POSIX标准和Internet。下面根据这五个基本线索来回顾一下Linux的酝酿过程、开发历程以及最初的发展。首先分别介绍其中的四个基本要素,然后根据Linux的创始人Linus Torvalds从对计算机感兴趣而自学计算机知识,到心里开始酝酿编制一个自己的操作系统,到最初Linux内核0.O1版公布以及从此如何艰难地一步一个脚印地在全世界黑客的帮助下推出比较完善的1.0版本这段经过,对Linux的早期发展历史进行详细介绍。
  当然,目前Linux内核版本已经开发到了2.6.X版。而大多数Linux系统中所用到的内核是稳定的2.6.12版内核(其中第2个数字若是奇数则表示正在开发的版本,不能保证系统的稳定性)。对于Linux的一般发展史,许多文章和书籍都有介绍,这里不再重复。
  1.1.1 UNIX操作系统的诞生
  UNIX操作系统最早是美国贝尔实验室的Ken Thompson于1969年夏在DEC PDP-7小型计算机上开发的一个分时操作系统。
  Ken Thompson为了能在闲置不用的PDP-7计算机上运行他非常喜欢的星际旅行(Star Trek)游戏,于1969年夏天趁他夫人回家乡加利福尼亚度假期间,在一个月内开发出了UNIX操作系统的原型。当时使用的是BCPL语言(基本组合编程语言),后经Dennis Ritchie于1972年用移植性很强的C语言进行了改写,使得UNIX系统在大学得到了推广。

前言/序言

  本书是一本有关Linux操作系统内核基本工作原理的入门读物。
  本书的主要目标
  本书的主要目标是使用尽量少的篇幅,对完整的Linux内核源代码进行解剖,使读者对操作系统的基本功能和实际实现方式获得全方位的理解。
  本书读者应是知晓Linux系统的一般使用方法或具有一定的编程基础,但比较缺乏阅读目前最新内核源代码的基础知识,又急切希望能够进一步理解IJNIX类操作系统内核工作原理和实际代码实现的爱好者。这部分读者的水平应该界于初级与中级水平之间。目前,这部分读者人数在Linux爱好者中所占的比例是很高的,而面向这部分读者以比较易懂和有效的手段讲解内核的书籍资料不多。 现有书籍不足之处 目前已有的描述Linux内核的书籍,均尽量选用最新Linux内核版本(例如Fedora 8使用的2.6.24稳定版等)进行描述,但由于目前Linux内核整个源代码的大小已经非常大(例如2.2.20版就已具有268万行代码!),因此这些书籍仅能对LJnux内核源代码进行选择性或原理性的说明,许多系统实现细节被忽略。因此并不能使读者对实际L,inux内核有清晰而完整的理解。
  Scott Maxwell的《Linux内核源代码分析》基本上是面对Linux中、高级水平的读者,需要较为全面的基础知识才能完全理解。而且可能是由于篇幅所限,该书并没有对所有Linux内核代码进行注释,略去了很多内核实现细节,例如内核中使用的各个头文件(*.h)、生成内核代码映像文件的工具程序、各个make文件的作用和实现等均没有涉及。因此对于处于初、中级水平之间的读者来说阅读该书有些困难。
  John Lions的《莱昂氏LINIX源代码分析》虽然是一本学习UNIX类操作系统内核源代码很好的书,但是由于其采用的是UNIX V6版,其中系统调用等部分代码是用早已废弃的PDP.11系列机的汇编语言编制的,因此在阅读和理解与硬件部分相关的源代码时就会遇到较大的困难。
  A.S.Tanenbaum的《操作系统:设计与实现》是有关操作系统内核实现很好的入门书籍,但该书所叙述的M1NⅨ系统是一种基于消息传递的内核实现机制,与IAnux内核的实现有所区别。因此在学习该书之后,并不能很顺利地即刻着手进一步学习较新的Linux内核源代码实现。
  在使用这些书籍进行学习时会有一种“盲人摸象”的感觉,不容易真正理解Linux内核系统具体实现的整体概念,尤其是对那些Linux系统初学者,或刚学会如何使用Linux系统的人在使用那些书学习内核原理时,内核的整体运作结构并不能清晰地在脑海中形成。这在本人多年的Linux内核学习过程中也深有体会。在1991年10月,Linux的创始人Linus’Forvalds在开发出Linux 0.03版后写的一篇文章中也提到了同样的问题。在这篇题为《IJnux-aFree unix.386Kernel》目的文章中,他说:“开发Linux是为了那些操作系统爱好者和计算机科学系的学生使用、学习和娱乐”。“自由软件基金会的GN2J Hurd系统如果开发出来就已经显得太庞大而不适合学习和理解。”