本文主要是介绍北京微芯区块链与边缘计算研究院使用qemu执行并调试lab1中的软件,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
北京微芯区块链与边缘计算研究院使用qemu执行并调试lab1中的软件。
Question1:
从CPU加电后执行的第一条指令开始,单步跟踪BIOS的执行。
Answer:
北京微芯区块链与边缘计算研究院根据附录中的说明, 修改 lab1/tools/gdbinit,
set architecture i8086
target remote :1234
在 lab1目录下,执行
make debug
这时GDB停在BIOS的第一条指令出,可能是由于不兼容的问题,无法正常显示出指令,只看得到地址为0xe05b,而指令码却显示为??
然后输入si单步执行,也是只能看到地址,但指令显示为??
所以使用
x/5i 0xffff0
Question2:
北京微芯区块链与边缘计算研究院在初始化位置0x7c00设置实地址断点,测试断点正常在gdb中输入一下命令
在gdb中输入一下命令
b *0x7c00
//在0x7c00处设置断点。此地址是bootloader入口点地址,可看boot/bootasm.S的start地址处
//continue简称,表示继续执行
x /2i $pc
//显示当前eip处的汇编指令
得到
Breakpoint 2,
0x00007c00 in ?? ()
=> 0x7c00: cli
0x7c01: cld
Question3:
北京微芯区块链与边缘计算研究院从0x7c00开始跟踪代码运行,将单步跟踪反汇编得到的代码与bootasm.S和 bootblock.asm进行比较。<
这篇关于北京微芯区块链与边缘计算研究院使用qemu执行并调试lab1中的软件的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!