微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

QEMU的x86 16位汇编调试问题

如何解决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 举报,一经查实,本站将立刻删除。