写点什么

鸿蒙 Flutter 之解析 flutter 相关的 cppcrash 堆栈

作者:flfljh
  • 2024-12-18
    湖南
  • 本文字数:1428 字

    阅读完需:约 5 分钟

鸿蒙 Flutter 之解析 flutter 相关的 cppcrash 堆栈

本文介绍如何解析 flutter 鸿蒙化版本 libflutter.so 相关的崩溃堆栈。


介绍


llvm-addr2line 工具是一个可以将指令的地址和可执行映像转换成文件名、函数名和源代码行数的工具。一般适用于带有 symbol 信息的 so 库。


工具位置


DevEco StudioCommand Line Tools for HarmonyOS 的 sdk 目录下有这个工具,对应路径如下


  • Windows: sdk/default/openharmony/native/llvm/bin/llvm-addr2line.exe

  • Linux/Mac: sdk/default/openharmony/native/llvm/bin/llvm-addr2line


可以将 llvm-addr2line 所在目录配置到环境变量 PATH 里,如


export PATH=/Applications/DevEco-Studio.app/Contents/sdk/default/openharmony/native/llvm/bin:$PATH
复制代码


使用命令


llvm-addr2line -f -e so.unstripped/libflutter.so [addr1] [addr2]
复制代码


如何获取带有 symbol 的 libflutter.so 文件


1 使用本地编译的 engine 产物


  • debug 版本

  • src/out/ohos_debug_unopt_arm64/so.unstripped/libflutter.so

  • release 版本

  • src/out/ohos_release_arm64/so.unstripped/libflutter.so

  • profile 版本

  • src/out/ohos_profile_arm64/so.unstripped/libflutter.so


2 在云端产物中下载



使用示例


libflutter.so 相关的部分崩溃日志:


#00 pc 00000000001b5a34 /system/lib/ld-musl-aarch64.so.1(__timedwait_cp+188)(ef860a9c8bd64e964a4dd4ef838876e1)#01 pc 00000000001b7a3c /system/lib/ld-musl-aarch64.so.1(__pthread_cond_timedwait+188)(ef860a9c8bd64e964a4dd4ef838876e1)#02 pc 000000000021d450 /data/storage/el1/bundle/libs/arm64/libflutter.so(85c51e03a4f191b946582701e79e1be4a0c83959)#03 pc 00000000001f21f4 /data/storage/el1/bundle/libs/arm64/libflutter.so(85c51e03a4f191b946582701e79e1be4a0c83959)
复制代码


获取带有 symbol 的文件 so.unstripped/libflutter.so ,可以将错误堆栈中的地址转换为具体的报错代码行数。


执行命令:


llvm-addr2line -f -e so.unstripped/libflutter.so 00000000001b5a34 00000000001b7a3c 000000000021d450 00000000001f21f4
复制代码


解析后的结果:


_ZNSt21_LIBCPP_ABI_NAMESPACE21__libcpp_condvar_waitB6v15004EP14pthread_cond_tP15pthread_mutex_t/home/hazy/tools/ohos-v5.0.3.900/command-line-tools/sdk/default/openharmony/native/llvm/include/c++/v1/__threading_support:335_ZN7flutter16PlatformViewOHOS13NotifyChangedERK7SkISize/home/hazy/work/engine_build/engine_daily/src/out/ohos_release_arm64/../../flutter/shell/platform/ohos/platform_view_ohos.cpp:192
复制代码


用户头像

flfljh

关注

还未添加个人签名 2024-10-29 加入

还未添加个人简介

评论

发布
暂无评论
鸿蒙Flutter之解析flutter相关的cppcrash堆栈_flfljh_InfoQ写作社区