ucore练习二

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当做断点

设置断点如下:

在这里插入图片描述

发布了33 篇原创文章 · 获赞 2 · 访问量 1735

猜你喜欢

转载自blog.csdn.net/weixin_42469716/article/details/90213175