使用qemu调试arm内核

参考书籍《奔跑吧Linux内核》--笨叔

下载Linux-5.0源码

bash 复制代码
https://benshushu.coding.net/public/runninglinuxkernel_5.0/runninglinuxkernel_5.0/git/files

或者直接git源码

bash 复制代码
git clone https://e.coding.net/benshushu/runninglinuxkernel_5.0/runninglinuxkernel_5.0.git

安装必要的包

bash 复制代码
sudo apt-get install qemu libncurses5-dev gcc-aarch64-linux-gnu build-essential bison flex libssl-dev qemu-system-arm

切换到rlk_5.0分支

bash 复制代码
git checkout rlk_5.0

编译内核

bash 复制代码
~/kernel/runninglinuxkernel_5.0$ ./run_debian_arm64.sh build_kernel

编译文件系统

bash 复制代码
~/kernel/runninglinuxkernel_5.0$ sudo ./run_debian_arm64.sh build_rootfs

使用qemu运行Debian系统

bash 复制代码
/kernel/runninglinuxkernel_5.0$ ./run_debian_arm64.sh run

running:

或者使用:

bash 复制代码
qemu-system-aarch64 -m 1024 -cpu max,sve=on,sve256=on -M virt,gic-version=3,its=on,iommu=smmuv3 -nographic -smp 4 -kernel arch/arm64/boot/Image -append "noinitrd nokaslr loglevel=8 sched_debug root=/dev/vda rootfstype=ext4 rw crashkernel=256M vfio.dyndbg=+pflmt irq_gic_v3_its.dyndbg=+pflmt iommu.dyndbg=+pflmt irqdomain.dyndbg=+pflmt" -drive if=none,file=/home/book/kernel/runninglinuxkernel_5.0/rootfs_debian_arm64.ext4,id=hd0 -device virtio-blk-device,drive=hd0 --fsdev local,id=kmod_dev,path=./kmodules,security_model=none -device virtio-9p-pci,fsdev=kmod_dev,mount_tag=kmod_mount

进入虚拟机界面

登录

用户名:root或benshushu

密码:123

成功进入qemu

bash 复制代码
benshushu:~# ifconfig
bash 复制代码
benshushu:~# gcc -v

如果没有可以在线安装

在qemu和Ubuntu之间共享文件

:~/kernel$ cp test.txt runninglinuxkernel_5.0/kmodules/

benshushu:~# ls /mnt/

README arm64_virt.dts rlk_lab test.txt

benshushu:~# vi /mnt/test.txt

退出qemu

bash 复制代码
Ctrl +a  x

或者之间结束qemu

bash 复制代码
ps -e | grep qemu
 kill -9 48977

使用GDB调试

安装支持不同处理器架构的gdb

bash 复制代码
 sudo apt install gdb-multiarch

运行脚本启动qemu和GDB

bash 复制代码
:~/kernel/runninglinuxkernel_5.0$ ./run_debian_arm64.sh run debug

开启另外一个终端:

远程调用GDB调试

bash 复制代码
:~/kernel/runninglinuxkernel_5.0$ gdb-multiarch --tui  vmlinux

设置 aarch64架构

bash 复制代码
(gdb)set architecture aarch64

通过1234端口远程连接到qemu虚拟机。

bash 复制代码
(gdb)target remote localhost:1234

在内核的start_kernel 处设置断点

bash 复制代码
(gdb)b start_kernel

运行测试

bash 复制代码
(gdb)c 

将跳转到断点 start_kernelchu

退出 GDB

bash 复制代码
(gdb)q/quit

方法二:图形化界面调试工具

安装 Eclipse-CDT插件

下载Eclipse-CDT插件

bash 复制代码
https://projects.eclipse.org/projects/tools.cdt

Download Packages

bash 复制代码
https://projects.eclipse.org/projects/iot.embed-cdt

下载x86_64 Linux安装包

Download

Linux x86_64 | AArch64

https://www.eclipse.org/downloads/download.php?file=/oomph/epp/2023-09/R/eclipse-inst-jre-linux64.tar.gz

安装java运行环境。

bash 复制代码
sudo apt-get install openjdk-13-jre

安装

bash 复制代码
hudahua@VirtualBox:~/workspace/tools$ tar xzf eclipse-inst-jre-linux64.tar.gz
hudahua@VirtualBox:~/workspace/tools/eclipse-installer$ ./eclipse-inst

安装 Eclipse IDE for C/C++ Developer

图形界面下载和调试较慢,后期不使用了。

相关推荐
板栗焖小鸡12 小时前
Odrive0.5.1-FOC电机控制 arm_cos_f32.cpp arm_sin_f32.cpp代码实现(二)
arm开发·单片机·嵌入式硬件
板栗焖小鸡12 小时前
Odrive0.5.1-FOC电机控制 arm_cos_f32.cpp arm_sin_f32.cpp代码实现(一)
arm开发·单片机·嵌入式硬件
暮云星影1 天前
十二、buildroot系统 adb登录权限设置
linux·arm开发·adb
钡铼技术物联网关1 天前
ARM分拣机vs传统PLC:实测数据揭示的4倍效率差
大数据·linux·arm开发·人工智能·边缘计算
阿超爱嵌入式2 天前
STM32学习之ARM内核自带的中断
arm开发·stm32·学习
程序员JerrySUN2 天前
深入解析ARM与RISC-V架构的Bring-up核心流程
arm开发·架构·risc-v
ZzxtEcho3 天前
ARM 汇编启动代码详解:从中断向量表到中断处理
汇编·arm开发
钡铼技术物联网关3 天前
工业4.0时代:RK3588边缘工业计算机助力AGV导航升级
linux·arm开发·人工智能·5g·边缘计算
逆鱼_043 天前
ARM-UART
linux·运维·arm开发
钡铼技术物联网关4 天前
ARM架构+CODESYS:解锁嵌入式边缘计算的实时控制新范式
大数据·linux·arm开发·人工智能·边缘计算