操作系统实验报告
课程名称
操作系统
课程编号
0906553
实验项目名称
操作系统的启动
学号
年级
姓名
专业
计算机科学与技术
学生所在院
计算机科学与技术学院
指导老师
实验室名称
哈尔滨工程大学
计算机科学与技术学院
一.实验概述
实验名称:操作系统的启动
实验目的:
跟踪调试EOS在PC机上从加电复位到成功后启动的全过程,了解操作系统的启动过程;
查看EOS启动后的状态和行为,理解操作系统启动后的工作方式。
实验类型:验证,设计
实验内容:
准备实验,启动OS Lab,新建一个EOS Kernel项目;
调试EOS操作系统的启动过程
使用Bochs作为远程目标机
调试BIOS程序
调试软盘引导扇区程序
调试加载程序
调试内核
查看EOS启动后的状态和行为
二.实验环境
操作系统:windows XP
编译器:Tevalaton OS Lab
语言:C++
三.实验过程
1.设计思路和流程图:
CPU从默认位置执行BIOS的开机自检和初始化程序之后,
CPU从默认位置执行BIOS的开机自检和初始化程序之后,BIOS将软盘引导扇区加载到0x7C00并执行
软盘引导扇区中的Boot程序开始执行
软盘引导扇区中的Boot程序开始执行,将软盘根目录中的Loader程序文件Loader.bin加载到0x1000并执行
Kernel
Kernel.dll开始执行,初始化EOS内核,EOS启动完毕
Loader程序开始执行
Loader程序开始执行,先加载Kernel.dll,然后启动保护模式和分页机制,最后调到Kernel.dll的入口点执行
2.实验过程:
1)在Console窗口中输入调试指令sreg,查看当前CPU中各个段寄存器的值,其中CS寄存器信息行中的“s=0xf000”表示CS寄存器的值为0xf000。
2)输入调试命令r,显示当前CPU中各个通用寄存器的值,“rip: 00000fff0”表示 IP 寄存器的值为 0xfff0。
3)输入调试命令 xp /1024b 0x0000,查看开始的 1024 个字节的物理内存。在 Console 中输出的这 1K 物理内存的值都为 0,说明 BIOS 中断向量表还没有被加载到此处。
4)输入调试命令 xp /512b 0x7c00,查看软盘引导扇区应该被加载到的内存位置。输出的内存值都 为 0,说明软盘引导扇区还没有被加载到此处。
可以验证 BIOS 第一条指令所在逻辑地址中的段地址CS寄存器值是一致的,偏移地址和 IP 寄存器 的值是一致的。由于内存还没有被使用,所以其中的值都为0。
5) 输入调试命令 vb 0x0000:0x7c00,这样就在逻辑地址 0x0000:0x7c00(相当于物理地址 0x7c00)处添加了一个断点。输入调试命令 c 继续执行,在 0x7c00 处的断点中断。中断后会在 Console 窗口中输出下一个要 执行的指令,即软盘引导扇区程序的第一条指令。
6) 输入调试命令 sreg 验证 CS 寄存器(0x0000)的值。
7) 输入调试命令 r 验证 IP 寄存器(0x7c00)的值。
8)输入调试命令 xp /512b 0x0600 可验证第一个用户可用区域是空白的。
9)设计两个查看内存的调试命令,分别验证这两个用户可用区域的高地址端也是空白的。
10)软盘引导扇区程序的主要任务就是将软盘中的 loader.bin 文件加载到物理内存的 0x1000 处,然后跳 转到 loader 程序的第一条指令(物理地址 0x1000 处的指令)继续执行 loader 程序。
输入调试命令xp /8b 0x1000查看内存0x1000处的数据,验证此块内存的前三个字节和loader.lst 文件中的第一条指令的字节码是相同的。
11)根据之前记录的 loader.bin 文件的大小,自己设计一个查看内存的调试命令,查看内存中 loader 程序结束位置的字节码,并与 loader.lst 文件中最后指令的字节码比较,验证 loader 程序被完 全加载到了正确的位置。
12)调试内核,在项目管理器中打开start.c文件,对其中的操作系统内核入口点函数KiSystemStartup添加断点及监视,在监视窗口中可以看到此函数的地址,与在虚拟内存保存的函数入口地址相同,说明的确是由loader程序进入了操作系统内核。
13)在控制台中输入命令“ver”,可得EOS的的版本,在控制台中输入命令“pt”,课查看输出的进程和线程信息。
在进程列表中只有一个 ID 为 1 的系 统进程,其优先级为 24,包含有 10 个线程,其中的 ID 为 2 的线程是该进程的主线程,系统进程没有映像 名