Linux内核深度解析epub,Unix内核源码剖析 高清pdf版 含epub+mobi

本书是一本Unix内核源代码的阅读指南。作者结合UNIX V6已公开的相关文档,对其内核源码进行详细剖析,旨在让读者更深入地理解进程、中断、块I/O系统、文件系统、字符I/O系统、启动系统等操作系统的基本原理。

本书适合操作系统的初中级学习者阅读,特别适合通过大学课程和其他入门书对操作系统有所了解,但是对具体细节缺乏深入理解的读者,以及那些对操作系统的具体实现有兴趣的读者。

目录

第I部分

什么是UNIX V6  1

第1章 UNIX V6的全貌  2

1.1  什么是UNIX  V6  2

1.2  UNIX的历史2

1.3  UNIX  V6内核  4

1.4  构成UNIX V6运行环境的硬件  4

PDP-11  5

1.5  代码  9

1.6  手册  9

1.7  小结  10

第II部分

进程  11

第2章 进程  12

2.1  进程的概要  12

什么是进程  12

进程的并行执行  12

进程的执行状态  14

用户模式和内核模式  14

交换处理15

2.2  proc结构体和user结构体  15

proc结构体  16

user结构体  17

2.3  为进程分配的内存  21

代码段  21

数据段  21

虚拟地址空间  22

变换地址  24

2.4  小结  26

第3章 进程的管理I  27

3.1  进程的生命周期  27

3.2  创建进程  28

进程的复制  28

父进程和子进程  29

系统调用fork  29

newproc()  32

panic()  36

3.3  切换执行进程  37

中断执行进程  37

进程的执行状态  37

选择执行进程的算法  38

上下文切换  39

系统调用wait  39

sleep()  39

swtch()  41

swtch()  的返回位置  44

setpri()  51

wakeup()  51

setrun()  52

3.4  执行程序  53

程序执行文件的格式  53

系统调用exec  54

estabur()  62

sureg()  65

expand()  66

3.5  进程的终止  68

系统调用exit  69

系统调用wait  71

3.6  数据区域的扩展  73

系统调用break  73

3.7  管理内存和交换空间  76

map结构体  76

获取未使用区域  77

释放区域  79

3.8  小结  81

第4章 交换处理  82

4.1  什么是交换处理  82

代码段和数据段  82

sched()  83

xswap()  87

4.2  共享代码段的处理  88

xalloc()  90

xfree()  93

xccdec()  93

4.3  小结  94

第III  部分

中断  95

第5章 中断与陷入  96

5.1  什么是中断与陷入  96

什么是中断  96

什么是陷入  97

5.2  优先级与向量(Vector)  98

中断优先级和处理器优先级  98

中断和陷入向量  100

5.3  中断和陷入的处理流程  100

发生中断或陷入  101

执行call和trap  104

5.4  时钟中断处理函数  107

时钟设备的规格  107

时钟中断处理函数的内容  108

clock()  113

5.5  陷入处理函数  117

trap()  117

grow()  122

5.6  系统调用的处理流程  123

传递参数的方法  123

sysent结构体  124

trap()  126

5.7  小结  128

第6章 信号  129

6.1  什么是信号  129

信号的发送方法  129

确认接收信号  129

信号的种类  130

ssig()  131

kill()  132

signal()  133

psignal()  133

issig()  134

psig()  134

core()  136

在系统调用处理中处理信号  136

6.2  跟踪功能  137

什么是跟踪  137

ipc结构体  138

跟踪的处理流程  138

stop()  139

ptrace()  140

procxmt()  142

wait()  143

6.3  小结  144

第IV  部分

块I/O  系统  145

第7章 块设备子系统  146

7.1  设备的基础  146

设备的种类  146

设备驱动  146

类别和设备编号  147

特殊文件  147

7.2  块设备子系统  148

缓冲区  148

b-list和av-list  150

RAW  输入输出  151

7.3  缓冲区的初始化  152

binit()  152

clrbuf()  153

7.4  缓冲区的获取和释放  154

getblk()  154

notavail()  156

brelse()  157

7.5  读取  158

读取的种类  158

bread()  159

iowait()  160

iodone()  160

geterror()  161

breada()  161

incore()  162

7.6  写入  163

写入的种类  163

bwrite()  164

bawrite()  165

bdwrite()  165

bflush()  166

7.7  RAW输入输出  167

physio()  167

swap()  169

7.8  小结  171

第8章 块设备驱动  172

8.1  什么是块设备驱动  172

块设备驱动表  172

设备处理队列  173

处理流程  173

8.2  RK-11磁盘驱动  174

RK11-D  175

特殊文件  175

设定bdevsw[]  176

中断处理函数  176

RK11-D  的寄存器  177

rkstrategy()  179

rkstart()  180

rkaddr()  180

devstart()  181

rkintr()  182

RAW  输入输出  184

8.3  小结  184

第V  部分

文件系统  185

第9章 文件系统  186

9.1  什么是文件系统  186

inode  186

树状结构的命名空间  187

挂载  187

访问权限  188

根磁盘  189

9.2  块设备的区域  189

用于启动的区域  190

超级块  190

inode区域  191

存储区域  193

9.3  挂载  193

mount结构体  193

系统调用mount  194

getmdev()  196

系统调用umount  197

9.4  inode的获取和释放  198

inode[]  198

iget()  201

iput()  203

iupdat()  204

9.5  inode与存储区域的对应关系  205

bmap()  208

itrunc()  211

9.6  分配块设备中的块  213

ialloc()  213

ifree()  216

alloc()  217

free()  220

getfs()  222

badblock()  222

9.7  将路径变为inode  223

目录的内容  223

namei()  224

access()  230

9.8  初始化与同步  232

iinit()  232

update()  232

9.9  小结  234

第10章 文件处理  235

10.1  用户程序对文件的处理  235

10.2  3  个结构体  235

标准输入输出  237

10.3  文件的生成和打开处理  237

系统调用creat  238

maknode()  238

wdir()  239

系统调用open  240

open1()  241

falloc()  242

ufalloc()  243

openi()  243

10.4  文件的读取和写入  244

系统调用read、write  244

rdwr()  245

readi()  246

writei()  248

iomove()  250

getf()  252

10.5  指定文件的读写位置  252

系统调用seek  252

10.6  关闭文件  254

系统调用close  254

closef()  254

closei()  255

10.7  目录的生成  255

系统调用mknod  255

10.8  文件的链接  256

系统调用link  257

suser()  258

10.9  删除文件  258

系统调用unlink  258

10.10  小结  260

第11章 管道  261

11.1  什么是管道  261

使用管道的优点  262

11.2  开始管道通信  262

系统调用pipe  262

11.3  收发数据  264

writep()  264

readp()  266

plock()  267

prele()  267

11.4  结束管道通信  268

closef()  268

11.5  建立管道通信的流程  268

建立父子进程间的通信  268

系统调用dup  272

11.6  小结  273

第VI  部分

字符I/O  系统  275

第12章 字符设备  276

12.1  字符设备驱动  276

字符设备缓冲区  277

对缓冲区的操作  278

初始化缓冲区池  280

12.2  LP11设备驱动  281

什么是LP11  281

LP11设备驱动的功能  282

lpopen()  284

lpwrite()  285

lpcanon()  285

lpoutput()  287

lpstart()  288

lpint()  288

lpclose()  289

12.3  小结  289

第13章 电传终端  290

13.1  什么是电传终端  290

电传终端的接口  290

特殊文件  291

tty  结构体  292

maptab[]  295

partab[]  295

KL11/DL11  296

KL11/DL11设备驱动的规格  297

KL11/DL11设备驱动函数  298

13.2  终端的开启和关闭  298

klopen()  298

klclose()  300

wflushtty()  300

flushtty()  301

13.3  终端的设定  302

gtty()  302

stty()  302

sgtty()  303

klsgtty()  304

ttystty()  304

13.4  从终端输入文字  305

klrint()  306

ttyinput()  306

13.5  读取输入的数据  308

klread()  309

ttread()  309

canon()  310

13.6  向终端输出数据  313

klwrite()  314

ttwrite()  315

ttyoutput()  316

ttstart()  318

ttrstrt()  319

klxint()  320

13.7  小结  320

第VII  部分

启动系统  321

第14章 启动系统  322

14.1  启动的流程  322

start  323

main()  326

/etc/init  329

14.2  小结  330

附 录  参考资料等  331

A.1 参考文献、网站  331

A.2 pre  K&R  C  335

后记  337

索引  338

6c62c632f541412a5cf8cf11f89af092.png

  • 0
    点赞
  • 0
    评论
  • 0
    收藏
  • 一键三连
    一键三连
  • 扫一扫,分享海报

表情包
插入表情
评论将由博主筛选后显示,对所有人可见 | 还能输入1000个字符
相关推荐
前言 第一章 走进linux 1.1 GNU与Linux的成长 1.2 Linux的开发模式和运作机制 1.3走进Linux内核 1.3.1 Linux内核的特征 1.3.2 Linux内核本的变化 1.4 分析Linux内核的意义 1.4.1 开发适合自己的操作系统 1.4.2 开发高水平软件 1.4.3 有助于计算机科学的教学和科研 1.5 Linux内核结构 1.5.1 Linux内核在整个操系统中的位置 1.5.2 Linux内核的作用 1.5.3 Linux内核的抽象结构 1.6 Linux内核源代码 1.6.1 多本的内核源代码 1.6.2 Linux内核源代码的结构 1.6.3 从何处开始阅读源代码 1.7 Linux内核源代码分析工具 1.7.1 Linux超文本交叉代码检索工具 1.7.2 Windows平台下的源代码阅读工具Source Insight 第二章 Linux运行的硬件基础 2.1 i386的寄存器 2.1.1通用寄存器 2.1.2段寄存器 2.1.3状态和控制寄存器 2.1.4 系统地址寄存器 2.1.5 调试寄存器和测试寄存器 2.2 内存地址 2.3 段机制和描述符 2.3.1 段机制 2.3.2 描述符的概念 2.3.3系统段描述符 2.3.4 描述符表 2.3.5 选择符与描述符表寄存器 2.3.6 描述符投影寄存器 2.3.7 Linux中的段 2.4 分页机制 2.4.1 分页机构 2.4.2页面高速缓存 2.5 Linux中的分页机制 2.5.1 与页相关的数据结构及宏的定义 2.5.2 对页目录及页表的处理 2.6 Linux中的汇编语言 2.6.1 AT&T与Intel汇编语言的比较 2.6.2 AT&T汇编语言的相关知识 2.6.3 Gcc嵌入式汇编 2.6.4 Intel386汇编指令摘要 第三章中断机制 3.1 中断基本知识 3.1.1 中断向量 3.1.2 外设可屏蔽中断 3.1.3异常及非屏蔽中断 3.1.4中断描述符表 3.1.5 相关汇编指令 3.2中断描述符表的初始化 3.2. 1 外部中断向量的设置 3.2.2中断描述符表IDT的预初始化 3.2.3 中断向量表的最终初始化 3.3异常处理 3.3.1 在内核栈中保存寄存器的值 3.3.2 中断请求队列的初始化 3.3.3中断请求队列的数据结构 3.4 中断处理 3.4.1中断和异常处理的硬件处理 3.4.2 Linux对异常和中断的处理 3.4.3 与堆栈有关的常量、数据结构及宏 3.4.4 中断处理程序的执行 3.4.5 从中断返回 3.5中断的后半部分处理机制 3.5.1 为什么把中断分为两部分来处理 3.5.2 实现机制 3.5.3数据结构的定义 3.5.4 软中断、bh及tasklet的初始化 3.5.5后半部分的执行 3.5.6 把bh移植到tasklet 第四章 进程描述 4.1 进程和程序(Process and Program) 4.2 Linux中的进程概述 4.3 task_struct结构描述 4.4 task_struct结构在内存中的存放 4.4.1 进程内核栈 4.4.2 当前进程(current宏) 4.5 进程组织的方式 4.5.1哈希表 4.5.2双向循环链表 4.5.3 运行队列 4.5.4 等待队列 4.6 内核线程 4.7 进程的权能 4.8 内核同步 4.8.1信号量 4.8.2原子操作 4.8.3 自旋锁、读写自旋锁和大读者自旋锁 4.9 本章小节 第五章进程调度 5.1 Linux时间系统 5.1.1 时钟硬件 5.1.2 时钟运作机制 5.1.3 Linux时间基准 5.1.4 Linux的时间系统 5.2 时钟中断 5.2.1 时钟中断的产生 5.2.2.Linux实现时钟中断的全过程 5.3 Linux的调度程序-Schedule( ) 5.3.1 基本原理 5.3.2 Linux进程调度时机 5.3.3 进程调度的依据 5.3.4 进程可运行程度的衡量 5.3.5 进程调度的实现 5.4 进程切换 5.4.1 硬件支持 5.4.2 进程切换 第六章 Linux内存管理 6.1 Linux的内存管理概述 6.1.1 Linux虚拟内存的实现结构 6.1.2 内核空间和用户空间 6.1.3 虚拟内存实现机制间的关系 6.2 Linux内存管理的初始化 6.2.1 启用分页机制 6.2.2 物理内存的探测 6.2.3 物理内存的描述 6.2.4 页面管理机制的初步建立 6.2.5页表的建立 6.2.6内存管理区 6.3 内存的分配和回收 6.3.1 伙伴算法 6.3.2 物理页面的分配和释放 6.3.3 Slab分配机制 6.4 地址映射机制 6.4.1 描述虚拟空间的数据结构 6.4.2 进程的虚拟空间 6.4.3 内存映射 6.5 请页机制 6.5.1 页故障的产生 6.5.2 页错误的定位 6.5.3 进程地址空间中的缺页异常处理 6.5.4 请求调页 6.5.5 写时复制 6.6 交换机制 6.6.1 交换的基本原理 6.6.2 页面交换守护进程kswapd 6.6.3 交换空间的数据结构 6.6.4 交换空间的应用 6.7 缓存和刷新机制 6.7.1 Linux使用的缓存 6.7.2 缓冲区高速缓存 6.7.3 翻译后援存储器(TLB) 6.7.4 刷新机制 6.8 进程的创建和执行 6.8.1 进程的创建 6.8.2 程序执行 6.8.3 执行函数 第七章 进程间通信 7.1 管道 7.1.1 Linux管道的实现机制 7.1.2 管道的应用 7.1.3 命名管道(FIFO) 7.2 信号(signal) 7.2.1 信号种类 7.2.2 信号掩码 7.2.3 系统调用 7.2.4 典型系统调用的实现 7.2.5 进程与信号的关系 7.2.6 信号举例 7.3 System V 的IPC机制 7.3.1 信号量 7.3.2 消息队列 7.3.3 共享内存 第八章 虚拟文件系统 8.1 概述 8.2 VFS中的数据结构 8.2.1 超级块 8.2.2 VFS的索引节点 8.2.3 目录项对象 8.2.4 与进程相关的文件结构 8.2.5 主要数据结构间的关系 8.2.6 有关操作的数据结构 8.3 高速缓存 8.3.1 块高速缓存 8.3.2 索引节点高速缓存 8.3.3 目录高速缓存 8.4 文件系统的注册、安装与拆卸 8.4.1 文件系统的注册 8.4.2 文件系统的安装 8.4.3 文件系统的卸载 8.5 限额机制 8.6 具体文件系统举例 8.6.1 管道文件系统pipefs 8.6.2 磁盘文件系统BFS 8.7 文件系统的系统调用 8.7.1 open 系统调用 8.7.2 read 系统调用 8.7.3 fcntl 系统调用 8 .8 Linux2.4文件系统的移植问题 第九章 Ext2文件系统 9.1 基本概念 9.2 Ext2的磁盘布局和数据结构 9.2.1 Ext2的磁盘布局 9.2.2 Ext2的超级块 9.2.3 Ext2的索引节点 9.2.4 组描述符 9.2.5 位图 9.2.6 索引节点表及实例分析 9.2.7 Ext2的目录项及文件的定位 9.3 文件的访问权限和安全 9.4 链接文件 9.5 分配策略 9.5.1 数据块寻址 9.5.2 文件的洞 9.5.3 分配一个数据块 第十章 模块机制 10.1 概述 10.1.1 什么是模块 10.1.2 为什么要使用模块? 10.2 实现机制 10.2.1 数据结构 10.2.2 实现机制的分析 10.3 模块的装入和卸载 10.3.1 实现机制 10.3.2 如何插入和卸载模块 10.4 内核本 10.4.1 内核本与模块本的兼容性 10.4.2 从本2.0到2.2内核API的变化 10.4.3 把内核2.2移植到内核2.4 10.5 编写内核模块 10.5.1 简单内核模块的编写 10.5.2 内核模块的Makefiles文件 10.5.3 内核模块的多个文件 第十一章 设备驱动程序 11.1 概述 11.1.1 I/O软件 11.1.2 设备驱动程序 11.2 设备驱动基础 11.2.1 I/O端口 11.2.2 I/O接口及设备控制器 11.2.3 设备文件 11.2.4 VFS对设备文件的处理 11.2.5 中断处理 11.2.6 驱动DMA工作 11.2.7 I/O 空间的映射 11.2.8 设备驱动程序框架 11.3 块设备驱动程序 11.3.1 块设备驱动程序的注册 11.3.2 块设备基于缓冲区的数据交换 11.3.3 块设备驱动程序的几个函数 11.3.4 RAM 盘驱动程序的实现 11.3.5 硬盘驱动程序的实现 11.4 字符设备驱动程序 11.4.1 简单字符设备驱动程序 11.4.2 字符设备驱动程序的注册 11.4.3 一个字符设备驱动程序的实例 11.4.4 驱动程序的编译与装载 第十二章 网络 12.1 概述 12.2 网络协议 12.2.1 网络参考模型 12.2.2 TCP/IP 协议工作原理及数据流 12.2.3 Internet 协议 12.2.4 TCP协议 12.3 套接字(socket) 12.3.1 套接字在网络中的地位和作用 12.3.2 套接字接口的种类 12.3.3 套接字的工作原理 12.3.4 socket 的通信过程 12.3.5 socket为用户提供的系统调用 12.4 套接字缓冲区(sk_buff) 12.4.1 套接字缓冲区的特点 12.4.2 套接字缓冲区操作基本原理 12.4.3 sk_buff数据结构的核心内容 12.4.4 套接字缓冲区提供的函数 12.4.5 套接字缓冲区的上层支持例程 12.5 网络设备接口 12.5.1 基本结构 12.5.2 命名规则 12.5.3 设备注册 12.5.4 网络设备数据结构 12.5.5 支持函数 第十三章 启动系统 13.1 初始化流程 13.1.1 系统加电或复位 13.1.2 BIOS启动 13.1.3 Boot Loader 13.1.4 操作系统的初始化 13.2 初始化的任务 13.2.1 处理器对初始化的影响 13.2.2 其他硬件设备对处理器的影响 13.3 Linux 的Boot Loarder 13.3.1 软盘的结构 13.3.2 硬盘的结构 13.3.3 Boot Loader 13.3.4 LILO 13.3.5 LILO的运行分析 13.4 进入操作系统 13.4.1 Setup.S 13.4.2 Head.S 13.5 main.c中的初始化 13.6 建立init进程 13.6.1 init进程的建立 13.6.2 启动所需的Shell脚本文件 附录: 1 Linux 2.4内核API 2.1 驱动程序的基本函数 2.2 双向循环链表的操作 2.3 基本C库函数 2.4 Linux内存管理中Slab缓冲区 2.5 Linux中的VFS 2.6 Linux的连网 2.7 网络设备支持 2.8 模块支持 2.9 硬件接口 2.10 块设备 2.11 USB 设备
目 录 献辞 致谢 序(一) 序(二) 历史注记 上篇 UNIX操作系统本6源代码 UNIX操作系统过程分类索引 3 UNIX操作系统文件及过程 5 UNIX操作系统定义的符号列表 7 UNIX操作系统源代码交叉引用列表 9 第一部分 初始化、进程初始化 25 第二部分 陷入、中断、系统调用和 进程管理 75 第三部分 程序交换、基本输入/输出、 块设备 109 第四部分 文件和目录、文件系统、管道 133 第五部分 面向字符的特殊文件 181 下篇 莱昂氏UNIX源代码分析 前言 207 第1章 绪论 209 1.1 UNIX操作系统 209 1.2 公用程序 209 1.3 其他文档 210 1.4 UNIX程序员手册 210 1.5 UNIX文档 211 1.6 UNIX操作系统源代码 211 1.7 源代码中各部分 212 1.8 源代码文件 212 1.9 分析的使用 212 1.10 对程序设计水平的一条注释 212 第2章 基础知识 214 2.1 处理机 214 2.2 处理机状态字 214 2.3 通用寄存器 214 2.4 指令集 215 2.5 寻址方式 216 2.5.1 寄存器方式 217 2.5.2 寄存器延迟方式 217 2.5.3 自动增1方式 217 2.5.4 自动减1方式 217 2.5.5 变址方式 217 2.5.6 立即方式 218 2.5.7 相对方式 218 2.6 UNIX汇编程序 219 2.7 存储管理 219 2.8 段寄存器 220 2.9 页说明寄存器 220 2.10 存储分配 220 2.11 状态寄存器 221 2.12 “i”和“d”空间 221 2.13 启动条件 221 2.14 专用设备寄存器 221 第3章 阅读“C”程序 222 3.1 某些选出的例子 222 3.2 例1 222 3.3 例2 223 3.4 例3 223 3.5 例4 225 3.6 例5 225 3.7 例6 227 3.8 例7 227 3.9 例8 228 3.10 例9 228 3.11 例10 229 3.12 例11 229 3.13 例12 230 3.14 例13 230 3.15 例14 231 3.16 例15 231 3.17 例16 232 3.18 例17 233 第4章 概述 235 4.1 变量分配 235 4.2 全局变量 235 4.3 “C”预处理程序 235 4.4 第一部分 236 4.4.1 第1组“.h”文件 236 4.4.2 汇编语言文件 237 4.4.3 在第一部分中的其他文件 237 4.5 第二部分 237 4.6 第三部分 238 4.7 第四部分 238 4.8 第五部分 239 第一部分 初始化、进程初始化 第5章 两个文件 241 5.1 文件malloc.c 241 5.1.1 列表维护规则 241 5.1.2 malloc(2528) 242 5.1.3 mfree(2556) 243 5.1.4 结论 244 5.2 文件prf.c 244 5.2.1 printf(2340) 244 5.2.2 printn(2369) 245 5.2.3 putchar(2386) 246 5.2.4 panic(2419) 247 5.2.5 prdev(2433)、deverror(2447) 247 5.3 包的文件 247 第6章 系统初启 249 6.1 操作员的动作 249 6.2 start(0612) 249 6.3 main(1550) 251 6.4 进程 252 6.5 proc〔0〕的初始化 252 6.6 sched(1940) 253 6.7 sleep(2066) 253 6.8 swtch(2178) 253 6.9 再回到main 254 第7章 进程 256 7.1 进程映像 256 7.2 proc结构(0358) 257 7.3 user结构(0413) 257 7.4 每个进程数据区 258 7.5 段 258 7.6 映像的执行 258 7.7 核心态执行 259 7.8 用户态执行 259 7.9 一个实例 259 7.10 设置段寄存器 260 7.11 estabur(1650) 260 7.12 sureg(1739) 261 7.13 newproc(1826) 261 第8章 进程管理 263 8.1 进程切换 263 8.2 中断 263 8.3 程序交换 263 8.4 作业 264 8.5 汇编语言过程 264 8.6 savu(0725) 264 8.7 retu(0740) 264 8.8 aretu(0734) 264 8.9 swtch(2178) 265 8.10 setpri(2156) 265 8.11 sleep(2066) 266 8.12 wakeup(2133) 266 8.13 setrun(2134) 266 8.14 expand(2268) 267 8.15 再回到swtch 267 8.16 临界区 268 第二部分 陷入、中断、系统调用 和进程管理 第9章 硬件中断和陷入 269 9.1 硬件中断 269 9.2 中断矢量 270 9.3 中断处理程序 270 9.4 优先级 270 9.5 中断优先级 271 9.6 中断处理程序的规则 271 9.7 陷入 272 9.8 汇编语言trap 272 9.9 返回 273 第10章 汇编语言“trap”例程 274 10.1 陷入和中断源 274 10.2 fuibyte(0814)与fuiword(0844) 274 10.3 中断 275 10.4 call(0776) 275 10.5 用户程序陷入 276 10.6 核心态栈 277 第11章 时钟中断 279 11.1 clock(3725) 279 11.2 timeout(3845) 281 第12章 陷入与系统调用 282 12.1 trap(2693) 282 12.2 核心态陷入 282 12.3 用户态陷入 283 12.4 系统调用 284 12.5 系统调用处理程序 285 12.6 文件sys1.c 285 12.6.1 exec(3020) 285 12.6.2 fork(3322) 286 12.6.3 sbreak(3354) 286 12.7 文件sys2.c和sys3.c 287 12.8 文件sys4.c 287 第13章 软件中断 288 13.1 设置期望动作 288 13.2 对进程造成中断 288 13.3 作用 289 13.4 跟踪 289 13.5 过程 289 13.5.1 期望动作的设置 289 13.5.2 造成软件中断 289 13.5.3 作用 289 13.5.4 跟踪 290 13.6 ssig(3614) 290 13.7 kill(3630) 290 13.8 signal(3949) 290 13.9 psignal(3963) 291 13.10 issig(3991) 291 13.11 psig(4043) 291 13.12 core(4094) 292 13.13 grow(4136) 292 13.14 exit(3219) 292 13.15 rexit(3205) 293 13.16 wait(3270) 293 13.17 跟踪 293 13.18 stop(4016) 294 13.19 wait(3270)(继续) 294 13.20 ptrace(4164) 295 13.21 procxmt(4204) 295 第三部分 程序交换、基本输入 /输出、块设备 第14章 程序交换 297 14.1 正文段 297 14.2 sched(1940) 298 14.3 xswap(4368) 299 14.4 xalloc(4433) 299 14.5 xfree(4398) 300 第15章 基本输入/输出介绍 301 15.1 buf.h文件 301 15.2 devtab(4551) 301 15.3 conf.h文件 301 15.4 conf.c文件 302 15.5 系统生成 302 15.6 swap(5196) 302 15.7 竞态条件 303 15.8 可重入 304 15.9 继续分析“u.u_ssav” 304 第16章 RK磁盘驱动器 305 16.1 控制状态寄存器RKCS 306 16.2 字计数寄存器RKWC 306 16.3 磁盘地址寄存器RKDA 306 16.4 rk.c文件 306 16.5 rkstrategy(5389) 306 16.6 rkaddr(5420) 307 16.7 devstart(5096) 307 16.8 rkintr(5451) 307 16.9 iodone(5018) 308 第17章 缓存处理 309 17.1 标志 309 17.2 一个类超高速缓存存储 309 17.3 clrbuf(5038) 309 17.4 incore(4899) 310 17.5 getblk(4921) 310 17.6 brelse(4869) 310 17.7 binit(5055) 311 17.8 bread(4754) 312 17.9 breada(4773) 312 17.10 bwrite(4809) 312 17.11 bawrite(4856) 313 17.12 bdwrite(4836) 313 17.13 bflush(5229) 313 17.14 physio(5259) 313 第四部分 文件和目录、文件 系统、管道 第18章 文件存取和控制 315 18.1 源代码第四部分 315 18.2 文件特征 315 18.3 系统调用 316 18.4 控制表 316 18.4.1 file(5507) 316 18.4.2 inode(5659) 316 18.5 要求专用的资源 317 18.6 打开一个文件 317 18.7 creat(5781) 317 18.8 open1(5804) 317 18.9 open(5763) 318 18.10 再回到open1 318 18.11 close(5846) 318 18.12 closef(6643) 319 18.13 iput(7344) 319 18.14 删除文件 319 18.15 读和写文件 319 18.16 rdwr(5731) 320 18.17 readi(6221) 321 18.18 writei(6276) 322 18.19 iomove(6364) 322 18.20 bmap(6415) 322 18.21 剩余部分 322 第19章 文件目录和目录文件 323 19.1 文件名 323 19.2 目录数据结构 323 19.3 目录文件 323 19.4 namei(7518) 324 19.5 一些注释 325 19.6 link(5909) 326 19.7 wdir(7477) 327 19.8 maknode(7455) 327 19.9 unlink(3510) 327 19.10 mknod(5952) 327 19.11 access(6746) 328 第20章 文件系统 329 20.1 超级块(5561) 329 20.2 mount表(0272) 329 20.3 iinit(6922) 330 20.4 安装 330 20.5 smount(6086) 330 20.6 注释 331 20.7 iget(7276) 331 20.8 getfs(7167) 332 20.9 update(7201) 332 20.10 sumount(6144) 333 20.11 资源分配 333 20.12 alloc(6956) 334 20.13 itrunc(7414) 334 20.14 free(7000) 335 20.15 iput(7344) 335 20.16 ifree(7134) 335 20.17 iupdat(7374) 335 第21章 管道 337 21.1 pipe(7723) 337 21.2 readp(7758) 337 21.3 writep(7805) 338 21.4 plock(7862) 338 21.5 prele(7882) 338 第五部分 面向字符的特殊文件 第22章 面向字符的特殊文件 339 22.1 LP11行式打印机驱动程序 339 22.2 lpopen(8850) 340 22.3 注释 340 22.4 lpoutput(8986) 340 22.5 lpstart(8967) 341 22.6 lpint(8976) 341 22.7 lpwrite(8870) 342 22.8 lpclose(8863) 342 22.9 讨论 342 22.10 lpcanon(8879) 342 22.11 对读者的建议 343 22.12 PC11纸带阅读机/穿孔机驱动 程序 344 第23章 字符处理 345 23.1 cinit(8234) 346 23.2 getc(0930) 346 23.3 putc(0967) 347 23.4 字符集 347 23.5 图形字符 348 23.6 UNIX惯例 349 23.7 maptab(8117) 349 23.8 partab(7947) 349 第24章 交互式终端 351 24.1 接口 351 24.2 tty结构(7926) 351 24.3 注释 352 24.4 初始化 352 24.5 stty(8183) 352 24.6 sgtty(8201) 353 24.7 klsgtty(8090) 353 24.8 ttystty(8577) 353 24.9 DL11/KL11终端设备处理程序 353 24.10 设备寄存器 354 24.11 接收器状态寄存器 354 24.12 接收器数据缓存寄存器 354 24.13 发送器状态寄存器 354 24.14 发送器数据缓存寄存器 354 24.15 单总线地址 354 24.16 软件方面的考虑 355 24.17 中断矢量地址 355 24.18 源代码 355 24.19 klopen(8023) 355 24.20 klclose(8055) 356 24.21 klxint(8070) 356 24.22 klrint(8078) 356 第25章 tty.c文件 357 25.1 flushtty(8252) 357 25.2 wflushtty(8217) 357 25.3 字符输入 358 25.3.1 ttread(8535) 358
内容简介 · · · · · · 为什么要阅读内核源代码 ● 对计算机系统的全貌有更深入的了解 ● 对学到的算法和思路举一反三 ● 加深对操作系统的理解 ● 提升自身的技术水平 为什么选择UNIX V6? ● 代码行数约为1 万行 ● 有充实的资料可参考 ● 网罗了操作系统的基本功能 ● 简化的设计 ● 便于读者对系统有完整的了解 ● 有模拟器可供参考 本书是一本Unix内核源代码的阅读指南。作者结合UNIX V6已公开的相关文档,对其内核源码进行详细剖析,旨在让读者更深入地理解进程、中断、块I/O系统、文件系统、字符I/O系统、启动系统等操作系统的基本原理。 本书适合操作系统的初中级学习者阅读,特别适合通过大学课程和其他入门书对操作系统有所了解,但是对具体细节缺乏深入理解的读者,以及那些对操作系统的具体实现有兴趣的读者。 作者简介 · · · · · · 作者简介: 青柳隆宏 日本资深程序员,现在硅谷从事计算机处理芯片的设计工作。曾设计了超级计算机“京”的L1缓存,该计算机在2011年排名世界Top 500超级计算机的第1位,也是人类历史上第一台计算能力跨越1亿亿次每秒的计算系统。作者Email:v6@gachapin.jp。 译者简介: 殷中翔 日本国立九州大学系统信息专业硕士学位。具有十余年软件开发经验,现主要从事企业Web系统服务器端的开发及维护工作。 黄炎 同济大学本科毕业,现供职于上海爱可生,从事数据库高可用软件开发。大学有幸师从陈闳中教授,一窥UNIX V6代码的门径。 周金杰 同济大学硕士,法国国立高等电信学院(TELECOM PARIS)硕士。曾通读并研究UNIX V6源代码,同时参与了面向对象操作系统的移植以及操作系统调试器的开发工作,熟悉系统底层相关的技术知识。崇尚设计,享受编程给生活带来的乐趣。
©️2020 CSDN 皮肤主题: 数字20 设计师:CSDN官方博客 返回首页
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、C币套餐、付费专栏及课程。

余额充值