Android源代码级调试环境配置

来源:互联网 发布:网络结婚证制作软件 编辑:程序博客网 时间:2024/06/15 04:36

本文描述使用AOSP进行调试的环境配置,最终达到源码级调试目标。

1 环境&工具

硬件环境 软件环境 工具 LG Nexus 5(真机) Android 4.4.2 AOSP Prebuilt

2 步骤

2.1 配置环境

2.1.1 获取特定设备项目

这步是获取特定于设备的项目,这些项目是配置环境所需要的,至于需要git那些项目根据设备不同而不同,项目目录存在于{source-path}/device/{device-name}/,例如,我们的环境目录为/Android/android_442/device/lge/,命令如下:
这里写图片描述

问题:需要git那些项目呢?这些项目是做什么的?在我编译后的4.4.2真机中没有git任何项目,在调试过程中还未发现问题,希望后面遇到问题后再补充。

2.1.2 初始化AOSP环境

获取项目完成后,通过下载build/envsetup.sh脚本并执行lunch目录来配置和初始化AOSP生成环境,命令如下:
这里写图片描述
这里写图片描述
这里写图片描述
注:如果不执行这步骤的话,将影响后续“链接GDB客户端”步骤,会出现下面异常提示:
这里写图片描述

2.1.3 配置设备

AOSP的prebuilts目录中包含了调试所需的gdbserver二进制文件,只需通过命令拷贝到设备上即可,目录如下:
这里写图片描述

如果使用USB,需要ADB的端口转发功能为GDB客户端打开一个管道,命令如下:

adb forward tcp:31337 tcp:31337

2.2 附加到进程

2.2.1 启动进程

可以使用带有start参数的am命令来启动目标进程,也可以手动直接打开。

2.2.2 查询进程ID

以mediaserver进程为例,通过下面命令:
这里写图片描述

2.2.3 attach 进程

退出ADB shell 使用附加模式启动gdbserver,命令如下:

$ adb shell su -c /data/local/tmp/gdbserver --attach tcp:31337 2194

这里写图片描述

启动后通过Control-Z组合键挂起该进程,然后通过bg命令将adb进程转到后台运行。

2.3 连接GDB客户端

直接使用命令:

$ arm-eabi-gdb -q

这里写图片描述

2.4 使用符号调试

2.4.1 获取符号

通过编译AOSP支持的设备源代码,大部分符号信息文件会与发布版本文件同时生成。但由于包含符号的二进制文件非常大,如果直接将其刷入设备,会很快耗尽系统的可用内存空间。因此在远程调试时,可以将这些带有符号的大文件与运行在设备上的无符号二进制文件配合使用。

除了编译生成一个完整的设备镜像,也可以通过mmm和mm命令来单独编译需要的组件,编译系统会将包含符号文件写入out/target/product/{build-number}/symbols目录下。

2.4.2 使用符号

gdbclient、ndk-gdb和直接使用GDB三种方式都需要加载获取的符号来改进调试体验,但三种方法加载符号方式各不同,这里讲述gdbclient和直接使用GDB的方法及优缺点。

gdbclient会自动使用编译生成的符号。Gdbclient通过Android编译系统获取生成的符号并指示GDB客户端在其中查找。但gdbclient会默认使用生成的几乎所有模块符号,所以这个过程非常慢,而且大部分情况下,完全没有必要为所有模块加载符号。

所以,直接调用AOSP GDB客户端是调试原生代码的首选方法。此方法能够最大化的控制目标设备和GDB客户端自身的情况,同时调试不同的项目时,也可以支持管理项目的特定的配置。

要搭建项目特定的最佳调试环境的步骤如下:

  • 创建存放项目相关数据的目录:
    这里写图片描述

  • 为想要加载的符号的模块创建符号链接,为了加快加载过程,应该只为有限的需要的模块加载符号:
    这里写图片描述

    其中,包含了核心模块libstagefright.so、libstdc++.so和libdvm.so(Dalvik VM)。

  • 创建GDB脚本:
    这里写图片描述
    这个命令告诉GDB客户端在当前目录下查找符号文件。

2.4.3 源码级调试

在新建的符号目录进行attach服务器目标进程,即可实现源码级调试。这里以mediaserver进程调试为例:

$ arm-eabi-gdb -q -x script.gdb app_process

这里写图片描述
这里写图片描述

0 0
原创粉丝点击