QEMU的x86 16位汇编调试问题

问题描述

我是x86汇编的新手,但是成为一名程序员已有近34年的时间。我正在编写一个16位操作系统,并且一切正常。该程序分为Bootloader和Kernel Binaries,然后合并为一个映像文件。通过QEMU运行程序时,Bootloader会在0x7c00正常运行并加载,并在屏幕上显示消息,然后成功将内核加载到0x7e00,并成功启动清除屏幕并将光标置于屏幕左上方的过程。但是,当它随后向屏幕显示消息时,它将失败。当对内核二进制文件进行objbumping时,我可以看到二进制文件已设置为将第一个字节加载到正确地址的SI寄存器中,但是什么也没有发生。调整地址后,发现地址在正确位置后偏移了230-255个字节。我已经将所有段寄存器设置为零,但仍然没有区别。 是否有人对原因和解决方法有任何想法,以及是否有通过QEMU调试原始二进制文件的想法。我看过的每个链接都只显示了如何通过GDB通过TCP端口链接到QEMU来调试ELF文件。

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)

相关问答

错误1:Request method ‘DELETE‘ not supported 错误还原:...
错误1:启动docker镜像时报错:Error response from daemon:...
错误1:private field ‘xxx‘ is never assigned 按Alt...
报错如下,通过源不能下载,最后警告pip需升级版本 Requirem...