addr2line命令解析native backtrace

内容


带symbols信息的lib库位于out/target/product/{ProjectName}/symbols/system/lib/
注意:lib库必须是与用来复现问题的bin档同一次build出来的才可以;
 
Q:如何check lib库是否带有symbols?
A:将lib库copy到linux 开发环境下,在linux Terminal(终端命令行窗口)里面通过file命令来check:
file libhwui.so
若印出的信息后面带有not stripped,则是带symbols信息;
若是stripped,则不带symbols信息;
 
addr2line使用方法:
步骤一:将需要解析的backtrace对应的lib库拷贝到android gcc目录下
若是64位lib库,将带symbols信息的lib库拷贝到任意一份Android L及以上版本的代码路径下:platform(alps)/prebuilts/gcc/linux-x86/aarch64/ cit-aarch64-linux-android-4.9/bin/
 
若是32位的lib库,将带symbols信息的lib库拷贝到Android KK某版本对应代码下:
platform(alps)/prebuilts/gcc/linux-x86/arm/ cit-arm-linux-androideabi-4.8/bin/
 
备注:黄色部分的路径不一定非要是cit开头的,在该目录下找一个版本最新的目录进去即可
 
步骤二:用addr2line来逐行解析backtrace:
例如SWT_JBT_TRACES里面某2行trace是:
native: #02 pc 000 77540  /system/lib64/libhwui.so
native: #03 pc 00051d90  /system/lib64/libhwui.so
 
那么如下命令就可以解析出上述trace的代码行号:
addr2line -C -e libhwui.so -f 0x 77540
 
如下是上述2行trace的解析记录:
[xxx@mszswglx07 bin]$addr2line -C -e libhwui.so -f 0x77540
android::uirenderer::Task<android::uirenderer::VertexBuffer*>::getResult() const
/home/jenkins/workspace/5918/build_chambal_cosmos/linux_repo/system/core/include/utils/Condition.h:106
 
[xxx@mszswglx07 bin]$addr2line -C -e libhwui.so -f 0x51d90
android::uirenderer::OpenGLRenderer::drawRoundRect(float, float, float, float, float, float, SkPaint const*)
/home/jenkins/workspace/5918/build_chambal_cosmos/linux_repo/frameworks/base/libs/hwui/OpenGLRenderer.cpp:2660
  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值