书籍详情

精通Linux内核开发

精通Linux内核开发

作者:[印度] 拉古·巴拉德瓦杰 著,白浩文,文平波 译

出版社:人民邮电出版社

出版时间:2021-09-01

ISBN:9787115566041

定价:¥89.90

购买这本书可以去
内容简介
  《精通Linux内核开发》介绍了Linux内核、内核的内部编排与设计,以及内核的各个核心子系统等知识。本书分为11章,具体内容包括:进程、地址空间和线程;进程调度器;信号管理;内存管理和分配器;文件系统和文件I/O;进程间通信;虚拟内存管理;内核同步和锁;中断和延迟工作;时钟和时间管理;模块管理。《精通Linux内核开发》篇幅短小精悍,通过大量代码辅助介绍Linux内核的相关开发工作。通过学习本书,读者可以深入理解Linux内核的核心服务与机制,了解这个集中了集体智慧的Linux内核在保持其良好设计的同时,是如何保持其优雅特性的。《精通Linux内核开发》适合Linux内核开发人员、底层开发人员阅读,还适合希望深入理解Linux内核及其各组成部分的系统开发人员学习。高校软件工程专业的学生也可以将本书当作了解Linux内核设计原理的参考指南。
作者简介
  Raghu Bharadwaj是Linux内核领域的顾问、贡献者兼企业培训师,具有近20年的从业经验。他是一个狂热的内核爱好者,自20世纪90年代后期以来就一直密切关注Linux内核的发展。他还是TECH VEDA公司的创办人,该公司以技术支持、内核贡献和培训的形式,专门从事与Linux内核有关的工程和技能服务。他对Linux有独到的理解和阐述,而且因为对软件设计和操作系统架构的狂热而得到了客户的特别关注。在向从事Linux内核、Linux驱动以及嵌入式Linux等工作的工程团队提供定制的且面向解决方案的培训计划这一方面,Raghu颇有心得。他所服务的客户有Xilinx(赛灵思)、通用、佳能、富士通、UTC(美国联合技术公司)、TCS(印度塔塔咨询服务公司)、博通、Sasken(印度萨斯肯通讯技术公司)、高通、Cognizant(高知特信息技术公司)、意法半导体、Stryker(史赛克)和Lattice(莱迪斯)半导体等公司。
目录
第 1章 进程、地址空间和线程\t1
1.1 进程\t1
1.1.1 所谓地址空间的错觉\t2
1.1.2 内核空间和用户空间\t3
1.2 进程描述符\t4
1.2.1 进程属性:关键元素\t5
1.2.2 进程关系:关键元素\t8
1.2.3 调度属性:关键元素\t9
1.2.4 进程限制:关键元素\t9
1.2.5 文件描述符表:关键元素\t11
1.2.6 信号描述符:关键元素\t11
1.3 内核栈\t12
1.4 栈溢出问题\t16
1.5 进程创建\t17
1.5.1 fork()\t17
1.5.2 写时复制(COW)\t18
1.5.3 exec\t18
1.5.4 vfork()\t19
1.5.5 Linux线程支持\t19
1.6 内核线程\t21
1.7 进程状态和终止\t29
1.7.1 wait\t29
1.7.2 exit\t29
1.8 命名空间和cgroup\t30
1.8.1 挂载命名空间\t30
1.8.2 UTS命名空间\t31
1.8.3 IPC命名空间\t31
1.8.4 PID命名空间\t31
1.8.5 网络命名空间\t31
1.8.6 用户命名空间\t31
1.8.7 cgroup命名空间\t32
1.8.8 控制组(cgroup)\t32
1.9 小结\t33
第 2章 进程调度器\t34
2.1 进程调度器\t34
2.2 Linux进程调度器设计\t35
2.3 运行队列\t39
2.4 调度入口\t41
2.5 进程优先级\t43
2.6 调度类\t44
2.7 完全公平调度类(CFS)\t44
2.7.1 CFS计算优先级和时间片\t45
2.7.2 CFS运行队列\t45
2.7.3 组调度\t46
2.7.4 多核系统下的调度实体\t47
2.7.5 调度策略\t48
2.8 实时调度类\t49
2.8.1 FIFO\t49
2.8.2 RR\t49
2.8.3 实时组调度\t50
2.8.4 deadline调度类(零散任务模型的deadline调度)\t50
2.9 调度相关的系统调用\t51
2.10 进程抢占\t53
2.11 小结\t54
第3章 信号管理\t55
3.1 信号\t55
3.2 信号管理API\t58
3.2.1 程序发出信号\t61
3.2.2 等待排队信号\t62
3.3 信号数据结构\t62
3.3.1 信号描述符\t63
3.3.2 被阻塞和挂起的队列\t64
3.3.3 信号处理程序描述符\t65
3.4 信号生成和传递\t66
3.4.1 信号生成调用\t66
3.4.2 信号传递\t69
3.4.3 执行用户模式处理程序\t74
3.4.4 设置用户模式处理程序帧\t75
3.5 重新启动被中断的系统调用\t78
3.6 小结\t80
第4章 内存管理和分配器\t81
4.1 初始化操作\t81
4.2 区域和节点\t87
4.2.1 内存区域\t87
4.2.2 内存节点\t89
4.3 内存分配\t97
4.3.1 页帧分配器\t98
4.3.2 GFP掩码\t105
4.3.3 slab分配器\t110
4.3.4 vmalloc\t122
4.3.5 连续内存分配器(CMA)\t124
4.4 小结\t125
第5章 文件系统和文件I/O\t126
5.1 文件系统—高层视图\t126
5.1.1 元数据\t127
5.1.2 操作\t132
5.1.3 附加功能\t134
5.2 Linux内核中的文件系统\t135
5.3 通用文件系统接口\t138
5.4 特殊文件系统\t153
5.4.1 procfs\t154
5.4.2 sysfs\t156
5.4.3 debugfs\t157
5.5 小结\t157
第6章 进程间通信\t158
6.1 管道和FIFO\t158
6.2 消息队列\t163
6.2.1 System V消息队列\t163
6.2.2 POSIX消息队列\t165
6.3 共享内存\t167
6.3.1 System V共享内存\t167
6.3.2 POSIX共享内存\t170
6.4 信号量\t171
6.4.1 System V信号量\t171
6.4.2 POSIX信号量\t173
6.5 小结\t174
第7章 虚拟内存管理\t175
7.1 进程地址空间\t175
7.1.1 进程内存描述符\t177
7.1.2 页表\t193
7.2 小结\t195
第8章 内核同步和锁\t196
8.1 原子操作\t196
8.1.1 原子整数操作\t197
8.1.2 原子位操作\t198
8.2 排斥锁\t199
8.2.1 自旋锁\t199
8.2.2 互斥锁\t207
8.2.3 信号量\t217
8.2.4 顺序锁\t221
8.2.5 完成锁\t223
8.3 小结\t226
第9章 中断和延迟工作\t227
9.1 中断信号和向量\t227
9.2 可编程中断控制器\t229
9.2.1 中断控制器操作\t230
9.2.2 IRQ描述符表\t232
9.3 高级中断管理接口\t235
9.3.1 注册一个中断处理程序\t235
9.3.2 注销一个中断处理程序\t237
9.3.3 线程化中断处理程序\t237
9.3.4 控制接口\t240
9.3.5 中断栈\t241
9.4 延迟工作\t241
9.4.1 softirq\t242
9.4.2 tasklet\t244
9.4.3 工作队列\t248
9.5 小结\t252
第 10章 时钟和时间管理\t253
10.1 时间表示\t253
10.2 硬件抽象\t257
10.3 Linux计时数据结构体、宏以及辅助函数\t260
10.3.1 jiffies\t260
10.3.2 timeval和timespec\t262
10.3.3 跟踪和维护时间\t264
10.3.4 节拍和中断处理\t265
10.3.5 节拍设备\t267
10.4 软件定时器和延迟函数\t267
10.4.1 动态定时器\t268
10.4.2 带有动态定时器的竞争条件\t270
10.4.3 动态定时器处理\t271
10.4.4 延迟函数\t271
10.5 POSIX时钟\t272
10.6 小结\t273
第 11章 模块管理\t274
11.1 内核模块\t274
11.1.1 LKM的要素\t274
11.1.2 加载和卸载操作\t277
11.2 小结\t288
猜您喜欢

读书导航