qemu + vscode图形化调试linux kernel

一、背景

使用命令行连接gdb 在调试时,虽然可以通过tui enable 显示源码,但还是存在设置断点麻烦(需要对着源码设置),terminal显示代码不方便,不利于我们学习;另外在gdb 下p命令显示结构体内容时,看起来也是很别扭,可以利用vscode+gdb-multiarch 调试qemu 仿真的arm64 linux 内核,这样查看源码,设置断点,查看变量信息也很快捷方便

二、依赖环境

vscode extensions 搜索安装GDB Debug

 

 

2b0fc16a92004b6d854cc775b4ff8824.png

增加gdb config

 

bfdc67d566e447208c5355f64d073be1.png

json 文件中增加(主要是设置 elf, 以及gdb 的路径,远程gdb连接的端口号)

{
    // Use IntelliSense to learn about possible attributes.
    // Hover to view descriptions of existing attributes.
    // For more information, visit: https://go.microsoft.com/fwlink/?linkid=830387
    "version": "0.2.0",
    "configurations": [
        {
            "type": "cppdbg",
            "request": "launch",
            "name": "kernel GDB",
            "program": "${workspaceFolder}/vmlinux",
            "cwd":"${workspaceFolder}",
            "MIMode":"gdb",
            "miDebuggerPath":"/usr/bin/gdb-multiarch",
            "miDebuggerServerAddress": "localhost:1234",
            "stopAtConnect": true,
        },
    ]
}

 

三、在vscode中启动调试

如果不知道如何qemu 调试内核的可以参考我之前的文档

qemu搭建linux kernel环境

qemu单步调试linux kernel

 

这里有些差异,gdb 加载vmlinux, remote target设置的部分需要换成从vscode设置

第一步启动qemu并等待调试:

qemu-system-aarch64 \
    -machine virt,virtualization=true,gic-version=3 \
    -nographic \
    -m size=1024M \
    -cpu cortex-a72 \
    -smp 2 \ 
    -kernel Image \
    -drive format=raw,file=rootfs.img \
    -append "root=/dev/vda rw nokaslr" \
    -s \
    -S

第二步vscode启动调试 Run->Start Debugging

 

7d5f307ce53f4f6fbbd85f3e5b7482cb.png

第三步启动调试,在init/main.c中start_kernel设置断点,然后点击调试工具栏的continue即可触发到断点,可以开启单步调试了

 

da2e635f9fac49e38bece17495ba0edb.png

第四步如果在执行过程中连接,也是点击pause按钮,这时内核会停止执行,然后在vscode中设置断点,continue后触发断点vscode能正确显示断点位置及代码

 

4d1c0b8aaa344074ad98430438f3b81b.png

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值