打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
GDB+Qemu调试Linux
       1.下载内核源码和根文件系统镜像
http://oldlinux.org/Linux.old/bochs/linux-0.11-devel-040809.zip


Linux-0.11内核源码的改进版,可以在gcc-4.72下顺利编译通过,原生代码只能在gcc-1.4下编译:
https://github.com/yuanxinyu/Linux-0.11


2.编译Linux-0.11
解压Linux-0.11-master.zip,进入Linux-0.11-master目录中,直接执行make就可以编译内核

会生成2个文件,一个是内核Image, 一个是内核符号文件tools/system。

3.qemu启动虚拟机
提取出linux-0.11-devel-040809.zip中的hdc-0.11.img,
按下面命令执行:
/*pc-bios是qemu源码目录中文件,包含bios文件,vgabios文件和keymap */
./qemu-system-x86_64  -m 16M -L ./pc-bios/ -boot a -fda Image -hda hdc-0.11.img -vnc :0 -s -S


4.在另外一个控制台中,执行
#gdb system
(gdb)target remote localhost:1234 //连接gdbserer
(gdb)directory ./Linux-0.11-master //设置源码目录
(gdb)set architecture i8086 //设置成i8086模式,用来调试16位实模式代码
(gdb)set disassembly-flavor intel    //讲汇编显示成INTEL格式,好看一些
(gdb)b *0x7c00 //在地址0x7c00处打断点,因为系统加电后,BIOS会把MBR中的代码加载到内  存中的0x7c00的位置,并从0x7c00处开始执行bootsect.s的代码


(gdb)c 
(gdb)x /16b 0x7df0 //观察0x7DFE和0x7DFF的值是否为0x55,0xAA
(gdb)layout split //显示汇编窗口和源码窗口
(gdb)b main //main函数下断点


 




参考资料:
http://wwssllabcd.github.io/blog/2012/08/03/compile-linux011/
http://oldlinux.org/index_cn.html
http://blog.csdn.net/zhangjs0322/article/details/10152279

本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
使用qemu进行内核源码级调试
linux内核编译与调试方法
【原创】Android Linux内核编译调试
手工制作最新版arm-linux交叉工具链(ubuntu 9.04)
linux 3.4.10 内核内存管理源代码分析1:源代码阅读工具,编译及调试
使用gdb调试linux内核
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服