从零开始写Linux内核:一书学透核心原理与实现

从零开始写Linux内核:一书学透核心原理与实现

带你穿透层层迷雾,窥见繁复的Linux系统设计的绚丽“天光”

暂无评价综合评分的显示会考虑用户真实性等多项因素,每部作品出现综合评分的时间不定。

作品简介

全书分为三个部分:1.第一部分主要讲解CPU及相关外设的工作原理和内核的加载。2.第二部分主要讲解进程管理,内存管理和字符/块设备驱动等核心模块。3.第三部分针对文件系统进行讲解,由此延伸到链接器,加载器的工作原理。本书带领读者从零开始,使用现代的编译器逐步实现Linux0.11内核。读者在完成本书的所有实验以后,读者就可以继续研究更高版本的Linux内核,并且可以充分利用当前已经有的各种工具对Linux内核进行充分的调试和研究。

本书共8章,从逻辑上分为四部分。第一部分(第1和2章)是基础知识,介绍开发内核所需的基础知识,包括开发环境和调试环境的搭建,以及i386保护模式等。第二部分(第3~6章)是核心模块,逐步实现进程、中断、系统调用、内存管理、字符设备驱动和块设备驱动等模块。第三部分(第7章)文件系统,涵盖Minix文件系统、管理inode、管理普通文件、管理目录、文件链接、执行程序等内容。第四部分(第8章)縣统服务接口,介绍一些重要的函数,这部分不是内核的主要部分,但为了让shell程序正确地运行,这些函数也是必须实现的。

海纳:华为编译器开发高级工程师,目前投入鸿蒙系统开发语言ArkTS的开发。曾先后从事数据库、操作系统和编译器开发工作。著有图书《自己动手写Python虚拟机》,并撰写了极客时间专栏“编程高手必学的内存知识”“手写Python虚拟机”等。

作品目录

  1. 前言
  2. 第1章 基础知识和环境准备
  3. 1.1 操作系统概述
  4. 1.1.1 功能和架构
  5. 1.1.2 操作系统的发展历史
  6. 1.2 配置环境
  7. 1.2.1 配置开发环境
  8. 1.2.2 配置运行环境
  9. 1.3 第一个内核程序
  10. 1.3.1 打印Hello World
  11. 1.3.2 开机引导程序
  12. 1.4 汇编语言
  13. 1.4.1 内嵌汇编
  14. 1.4.2 链接器的工作原理
  15. 1.4.3 初识makefile
  16. 1.5 小结
  17. 第2章 保护模式
  18. 2.1 进入保护模式前的准备
  19. 2.1.1 加载并执行setup
  20. 2.1.2 获取硬件信息
  21. 2.2 内存管理
  22. 2.2.1 A20地址线
  23. 2.2.2 全局描述符
  24. 2.2.3 页表的原理
  25. 2.2.4 进入保护模式
  26. 2.3 中断机制
  27. 2.3.1 中断描述符表
  28. 2.3.2 可编程中断控制器
  29. 2.3.3 特权级
  30. 2.4 时钟中断
  31. 2.4.1 初始化中断控制芯片
  32. 2.4.2 设置中断描述符表
  33. 2.4.3 重设全局描述符表
  34. 2.4.4 时钟中断实验
  35. 2.5 小结
  36. 第3章 进入内核
  37. 3.1 开启分页管理
  38. 3.1.1 设置页表
  39. 3.1.2 设置栈指针
  40. 3.2 实现格式化打印
  41. 3.2.1 初始化终端和控制台
  42. 3.2.2 操作显示控制器
  43. 3.2.3 支持换行和回车
  44. 3.2.4 格式化打印结果并输出
  45. 3.3 设置内存和陷阱处理
  46. 3.3.1 初始化内存管理
  47. 3.3.2 初始化系统调用
  48. 3.3.3 处理CPU异常
  49. 3.4 小结
  50. 第4章 创建进程
  51. 4.1 创建INIT进程
  52. 4.1.1 创建进程控制块
  53. 4.1.2 切换特权级
  54. 4.2 创建第二个进程
  55. 4.2.1 准备进程控制块
  56. 4.2.2 复制进程控制块
  57. 4.2.3 实现进程切换
  58. 4.3 第一个系统调用:fork
  59. 4.3.1 系统调用和中断
  60. 4.3.2 定义fork函数
  61. 4.3.3 内存的写时复制
  62. 4.3.4 处理页保护中断
  63. 4.3.5 完善调度器
  64. 4.4 小结
  65. 第5章 支持字符设备
  66. 5.1 支持键盘
  67. 5.1.1 键盘的工作原理
  68. 5.1.2 解析扫描码
  69. 5.1.3 构建缓冲区
  70. 5.1.4 完善屏幕回显功能
  71. 5.1.5 回显字符
  72. 5.2 优化输入功能
  73. 5.2.1 控制台和远程终端
  74. 5.2.2 系统调用read函数
  75. 5.3 优化输出功能
  76. 5.3.1 向标准输出写字符串
  77. 5.3.2 ANSI转义序列
  78. 5.3.3 支持转义序列
  79. 5.4 修改终端状态
  80. 5.4.1 支持方向键
  81. 5.4.2 修改控制台标志位
  82. 5.5 小结
  83. 第6章 支持块设备
  84. 6.1 硬盘的基本结构
  85. 6.1.1 初始化硬盘信息
  86. 6.1.2 硬盘分区表
  87. 6.1.3 硬盘控制器编程
  88. 6.1.4 设置硬盘中断
  89. 6.2 管理缓冲区
  90. 6.2.1 初始化缓冲区
  91. 6.2.2 申请缓冲区
  92. 6.2.3 缓冲区相关的读写操作
  93. 6.3 硬盘驱动
  94. 6.3.1 读写硬盘
  95. 6.3.2 读硬盘分区表
  96. 6.4 软盘驱动
  97. 6.4.1 软盘的工作原理
  98. 6.4.2 实现定时器
  99. 6.4.3 DMA读写
  100. 6.4.4 软盘控制器
  101. 6.4.5 实现软盘操作函数
  102. 6.5 小结
  103. 第7章 文件系统
  104. 7.1 Minix文件系统
  105. 7.1.1 Minix文件系统的基本结构
  106. 7.1.2 定义超级块
  107. 7.1.3 初始化超级块
  108. 7.2 管理inode
  109. 7.2.1 文件的元信息
  110. 7.2.2 管理位图
  111. 7.2.3 删除文件
  112. 7.2.4 进程支持文件操作
  113. 7.2.5 目录结构
  114. 7.3 管理普通文件
  115. 7.3.1 根据路径查找inode
  116. 7.3.2 打开文件
  117. 7.3.3 文件的读操作
  118. 7.3.4 读写普通文件
  119. 7.4 管理目录
  120. 7.4.1 创建目录和文件
  121. 7.4.2 删除目录:rmdir
  122. 7.4.3 新建文件
  123. 7.5 文件链接
  124. 7.5.1 创建硬链接
  125. 7.5.2 创建软链接
  126. 7.5.3 通过链接访问文件
  127. 7.5.4 删除文件链接
  128. 7.6 执行程序
  129. 7.6.1 a.out格式
  130. 7.6.2 执行程序:execve
  131. 7.6.3 缺页中断
  132. 7.6.4 实验:运行第一个可执行程序
  133. 7.7 小结
  134. 第8章 系统服务接口
  135. 8.1 POSIX接口
  136. 8.1.1 时间管理
  137. 8.1.2 挂载文件系统
  138. 8.2 管理进程
  139. 8.2.1 信号处理
  140. 8.2.2 管道通信
  141. 8.2.3 进程同步
  142. 8.2.4 进程退出
  143. 8.3 构建C语言库
  144. 8.4 小结
  145. 附录 显示模式