GDB与GDBServer配合实现在安卓设备中进行程序调试

2021-08-24 14:52:25 浏览数 (1)

实验环境

  • windows开发平台
  • 安卓模拟器(ARM架构 linux系统 已Root): 可以通过adb shell getprop指令查看当前设备的cpu架构
  • arm-linux-androideabi编译工具 gdbgdbserver皆存放在此开发包下

实验开始

第一步 编写测试代码 文件名为test.c

代码语言:javascript复制
#include <stdio.h>

int main(){
 	char *a="he"
	printf("hello pangshu");
	return 0;
}

第二步 将测试代码编译成可执行文件

代码语言:javascript复制
arm-linux-androideabi-gcc.exe -g test.c -o main -static #输出可执行文件名为main

第三步 将可执行文件传送到模拟器中

代码语言:javascript复制
adb push main /data/local/tmp

第四步 将gdbserver工具传送到模拟器中

代码语言:javascript复制
adb push gdbserver /data/local/tmp

第五步 进入模拟器shell窗口,使用gdbserver执行程序

代码语言:javascript复制
./gdbserver 192.168.177.71:23946 main #这里的ip是宿主机的ip  23946为监听端口

第六步 在宿主机中运行gdb工具

代码语言:javascript复制
gdb.exe main  #这里需要指定调试的执行文件

此时进入到gdb模式

第七步 在gdb模式下连接模拟器中的gdbserver

代码语言:javascript复制
(gdb) target remote 192.168.0.1:23946  #这里的ip是模拟器的ip

连接成功后进入断点调试模式,该模式下可以使用~调试指令进行相关调试

开始调试

使用list指令列出所有源代码 可简写为l

使用break指令设置断点位置 可简写为b

使用continue指令运行到断点处 可简写为c

使用step指令进行单步执行 可简写为s

使用next执行进行单步执行 可简写为n

使用print指令打印变量的值 可简写为a

使用quit指令退出调试模式 可简写为q

更多调试指令

GCC调试工具GDB的常用指令

关于arm-linux-androideabi的获取

建议下载Android NDK开发包,然后将里面的GCC套件单独抽出来使用,NDK提供了抽包脚本make-standalone-toolchain,在bulid目录的tools文件夹中可以找到,执行脚本自动抽取打包成压缩包到当前目录:

代码语言:javascript复制
python make-standalone-toolchain.py --arch arm

附加

如果是在非安卓系统的ARM模拟器上,比如qemu模拟器,那么直接使用官方的arm-none-linux-eabi即可,即便是安卓设备,如果没有代码调试需求的话,仅仅是编译运行程序,也是完全够用了

但是你需要进行代码调试的话,由于android系统的安全策略,arm-none-linux-eabi包中的gdbserver无法运行,提示:

代码语言:javascript复制
error: only position independent executables (PIE) are supported.

为了解决这个问题,我们因此采用arm-linux-androideabi,这里面的gdbserver可以正常运行

上面的例子中使用的NDKr17的版本

0 人点赞