博客
关于我
Linux系统上的Breakpad编译和使用
阅读量:142 次
发布时间:2019-02-26

本文共 1359 字,大约阅读时间需要 4 分钟。

  1. 下载源码

  2. 下载依赖包

    PS:无该依赖包,会报错src/client/linux/crash_generation/crash_generation_client.cc:40:10: fatal error: third_party/lss/linux_syscall_support.h: 没有那个文件或目录

    下载完后,在/third_part/目录下创建lss文件夹,并将linux_syscall_support.h拷贝进来。

  3. 编译

    ./configure && make

    ps:Android studio 的安装/bin/lldb/bin目录下也有一个可以直接使用。

  4. 使用

  • 解析dmp,定位问题位置
    ./minidump_stackwalk *.dmp > crash.txt
Operating system: Android                 0.0.0 Linux 4.9.117+ #34 SMP PREEMPT Wed Apr 14 09:45:19 CST 2021 armv7lCPU: arm    ARMv7 ARM part(0x4100c070) features: half,thumb,fastmult,vfpv2,edsp,neon,vfpv3,tls,vfpv4,idiva,idivt    4 CPUsGPU: UNKNOWNCrash reason:  SIGSEGV /SEGV_MAPERRCrash address: 0x0Process uptime: not availableThread 0 (crashed)  //问题线程0  libcrash-lib.so + 0x7b2  //问题位置和寄存器信息    r0 = 0x00000000    r1 = 0x00000001    r2 = 0xbea1e74c    r3 = 0xacb13680    r4 = 0xa94750f0    r5 = 0x00000001    r6 = 0x00000000    r7 = 0xbea1e728    r8 = 0x00000000    r9 = 0xacb4e000   r10 = 0xbea1e750   r12 = 0x909d6fd8    fp = 0xacb4e000    sp = 0xbea1e714    lr = 0x909d37cf    pc = 0x909d37b2   Found by: given as instruction pointer in context1  libart.so + 0x41b279
  • 符号解析,反解符号
    ./arm-linux-androideabi-addr2line -f -C -e libcrash-lib.so 0x77e
xxx/xxx/xxx/app/src/main/cpp/crash.cpp:6//crahs.cpp#include 
#include
void Crash() { volatile int *a = (int *) (NULL); *a = 1;//第6行}

转载地址:http://xkof.baihongyu.com/

你可能感兴趣的文章
MySql中 delimiter 详解
查看>>
MYSQL中 find_in_set() 函数用法详解
查看>>
MySQL中auto_increment有什么作用?(IT枫斗者)
查看>>
MySQL中B+Tree索引原理
查看>>
mysql中cast() 和convert()的用法讲解
查看>>
mysql中datetime与timestamp类型有什么区别
查看>>
MySQL中DQL语言的执行顺序
查看>>
mysql中floor函数的作用是什么?
查看>>
MySQL中group by 与 order by 一起使用排序问题
查看>>
mysql中having的用法
查看>>
MySQL中interactive_timeout和wait_timeout的区别
查看>>
mysql中int、bigint、smallint 和 tinyint的区别、char和varchar的区别详细介绍
查看>>
mysql中json_extract的使用方法
查看>>
mysql中json_extract的使用方法
查看>>
mysql中kill掉所有锁表的进程
查看>>
mysql中like % %模糊查询
查看>>
MySql中mvcc学习记录
查看>>
mysql中null和空字符串的区别与问题!
查看>>