热门标签 | HotTags
当前位置:  开发笔记 > 前端 > 正文

kgdb和qemu

1.编译linux下载内核sudomkdir-p/usr/src/worksudochmod777/usr/src/work-Rcd/usr/src/work配置内核选项$sudomakedefconfig//你可以选择你需要的版本,生成.config$sudomakemenuconfig//配置内核确保如下的选项是打

1. 编译 linux

下载内核
    sudo mkdir -p  /usr/src/work
    sudo chmod 777 /usr/src/work -R
    cd /usr/src/work
配置内核选项
    $ sudo make defconfig
        //你可以选择你需要的版本,生成.config
    $ sudo make menuconfig    
        //配置内核
    确保如下的选项是打开的:
    CONFIG_EXPERIMENTAL = y
    CONFIG_KGDB = y
    CONFIG_KGDB_SERIAL_COnSOLE= y (使用串口进行通信)
    建议关闭的选项: 
    CONFIG_DEBUG_RODATA = n
该选项是将内核的一些内存区域空间设置为只读,这样可能导致kgdb的
        设置软断点功能失效。所以推荐将该选项关闭。
    建议打开的选项:
    CONFIG_KGDB_LOW_LEVEL_TRAP = y                                         
使能该选项可以kgdb不依赖notifier_call_chain()机制来获取断点异常,
这样就可以对notifier_call_chain()机制实现相关的函数进行单步调试。
    CONFIG_DEBUG_INFO = y
该选项可以使得编译的内核包含一些调试信息,使得调试更容易。
    CONFIG_FRAME_POINTER = y
该选项将使得内核使用帧指针寄存器来维护堆栈,从而就可以正确地执行堆栈回溯,即函数调用栈信息。
        arm体系的配置中没有找到这个选项.
    CONFIG_MAGIC_SYSRQ = y (如果你选择了KGDB_SERIAL_CONSOLE,这个选项将自动被选上)
        激活"魔术 SysRq"键. 该选项对kgdboc调试非常有用,kgdb向其注册了‘g’魔术键来激活kgdb 。
        当你想手动激活kgdb时,你可以触发SysRq的g键, 如:
            $ echo "g" > /proc/sysrq-trigger
    注意:打开make menuconfig后,按 '/'并将选项(如:CONFIG_KGDB)复制到搜索框,然后回车就可找到
        关于该选项的有关信息。
        GCOV-based kernel profiling 在general 下
    保存配置退出.

编译内核 
    # sudo make
    ( 如果你是双核可以 加上 -j2 速度更快 )
    error: ld: final link failed: No space left on device
内核在编译时编出来的临时文件,占用的是源码所在的分区而不是/tmp/分区
        将源码复制到其他分区,编译
    编译完成后,复制bzImage和vmlinux到工作目录下备用
    $ sudo cp arch/x86/boot/bzImage /usr/src/work
    $ sudo cp vmlinux /usr/src/work

2. 制作自己的文件系统
    下载busybox
去busybox站点(http://www.busybox.net/downloads/)下载一个busybox源码包,并解压。
        # wget http://www.busybox.net/downloads/XXX
        # tar -jxvf busybox-1.17.2.tar.bz2
    编译busybos
        # sudo cd busybox-1.17.2
        # sudo make menuconfig
        Busybox Settings  --->
   Build Options  --->
        [ * ] Build BusyBox as a static binary (no shared libs)
   Installation Options  --->
        [ * ] Don't use /usr
    Miscellaneous Utilities  --->
    [ ] flashcp
    [ ] flash_lock
    [ ] flash_unlock
    [ ] flash_eraseall
    注:[ ] 表示不选择
        保存配置文件后开始编译和安装
        # sudo make
我的编译错误:cannot find -lcrypt
            解决:yum install glibc-static //fedora
            make 后显示
LINK    busybox_unstripped
            Trying libraries: crypt m
 Library crypt is not needed, excluding it
 Library m is needed, can't exclude it (yet)//可以不必理会,我不知到为什么
        # sudo make install     制作文件系统
使用如下命令来创建一个虚拟文件系统磁盘文件,在当前目录下创建一个名为busybox.img,大小为100M的文件,并
        将其格式化为ext3的文件系统
        # cd /usr/src/work
        # sudo dd if=/dev/zero of=./busybox.img bs=1M count=100
            解释: dd: Copy a file, converting and formatting according to the operands.
      if=FILE read from FILE instead of stdin
      of=FILE write to FILE instead of stdout
      bs=BYTES read and write BYTES bytes at a time
        # sudo mkfs.ext3 busybox.img
            解释:mkfs - build a Linux file system
将这个虚拟磁盘文件到本地系统中,这样我们可以像访问本地文件一样访问它,
        并将生成好的busybox的文件拷贝到这个文件里。
        # sudo mkdir /mnt/disk
        # sudo mount -o loop /usr/src/work/busybox.img /mnt/disk
解释:    Loopback设备 是linux中的一个可以用来像其他媒体设备一样的虚拟设备。
媒体设备的例子像硬盘分区,例如/dev/had1,/dev/had2,dev/sda1,或者像/dev/fd0软
盘分区一样的整个磁盘。这些设备全部都可以用来储存文件以及目录。它们可以被格式
        化成需要的文件格式(ext2fs, msdos, ntfs等)然后被mount。
Loopback文件系统就是把一个文件和另外的一个文件系统联系起来,就像一个完整像系
统一样。它可以被格式化和mount成以上所提到过块设备.(原文:http://www.dzshebei.com
        /bbs/33424.html)
        # sudo cp -rf /usr/src/work/busybox-1.17.2/_install/* /mnt/disk
        创建必须的文件系统目录
        # cd /mnt/disk/
        # sudo mkdir dev sys proc etc lib mnt
        使用busybox默认的设置文件
            # sudo cp -a /usr/src/work/busybox-1.17.2/examples/bootfloppy/etc/* /mnt/disk/etc
            # sudo vim /mnt/disk/etc/init.d/rcS
将下面内容拷贝到rcS里:
    #! /bin/sh
    /bin/mount -a
    /bin/mount -t  sysfs sysfs /sys
    /bin/mount -t tmpfs tmpfs /dev
    #动态添加虚拟机环境中的设备
    /sbin/mdev -s
    解释: 
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
        做完上面对工作后,我们就可以卸载虚拟磁盘文件了
            # cd /usr/src/work
            # sudo umount /mnt/disk

3. 安装qemu
    有关 qemu的介绍:http://www.askarali.org/qemu_howto.html
 http://wiki.qemu.org/Main_Page
    Ubuntu/Debian:
        $ sudo apt-get install qemu
    Fedora:
        # yum install qemu/
4. 使用qemu运行自己编译的内核
    $ sudo qemu  -kernel /usr/src/work/bzImage -append "root=/dev/sda" -boot c -hda /usr/src/work/busybox.img -k en-us
     解释:-boot a”的意思是从软盘启s动。你还可以用“-boot c”来表示从硬盘启动
    note:
    根据你硬盘的种类选择使用 "root=/dev/hda" 或者 "root=/dev/sda".
    这样就能正常启动.
    如果顺利的话,自己编译的内核+文件系统就会在那qemu黑乎乎的窗口里展现出来,
    我的提示:
    This kernel requires an x86-64 CPU, but only detected an i686 CPU. Unable to boot -please
     use a kernel appropritate for your CPU.
 [参考:https://bugzilla.redhat.com/show_bug.cgi?id=494286
http://www.oschina.net/bbs/thread/7740
     ]
     # qemu -cpu ?
x86           qemu32
x86              486
x86          pentium
x86         pentium2
x86         pentium3

    error 1 :
    Could not open '/dev/kqemu' - QEMU acceleration layer not activated: No such file or directory
    Warning : unable to open an initial console
    解决:   
    $ sudo apt-get install  kqemu-source kqemu-common
5. 开始调试   
    $ sudo qemu -kernel /usr/src/work/bzImage -append "root=/dev/hda kgdboc=ttyS0,115200 kgdbwait" -boot c -hda /usr/src/work/busybox.img -k en-us -serial tcp::4321,server
   打开另外一个终端
    $ gdb /usr/src/work/vmlinux
    如果正确则显示如下:
    (gdb) target remote localhost:4321
    Remote debugging using localhost:4321
    kgdb_breakpoint () at kernel/debug/debug_core.c:983
    983        wmb(); /* Sync point after breakpoint */
    (gdb)


推荐阅读
  • 本文介绍了几个有趣的Linux命令行工具,包括模拟蒸汽机车的sl命令、反转字符串的rev命令、显示随机名言的fortune命令等,不仅增添了命令行操作的乐趣,也展示了Linux系统的多样性和灵活性。 ... [详细]
  • 远程访问用户 Kindle通过电子书实现控制
    介绍自2007年以来,亚马逊已售出数千万台Kindle,令人印象深刻。但这也意味着数以千万计的人可能会因为这些Kindle中的软件漏洞而被黑客入侵。他 ... [详细]
  • Linux系统中高效解决高Buff/Cache占用问题
    本文详细探讨了在Linux系统中遇到的高Buff/Cache占用问题及其解决方案,提供了手动清除与定时任务自动化处理的方法。 ... [详细]
  • Windows 平台 Ruby on Rails 安装指南
    本文详细介绍如何在 Windows 系统上安装 Ruby 及其开发框架 Rails,包括必要的环境配置和组件安装。 ... [详细]
  • 本文详细介绍了如何通过Percona插件监控MySQL 5.7数据库,包括环境准备、插件安装、配置调整及数据测试等步骤,旨在为用户提供一个高效且稳定的监控解决方案。 ... [详细]
  • 本文介绍了如何通过安装 VirtualBox 和 Vagrant 来快速搭建和管理虚拟机环境。我们将详细探讨如何选择合适的 Box 镜像,以及如何高效地下载、添加和管理这些镜像。 ... [详细]
  • ThinkPHP 文件缓存组件详解与应用
    本文深入探讨了ThinkPHP框架中的文件缓存类实现,提供了详细的代码示例和使用说明,旨在帮助开发者更好地理解和利用这一功能来优化应用程序性能。 ... [详细]
  • 本文基于https://major.io/2014/05/13/coreos-vs-project-atomic-a-review/的内容,对CoreOS和Atomic两个操作系统进行了详细的对比,涵盖部署、管理和安全性等多个方面。 ... [详细]
  • 在安装Ubuntu 12.04后,用户可能会遇到系统菜单中缺少休眠(Hibernate)选项的问题。这通常是由于某些程序的错误导致系统默认禁用了此功能。本文将详细介绍如何恢复和使用休眠选项。 ... [详细]
  • 在Ubuntu系统上安装搜狗输入法的详细步骤
    本文介绍了如何在Ubuntu操作系统中安装搜狗输入法,包括安装输入框架、下载安装包以及配置输入法的具体步骤。 ... [详细]
  • CentOS 7.4 KVM虚拟化平台搭建指南
    本文详细介绍了如何在CentOS 7.4系统上搭建KVM虚拟化平台,包括环境准备、网络配置、KVM安装与管理等步骤,适用于希望利用KVM进行虚拟化部署的技术人员。 ... [详细]
  • 开发笔记:Mongodb副本集集群搭建 ... [详细]
  • ANSI最全介绍linux终端字体改变颜色等ANSI转义序列维基百科,自由的百科全书由于国内不能访问wiki而且国内关于ANSI的介绍都是简短的不能达到,不够完整所以转wiki到此 ... [详细]
  • Minetest 0.4.9 开源游戏在 Ubuntu 下通过 PPA 安装指南
    本文介绍了如何在 Ubuntu 系统上安装最新版本的 Minetest 0.4.9,包括添加 PPA、更新软件包列表以及安装过程,适合所有 Ubuntu 及其衍生系统的用户。 ... [详细]
  • 深入探讨Web服务器与动态语言的交互机制:CGI、FastCGI与PHP-FPM
    本文详细解析了Web服务器(如Apache、Nginx等)与动态语言(如PHP)之间通过CGI、FastCGI及PHP-FPM进行交互的具体过程,旨在帮助开发者更好地理解这些技术背后的原理。 ... [详细]
author-avatar
zhuzhu-2012_389
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有