Ubuntu использует qemu для отладки ядра Linux

Чтобы отладить код ядра на виртуальной машине, посмотрите, может ли он помочь в изучении ядра. , Выполнена следующая проверка.

Команды в середине предназначены только для справки и представляют собой некоторые записи в процессе использования. Соответствующую настройку необходимо выполнить, когда используется имя пути к файлу.

1. Загрузите исходный код ядра Linux.

https://mirrors.edge.kernel.org/pub/linux/kernel/v3.x/

$ wget https://cdn.kernel.org/pub/linux/kernel/v3.x/linux-3.10.104.tar.xz # декомпрессировать $ tar xvf linux-3.10.104.tar.xz

$ cd linux-3.10.104

Настройка

$ make menuconfig
编译。

$ make -j8 #  

$ cp linux-3.10.104 / arch / x86_64 / boot / bzImage

Установить виртуальную машину

$ sudo apt-get install qemu
 

2. Сделать rootfs

мы привет

gcc -static -o helloworld hello.cecho helloworld | cpio -o --format = newc> rootfs

Сделать корневую файловую систему.

emu-system-x86_64 -kernel linux_3.10 / linux-3.10.92 / arch / x86_64 / boot / bzImage -initrd ./rootfs/rootfs -append "root = / dev / ram rdinit = / helloworld"

3. Запустите ядро ​​Linux.

   cd LinuxKernel
    qemu-system-i386 -kernel linux-3.18.6/arch/x86/boot/bzImage -initrd rootfs.img -s -S # 关于-s和-S选项的说明:
    # -S freeze CPU at startup (use ’c’ to start execution)
    # -s shorthand for -gdb tcp::1234 若不想使用1234端口,则可以使用-gdb tcp:xxxx来取代-s选项

qemu-system-x86_64 -kernel linux_3.10 / linux-3.10.92 / arch / x86_64 / boot / bzImage -initrd ./rootfs/rootfs -append "root = / dev / ram rdinit = / helloworld" -s -S

4 Запустите отладку GDB

    gdb
    (gdb)file linux-3.18.6/vmlinux # 在gdb界面中targe remote之前加载符号表
    (gdb)target remote:1234 # 建立gdb和gdbserver之间的连接,按c 让qemu上的Linux继续运行
    (gdb)break start_kernel # 断点的设置可以在target remote之前,也可以在之后
Освобожденные восемь оригинальных статей · вона похвала 0 · Просмотров 2874

рекомендация

отblog.csdn.net/skyxiaoyan1/article/details/85038742