qemu模拟arm64 用eclipse图形化调试aar64内核

本文详细介绍了在Ubuntu 16.04上为Aarch64架构编译Linux内核的过程,包括设置环境变量、配置内核、使用make命令编译,并在QEMU中进行调试的步骤。在调试过程中,针对GDB无法找到函数边界、QEMU无法在start_kernel处暂停以及Eclipse分析源码时崩溃等常见问题提供了解决方案。最后展示了内核单步调试的截图。
摘要由CSDN通过智能技术生成

虚拟机系统版本:

Ubuntu 16.04 x86_64

qemu 版本:

Linux内核源码和工具链版本:

eclipse 版本:

eclipse CDT 插件版本:

编译内核:

1. 进入内核源码目录

2. export ARCH=arm64

3. export CROSS_COMPILE=aarch64-linux-gnu-

4. make defconfig

5. make -j16  #16表示我本地虚拟机有16核,具体多少核可以用命令nproc来获取

编译后的内核镜像文件在arch/arm64/boot/下

遇到的问题:

1.GDB输入r指令提示Cannot find bounds of current function

解决方案:如果不是待调试程序格式问题(x86和arm64),那么就先输入C(continue)指令让程序运行起来

2.qemu调试l内核在start_kernel打了断点,输入C后,不会停到start_kernel

解决方案:禁用randomize address of kernel image

3.eclipse创建Linux内核源码工程后,分析源码文件过程中程序奔溃

解决方案:新建debug的时候不指定project,只需配置好gdb和待调试的vmlinux,connect下使用tcp,端口1234,IP:localhost

最后来一张真香的单步调试:

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值