ucore练习报告二
(1)从CPU加电后执行的第一条指令开始,单步追踪BIOS
步骤:
首先进入ucore文件中lab1的bin目录下,也就是ucore的镜像文件ucore.img存放的地方,打开终端,输入 qemu -S -s -hda ucore.img -monitor stdio指令(-S 表示在启动时不启用cpu,在monitor下输入c让qemu继续工作。-s表示等待gdb连接到端口1234,以实现gdb和qemu的通信。 -hda ucore.img -monitor stdio表示可在命令行方式下进入qemu的monitor子模块对ucore操作系统进行监控)。其次执行GDB调试程序。在GDB下输入target remote 127.0.0.1:1234,使GDB和qemu通过网络端口1234进行通信,此时qemu会进入停止状态,听从GDB的命令
si为单步执行指令,图中最下面几行便是单步追踪BIOS
(2)从初始化位置0x7c00设置实地址断点,测试断点是否正常
步骤:
在gdb调试工具中,b表示设置断点,首先在gdb下输入b*0x7c00表示在0x7c00处设置了断点,其次使用c命令执行,观察断点是否正常。侧视图如下:
上述表明设置断点正常
(3)从0x7c00开始跟踪代码执行,将单步跟踪反汇编得到的代码与bootasm.S和bootblock.asm进行比较
下图表示的是0x7c00断点处开始的代码和bootasm.S的代码比较图示:
下图为bootasm.asm的图示:
由上图可知0x7c00处的代码与bootasm.S和bootblock.asm的代码相同
(4)自己找一个bootloader或内核中的代码位置,设置断点并进行测试
CPU执行内存的0x7c00中的程序,即bootloader
设置0x7c90当做断点
设置断点如下: