博客
关于我
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/

你可能感兴趣的文章
mysql8的安装与卸载
查看>>
MySQL8,体验不一样的安装方式!
查看>>
MySQL: Host '127.0.0.1' is not allowed to connect to this MySQL server
查看>>
Mysql: 对换(替换)两条记录的同一个字段值
查看>>
mysql:Can‘t connect to local MySQL server through socket ‘/var/run/mysqld/mysqld.sock‘解决方法
查看>>
MYSQL:基础——3N范式的表结构设计
查看>>
MYSQL:基础——触发器
查看>>
Mysql:连接报错“closing inbound before receiving peer‘s close_notify”
查看>>
mysqlbinlog报错unknown variable ‘default-character-set=utf8mb4‘
查看>>
mysqldump 参数--lock-tables浅析
查看>>
mysqldump 导出中文乱码
查看>>
mysqldump 导出数据库中每张表的前n条
查看>>
mysqldump: Got error: 1044: Access denied for user ‘xx’@’xx’ to database ‘xx’ when using LOCK TABLES
查看>>
Mysqldump参数大全(参数来源于mysql5.5.19源码)
查看>>
mysqldump备份时忽略某些表
查看>>
mysqldump实现数据备份及灾难恢复
查看>>
mysqldump数据库备份无法进行操作只能查询 --single-transaction
查看>>
mysqldump的一些用法
查看>>
mysqli
查看>>
MySQLIntegrityConstraintViolationException异常处理
查看>>