百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

Qemu模拟ARM64和GDB调试linux kernel

liuian 2024-12-09 15:21 39 浏览

Qemu模拟ARM64使用GDB调试linux kernel

1、linux文件编译

大家在学习linux kernel时,需要购买硬件开发板,这是一笔不少的投入,今天就介绍大家如何使用模拟器来模拟ARM硬件,并且使用GDB来调试linux kernel。在buildroot编译框架下,我们使用qemu_aarch64_virt_defconfig配置进行编译,编译过程中,buildroot会根据配置文件自动下载相关的文件,包含编译工具链、linux、文件系统等。要使用GDB对linux kernel进行调试,需要开启内核参数CONFIG_DEBUG_INFOCONFIG_GDB_SCRIPTS两个配置项目。

在buildroot编译框架下输入命令进入linux kernel配置目录:make linux-menuconfig

配置目录下进入kernel hacking条目,首先开启Kernel debugging选项,最后进入Compile-time checks and compiler options 条目,开启Compile the kernel with debug infoProvide GDB scripts for kernel debugging内核参数配置项。

配置完成后使用make命令编译。

2、qemu模拟器

qemu是一个广泛使用的开源计算机模拟器和虚拟机。当作为模拟器时,可以在一种架构(如x86 PC)下运行另一种架构(如ARM)下的操作系统和程序。通过使用动态翻译,它可以获得非常好的性能。作为虚拟机时,qemu可以使用其他虚拟机管理程序( KVM)来使用CPU扩展进行虚拟化,通过在主机CPU上直接执行客户机代码来获得接近于宿主机的性能。

ubuntu下安装qemu:sudo apt-get install qemu qemu-system,安装好qemu后我们进入buildroot-2021.08.1/output/images目录下,用qemu_aarch64_virt_defconfig配置编译时自动会生成qemu启动脚本文件:start-qemu.sh,直接运行此文件则可以启动qemu模拟器,模拟ARM芯片启动编译好的linux kernel内核:

qemu启动参数说明:

参数

说明

-M vexpress-a9

指定要仿真的开发板:vexpress-a9

-m 512M

指定DRAM内存大小为512MB

-cpu cortex-a9

指定CPU架构

-smp n

CPU的个数,不设置的话,默认是1

-kernel ./zImage

要运行的镜像

-dtb ./vexpress-vap-ca9.dtb

要加载的设备树文件

-append cmdline

设置Linux内核命令行、启动参数

-initrd file

使用file文件作为初始化ram disk

-nographic

非图形化启动,使用串口作为控制台

-sd rootfs.ext3

使用rootfs.ext3作为SD卡镜像文件

-net nic

创建一个网卡

-net nic -net tap

将开发板网卡和主机网卡建立桥接(Bridge)

qemu启动运行linux后,退出指令:ctrl+a,然后再按x键。

3、GDB调试

ubuntu 默认安装的gdb 是x86的版本,需要调试aarch64架构的内核必须要安装gdb-multiarch命令:apt-get install gdb-multiarch

3.1、修改qemu启动文件

使用gdb调试,qemu启动命令需要添加一项参数“-s -S”:-s的意思是等待外面gdb的链接,默认开启1234端口进行监听;-S是在内核的入口打断点。添加-s -S参数到 start_qemu.sh文件"EXTRA_ARGS"变量处,运行start_qemu.sh文件后不会直接启动kernel,会保持在暂停状态,等待外部gdb的连接。

#!/bin/sh
(
 BINARIES_DIR="${0%/*}/"
 cd ${BINARIES_DIR}

 if [ "${1}" = "serial-only" ]; then
     EXTRA_ARGS='-nographic'
 else
     EXTRA_ARGS='-s -S'
 fi
 
 export PATH="/home/ubuntu/work/buildroot-2021.08.1/output/host/bin:${PATH}"
 exec qemu-system-aarch64 -M virt -cpu cortex-a53 -nographic -smp 1 -kernel Image -append "rootwait root=/dev/vda console=ttyAMA0" -netdev user,id=eth0 -device virtio-net-device,netdev=eth0 -drive file=rootfs.ext4,if=none,format=raw,id=hd0 -device virtio-blk-device,drive=hd0 ${EXTRA_ARGS}
)

3.2、GDB连接调试

启动qemu后,在另外一个端口下使用gdb连接qemu启动的模拟器:gdb-multiarch vmlinux(vmlinux是linux编译目录下的非压缩文件)

启动日志有警告信息提醒,需要添加两行指令到/home/xxxx/.gdbinit文件下(如不存在文件则直接新建):

gdb启动后会停留在输入指令状态,输入:target remote localhost:1234,连接qemu模拟器:

如上图所示,则已正常地连接到qemu模拟器上了,可以使用b xx进行设置断点:b start_kernel,在start_kernel函数设置断点,设置完成后输入字符c运行:

这样模拟器运行到 start_kernel函数时会自动暂停执行,后续可以使用next、step等gdb指令进行调试了。

相关推荐

python入门到脱坑函数—定义函数_如何定义函数python

Python函数定义:从入门到精通一、函数的基本概念函数是组织好的、可重复使用的代码块,用于执行特定任务。在Python中,函数可以提高代码的模块性和重复利用率。二、定义函数的基本语法def函数名(...

javascript函数的call、apply和bind的原理及作用详解

javascript函数的call、apply和bind本质是用来实现继承的,专业点说法就是改变函数体内部this的指向,当一个对象没有某个功能时,就可以用这3个来从有相关功能的对象里借用过来...

JS中 call()、apply()、bind() 的用法

其实是一个很简单的东西,认真看十分钟就从一脸懵B到完全理解!先看明白下面:例1obj.objAge;//17obj.myFun()//小张年龄undefined例2shows(...

Pandas每日函数学习之apply函数_apply函数python

apply函数是Pandas中的一个非常强大的工具,它允许你对DataFrame或Series中的数据应用一个函数,可以是自定义的函数,也可以是内置的函数。apply可以作用于DataF...

Win10搜索不习惯 换个设定就好了_window10搜索用不了怎么办

Windows10的搜索功能是真的方便,这点用惯了Windows10的小伙伴应该都知道,不过它有个小问题,就是Windows10虽然会自动联网搜索,但默认使用微软自家的Bing搜索引擎和Edge...

面试秘籍:call、bind、apply的区别,面试官为什么总爱问这三位?

引言你有没有发现,每次JavaScript面试,面试官总爱问你call、bind和apply的区别?好像这三个方法成了通关密码,掌握了它们,就能顺利过关。其实不难理解,面试官问这些问题,不...

记住这8招,帮你掌握“追拍“摄影技法—摄影早自习第422日

杨海英同学提问:请问叶梓老师,我练习追拍时,总也不能把运动的人物拍清晰,速度一般掌握在1/40-1/60,请问您如何把追拍拍的清晰?这跟不同的运动形式有关系吗?请您给讲讲要点,谢谢您!摄影:Damia...

[Sony] 有点残酷的测试A7RII PK FS7

都是好机!手中利器!主要是最近天天研究fs5,想知道fs5与a7rii后期匹配问题,苦等朋友的fs5月底到货,于是先拿手里现有的fs7小测一下,十九八九也能看到fs5的影子,另外也了解一下fs5k标配...

AndroidStudio_Android使用OkHttp发起Http请求

这个okHttp的使用,其实网络上有很多的案例的,但是,如果以前没用过,copy别人的直接用的话,可以发现要么导包导不进来,要么,人家给的代码也不完整,这里自己整理一下.1.引入OkHttp的jar...

ESL-通过事件控制FreeSWITCH_es事务控制

通过事件提供的最底层控制机制,允许我们有效地利用工具箱,适时选择使用其中的单个工具。FreeSWITCH是一个核心交换与混合矩阵,它周围有几十个模块提供各种功能特性。我们完全控制了所有的即时信息,这些...

【调试】perf和火焰图_perf生成火焰图

简介perf是linux上的性能分析工具,perf可以对event进行统计得到event的发生次数,或者对event进行采样,得到每次event发生时的相关数据(cpu、进程id、运行栈等),利用这些...

文本检索控件也玩安卓?dtSearch Engine发布Android测试版

dtSearchEngineforLinux(原生64-bit/32-bitC++和JavaAPIs)和dtSearchEngineforWin&.NET(原生64-bi...

网站后台莫名增加N个管理员,记一次SQL注入攻击

网站没流量,但却经常被SQL注入光顾。最近,网站真的很奇怪,网站后台不光莫名多了很多“管理员”,所有的Wordpres插件还会被自动暂停,导致一些插件支持的页面,如WooCommerce无法正常访问、...

多元回归树分析Multivariate Regression Trees,MRT

多元回归树(MultivariateRegressionTrees,MRT)是单元回归树的拓展,是一种对一系列连续型变量递归划分成多个类群的聚类方法,是在决策树(decision-trees)基础...

JMETER性能测试_JMETER性能测试指标

jmeter为性能测试提供了一下特色:jmeter可以对测试静态资源(例如js、html等)以及动态资源(例如php、jsp、ajax等等)进行性能测试jmeter可以挖掘出系统最大能处...