debug vmlinux via qemu


 * linux
    compile linux src with debug info

    make bzImage 

    gen arch/XXX/boot/bzImage & ./vmlinux


 * qemu
    sudo apt-get install libsdl zlib ...
    ./configure --target-list=i386-softmmu --enable-sdl
    make
    make install

 * busybox
    make defconfig
    make
    make install

 * mkinitramfs
    dd if=/dev/zero of=./busybox.img bs=1M count=64
    mkfs.ext4 busybox.img

    cp -a busybox/examples/bootfloppy/etc/* busybox/_install/etc/
    cd busybox/_install
    mkdir dev proc sys
    cd dev
    sudo cp -a /dev/zero ./
    sudo cp -a /dev/console ./
    sudo cp -a /dev/null ./
    sudo cp -a /dev/tty ./
    sudo cp -a /dev/ttyS0 ./

    sudo mount -o loop busybox.img /mnt/busybox
    cp -a busybox/_install/* /mnt/busybox
    ...
    sudo umount /mnt/busybox

 * start qemu

   cp bzImage ... , vmlinux ...

    qemu -s -S -kernel bzImage -append "root=/dev/sda" -hda busybox.img

 * gdb
    gdb vmlinux
    target remote localhost:1234

    ...
    b start_kernel
    ...

你可能感兴趣的:(debug vmlinux via qemu)