美文网首页
GDB+Qemu调试Linux-0.11的代码

GDB+Qemu调试Linux-0.11的代码

作者: readilen | 来源:发表于2019-08-18 23:34 被阅读0次

1.下载内核源码和根文件系统镜像
http://oldlinux.org/Linux.old/bochs/linux-0.11-devel-040809.zip

Linux-0.11内核源码的改进版,可以在gcc- 5.5.0下顺利编译通过,原生代码只能在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,
按下面命令执行:

qemu-system-x86_64 -m 16 -boot a -fda Image -hda hdc-0.11.img -s -S

解释一下

-fda Image:代表你把 Image 執行目錄下  
-hda hdc-0.11.img:代表你把 HD img,是一个模拟硬盘的文件,可以在赵博士所提供的`linux-0.11-devel-040809.zip`找到
-m:设定模拟的内存大小,本地设定为 16MB 
-s : 服务器开启1234端口
-S: 开始执行就挂住

另外开启控制台

gdb tools/system

进入客户端
载入符号

(gdb) file tools/system

链接远端服务器

(gdb) target remote localhost:1234

下中断,停在0x7c00处

(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)  layout split
(gdb)  c

在此時,bios 把控制权正式的交给了 linux,而 0x7C00对应的代码应该是 bootsect.S
观察0x7DFE与 0x7DFF的值是否为0x55,0xAA

(gdb) x/16xb 0x7DF0

单步执行

(gdb) si

下中断

(gdb) b main

相关文章

  • GDB+Qemu调试Linux-0.11的代码

    1.下载内核源码和根文件系统镜像http://oldlinux.org/Linux.old/bochs/linux...

  • 从start_kernel到init进程启动的过程

    首先按照课程中的内容编译并用gdb+qemu调试运行我们的Linux操作系统.其命令如下: 再打开另一个终端窗口,...

  • vscode使用指南(代码调试)

    代码调试 vscode 原生支持nodejs的调试,其他语言需要安装拓展支持调试 代码调试界面 调试界面 调试配置...

  • 前端调试

    代码调试 chrome调试 代码调试 1.debugger 可以直接在编写代码的时候,加入debugger,打开浏...

  • 使用IntelliJ IDEA进行Java代码调试的技巧

    一、前言 什么是代码调试? 通过调试可以让我们了解代码运行过程中的代码执行信息,比如变量的值等等。 通常调试代码是...

  • [译]用 LLDB 调试 Swift 代码

    [译]用 LLDB 调试 Swift 代码 [译]用 LLDB 调试 Swift 代码

  • 调试信息的格式对调试器的影响

    简介 调试代码的时候离不开调试信息,代码有代码的规范,调试信息也同样有调试信息格式的规范。我们以elf64文件格式...

  • JavaScript调试(8/28)

    JavaScript 调试 在程序代码中寻找错误叫做代码调试。调试很难,但幸运的是,很多浏览器都内置了调试工具。内...

  • FPN源码 代码调试

    由于特属原因,需要调试这里的代码。。。 代码地址原始代码与作者的讨论代码是在ubuntu上面调试的 目录: 制作数...

  • 收藏|程序员需要了解的调试技巧!

    ​程序员工作的大部分时间,除了写代码之外,就是在调试代码,也可以说是即将调试代码。 今天我们来谈谈调试代码的一些技...

网友评论

      本文标题:GDB+Qemu调试Linux-0.11的代码

      本文链接:https://www.haomeiwen.com/subject/ynfjsctx.html