一个64位操作系统的设计与实现 作者:田宇 出版时间:2018.5内容简介 本书讲述了一个64位多核操作系统的自制过程。此操作系统自制过程是先从虚拟平台构筑起一个基础框架,随后再将基础框架移植到物理平台中进行升级、完善与优化。为了凸显64位多核操作系统的特点,物理平台选用搭载着Intel Core-i7处理器的笔记本电脑。与此同时,本书还将Linux内核的源码精髓、诸多官方白皮书以及多款常用协议浓缩于其中,可使读者在读完本书后能够学以致用,进而达到理论联系实际的目的。全书共分为16章。第1~2章讲述了操作系统的基础概念和开发操作系统需要掌握的知识;第3~5章在虚拟平台下快速构建起一个操作系统模型;第6~16章将在物理平台下对操作系统模型做进一步升级、优化和完善。本书既适合在校学习理论知识的初学者,又适合在职工作的软件工程师或有一定基础的业余爱好者。目录第 一部分 操作系统相关知识介绍及环境搭建第 1章 操作系统概述 41.1 什么是操作系统 41.2 操作系统的组成结构 41.3 编写操作系统需要的知识 71.4 本书操作系统简介 8第 2章 环境搭建及基础知识 92.1 虚拟机及开发系统平台介绍 92.1.1 VMware的安装 92.1.2 编译环境CentOS 6 102.1.3 Bochs虚拟机 112.2 汇编语言 142.2.1 AT&T汇编语言格式与Intel汇编语言格式 142.2.2 NASM编译器 162.2.3 使用汇编语言调用C语言的函数 162.3 C语言 192.3.1 GNU C内嵌汇编语言 202.3.2 GNU C语言对标准C语言的扩展 23第二部分 初级篇第3章 BootLoader引导启动程序 303.1 Boot引导程序 303.1.1 BIOS引导原理 313.1.2 写一个Boot引导程序 323.1.3 创建虚拟软盘镜像文件 363.1.4 在Bochs上运行我们的Boot程序 383.1.5 加载Loader到内存 403.1.6 从Boot跳转到Loader程序 523.2 Loader引导加载程序 543.2.1 Loader原理 543.2.2 写一个Loader程序 553.2.3 从实模式进入保护模式再到IA-32e模式 653.2.4 从Loader跳转到内核程序 75第4章 内核层 784.1 内核执行头程序 784.1.1 什么是内核执行头程序 784.1.2 写一个内核执行头程序 794.2 内核主程序 834.3 屏幕显示 854.3.1 在屏幕上显示色彩 864.3.2 在屏幕上显示log 884.4 系统异常 1004.4.1 异常的分类 1014.4.2 系统异常处理(一) 1024.4.3 系统异常处理(二) 1094.5 初级内存管理单元 1214.5.1 获得物理内存信息 1214.5.2 计算可用物理内存页数 1234.5.3 分配可用物理内存页 1264.6 中断处理 1424.6.1 8259A PIC 1424.6.2 触发中断 1484.7 键盘驱动 1524.7.1 简述键盘功能 1524.7.2 实现键盘中断捕获函数 1544.8 进程管理 1554.8.1 简述进程管理模块 1554.8.2 PCB 1564.8.3 init进程 163第5章 应用层 1715.1 跳转到应用层 1715.2 实现系统调用API 1805.3 实现一个系统调用处理函数 185第三部分 高级篇第6章 处理器体系结构 1906.1 基础功能与新特性 1906.1.1 运行模式 1906.1.2 通用寄存器 1916.1.3 CPUID指令 1926.1.4 标志寄存器EFLAGS 1936.1.5 控制寄存器 1956.1.6 MSR寄存器组 1996.2 地址空间 1996.2.1 虚拟地址 2006.2.2 物理地址 2006.3 实模式 2006.3.1 实模式概述 2016.3.2 实模式的段寻址方式 2016.3.3 实模式的中断向量表 2016.4 保护模式 2026.4.1 保护模式概述 2026.4.2 保护模式的段管理机制 2066.4.3 保护模式的中断/异常处理机制 2146.4.4 保护模式的页管理机制 2176.4.5 保护模式的地址转换过程 2246.5 IA-32e模式 2266.5.1 IA-32e模式概述 2266.5.2 IA-32e模式的段管理机制 2286.5.3 IA-32e模式的中断/异常处理机制 2346.5.4 IA-32e模式的页管理机制 2346.5.5 IA-32e模式的地址转换过程 237第7章 完善BootLoader功能 2387.1 实模式的寻址瓶颈 2387.1.1 错综复杂的1 MB物理地址空间 2387.1.2 突破1 MB物理内存瓶颈 2397.1.3 实模式下的4 GB线性地址寻址 2407.2 获取物理地址空间信息 2407.3 操作系统引导加载阶段的内存空间划分 2427.4 U盘启动 2447.4.1 USB-FDD、USB-ZIP和USB-HDD启动模式的简介 2447.4.2 将Boot引导程序移植到U盘中启动 2517.5 在物理平台上启动操作系统 2557.6 细说VBE功能的实现 2617.6.1 VBE规范概述 2617.6.2 获取物理平台的VBE相关信息 2727.6.3 设置显示模式 279第8章 内核主程序 2828.1 内核主程序功能概述 2828.2 操作系统的Makefile编译脚本 2828.3 操作系统的kernel.lds链接脚本 2868.4 操作系统的线性地址空间划分 2898.5 获得处理器的固件信息 290第9章 高级内存管理单元 2979.1 SLAB内存池 2979.1.1 SLAB内存池概述及相关结构体定义 2989.1.2 SLAB内存池的创建与销毁 2999.1.3 SLAB内存池中对象的分配与回收 3029.2 基于SLAB内存池技术的通用内存管理单元 3089.2.1 通用内存管理单元的初始化函数slab_init 3089.2.2 通用内存的分配函数kmalloc 3129.2.3 通用内存的回收函数kfree 3179.3 调整物理页管理功能 3219.3.1 内存管理单元结构及相关函数调整 3219.3.2 调整alloc_pages函数 3239.3.3 创建free_pages函数 3279.4 页表初始化 3309.4.1 页表重新初始化 3319.4.2 VBE帧缓存区地址重映射 334第 10章 高级中断处理单元 33710.1 APIC概述 33710.2 Local APIC 33810.2.1 Local APIC的基础信息 33810.2.2 Local APIC整体结构及各功能描述 34410.3 I/O APIC 35210.3.1 I/O APIC控制器的基础信息 35310.3.2 I/O APIC整体结构及各引脚功能 35610.4 中断控制器的模式选择与初始化 35810.4.1 中断模式 35910.4.2 Local APIC控制器的初始化 36210.4.3 I/O APIC控制器的初始化 36810.5 高级中断处理功能 37510.5.1 Linux的中断处理机制概述 37510.5.2 实现中断上半部处理功能 377第 11章 设备驱动程序 38211.1 键盘和鼠标驱动程序 38211.1.1 键盘和鼠标控制器 38211.1.2 完善键盘驱动 38911.1.3 实现鼠标驱动 39811.2 硬盘驱动程序 40311.2.1 硬盘设备初探 40311.2.2 完善硬盘驱动程序 418第 12章 进程管理 42812.1 进程管理单元功能概述 42812.2 多核处理器 42912.2.1 超线程技术与多核技术概述 42912.2.2 多核处理器间的IPI通信机制介绍 43412.2.3 让我们的系统支持多核 43712.3 进程调度器 46412.3.1 Linux进程调度器简介 46512.3.2 墙上时钟与定时器 46812.3.3 内核定时器 47912.3.4 实现进程调度功能 48612.4 内核同步方法 49812.4.1 原子变量 49812.4.2 信号量 49912.4.3 完善自旋锁 50112.5 完善进程管理单元 50312.5.1 完善PCB与处理器运行环境 50312.5.2 完善进程调度器和AP处理器引导程序 50812.5.3 关于线程 514第 13章 文件系统 51613.1 文件系统概述 51613.2 解析FAT32文件系统 51713.2.1 FAT32文件系统简介 51713.2.2 通过实例深入解析FAT32文件系统 52313.2.3 实现基于路径名的文件系统检索功能 53213.3 虚拟文件系统 55213.3.1 Linux VFS简介 55213.3.2 实现VFS 554第 14章 系统调用API库 56614.1 系统调用API结构 56614.2 基于POSIX规范实现系统调用API库 56714.2.1 POSIX规范下的系统调用API简介 56714.2.2 升级系统调用模块 56814.2.3 基础文件操作的系统调用API实现 57414.2.4 进程创建的系统调用API实现 59914.2.5 内存管理的基础系统调用API实现 618第 15章 Shell命令解析器及命令 62615.1 Shell命令解析器 62615.1.1 Shell命令解析器概述 62615.1.2 实现Shell命令解析器 62715.2 基础命令 64115.2.1 重启命令reboot 64115.2.2 工作目录切换命令cd 64215.2.3 目录内容显示命令ls 64515.2.4 文件查看命令cat 65415.2.5 程序执行命令exec 655第 16章 一个彩蛋 665附录 术语表 676参考资料 679 上一篇: 拆穿数据胡扯 [(美)卡尔 伯格斯特龙] 下一篇: 数据驱动 通过用户数据和人工智能重塑现代营销