码迷,mamicode.com
首页 > 系统相关 > 详细

用qemu调试linux内核

时间:2014-07-26 03:27:17      阅读:317      评论:0      收藏:0      [点我收藏+]

标签:调试   qemu   linux   内核   

1)dd if=/dev/zero of=./busybox.img bs=1M count=64
2)mkfs.ext3 busybox.img
3)下载busybox,http://www.busybox.net/downloads/
#tar jxvf busybox-1.18.0.tar.bz2 (解压busybox压缩包)
#cd busybox-1.18.0 (进入到解压后的busybox源码目录)
#make menuconfig (配置busybox)
注意配置时,一定要选择静态链接选项,该选项位于:
Busybox Settings –> Build Options –> Build Busybox as a static binary
#yum install libselinux-static libsepol-static glibc-static(具体根据系统可能还需要其它的包,这是我的系统中需要安装的几个包,是链接busybox所需要的)
接下来,我们安装busybox
#make install (busybox默认安装到了其源码树目录的名字为_install的目录中)
4)制作启动img
在busybox源码目录
cp -a ./_install/*  /mnt/disk/
sudo cp -a ./examples/bootfloppy/etc /mnt/disk  
sudo mkdir /mnt/disk/dev  
sudo mkdir /mnt/disk/proc  
sudo mkdir /mnt/disk/etc  
sudo cp -ar ./examples/bootfloppy/etc /mnt/disk/etc  

sudo cp -a /dev/zero /mnt/disk/dev/  
sudo cp -a /dev/console /mnt/disk/dev/  
sudo cp -a /dev/null /mnt/disk/dev/  
sudo cp -a /dev/tty* /mnt/disk/dev/  
sudo cp -a /dev/ttyS0 /mnt/disk/dev/
5)下载linux内核源码
在linux内核源码目录
make defconfig
make menuconfig
make bzImage
6)安装qemu,yum install qemu
7)启动linux
qemu-system-x86_64 -s -kernel arch/x86_64/boot/bzImage -append "root=/dev/sda" -hda busybox.img


gdb问题:
1)下载gdb7.7,http://ftp.gnu.org/gnu/gdb/
2)到gdb源码目录,vim gdb/remote.c
if (buf_len > 2 * rsa->sizeof_g_packet)
  error (_("Remote ‘g‘ packet reply is too long: %s"), rs->buf);

改成:
if (buf_len > 2 * rsa->sizeof_g_packet) {
  rsa->sizeof_g_packet = buf_len ;

  for (i = 0; i < gdbarch_num_regs (gdbarch); i++) {
    if (rsa->regs[i].pnum == -1)
      continue;

    if (rsa->regs[i].offset >= rsa->sizeof_g_packet)
      rsa->regs[i].in_g_packet = 0;
    else
      rsa->regs[i].in_g_packet = 1;
  }
}
3)重新编译安装gdb:
./configure --prefix=/usr/local/mygdb
make && make install
4)使用新gdb:
/usr/local/mygdb/bin/gdb vmlinux


说明:以上只是个人的笔记,没有详细说明每个过程,如果跟着做没成功请谅解,本人也是网上找了很多资料参考才成功的,尤其是不同环境不同linux内核版本问题就不一样了。

本文出自 “陈漂评的博客” 博客,请务必保留此出处http://chenpiaoping.blog.51cto.com/5631143/1529988

用qemu调试linux内核,布布扣,bubuko.com

用qemu调试linux内核

标签:调试   qemu   linux   内核   

原文地址:http://chenpiaoping.blog.51cto.com/5631143/1529988

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!