朴英敏: 用crash工具分析Linux内核死锁的一次实战

本文简介:

内核死锁问题一般是读写锁(rw_semaphore)和互斥锁(mutex)引起的,本文主要讲如何通过ramdump+crash工具来分析这类死锁问题。

作者简介:

朴英敏,现就职于国内一家手机研发公司,任职资深系统工程师,主要负责安卓系统方面的调试工作。

0、背景知识点

ramdump是内存转存机制,我们可以在某个时刻把系统的内存转存到一个文件中,然后与符号信息(vmlinux)一起导入到trace32crash等内存分析工具中做离线分析。是分析崩溃、死锁、内存泄露等内核疑难问题的重要调试手段。

 

crash是用于解析ramdump的开源工具(http://people.redhat.com/anderson/),是命令行式的交互模式,提供诸多功能强大的调试命令,是分析定位内核复杂问题的利器。

 

死锁是指两个或两个以上的执行流在执行过程中,由于竞争锁资源而造成的一种阻塞的现象。如图:


 

1、问题描述

Android7.1系统中跑monkey时出现界面卡死现象:

1)没有任何刷新,所有输入事件无效,包括电源键

2)watchdog没有重启system_server

3)可以连adb,但ps等调试命令卡住

2、初步分析

由于无法直接用adb调试,用长按电源键的方式进入dump模式并导出ramdump文件,之后再用crash工具载入randump文件开始离线分析。

 

一般卡死时可能是因为核心线程处在UNINTERRUPTIBLE状态,所以先在crash环境下用ps命令查看手机中UNINTERRUPTIBLE状态的线程,参数-u可过滤掉内核线程:

bt命令可查看某个线程的调用栈,我们看一下上面UN状态的最关键的watchdog线程:

从调用栈中可以看到proc_pid_cmdline_read()函数中被阻塞的,对应的代码为:

这里是要获取被某个线程mmmmap_sem锁,而这个锁又被另外一个线程持有。

3、推导读写锁

要想知道哪个线程持有了这把锁,我们得先用汇编推导出这个锁的具体值。可用dis命令看一下proc_pid_cmdline_read()的汇编代码:

0xffffff99a680aaa0处就是调用down_read()的地方,它的第一个参数x0就是sem锁,如:

x0x28寄存器存放的就是sem的值,那x21自然就是mm_struct的地址了,因为mm_structmmap_sem成员的offset就是1040x68),用whatis

  • 9
    点赞
  • 59
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
### 回答1: 《linux内核情景分析pdf》是一本介绍Linux内核的教材,作者是罗柏特(Robert Love),他是一位资深的Linux内核开发者。这本书主要分为三个部分,分别是进程管理、内存管理和文件系统,涵盖了Linux内核中三个最核心的子系统。 在进程管理方面,这本书详细地介绍了进程的创建、调度、信号处理以及线程和多核处理等内容,涉及的知识点非常广泛和深入。在内存管理方面,罗柏特介绍了Linux内核的内存管理机制、虚拟内存和页表等概念,还介绍了内存分配、缓存和交换等操作。在文件系统方面,这本书介绍了文件系统的实现、文件的编写、缓存和磁盘的相关操作等内容。 《linux内核情景分析pdf》这本书的特点是非常系统和细致,作者不仅深入解析了Linux内核的工作原理,还提供了大量的代码实例,让读者可以更深入地理解内核的实现过程。此外,这本书也很适合那些希望深入学习Linux内核的程序员和系统管理员来阅读,因为它涉及了很多实用的知识点和调优技巧。 总的来说,《linux内核情景分析pdf》是一本非常优秀的Linux内核学习资料,它拥有非常严谨的逻辑和非常详细的介绍方式,所以非常适合在Linux内核开发、系统调优和性能优化方面进行借鉴和参考。 ### 回答2: 《Linux内核情景分析》是一本深入浅出地介绍Linux内核的经典之作,也是Linux内核开发者必读的一部书。该书的叙述深入浅出,条理清晰,配合大量的代码和图表,既便于初学者学习理解,又给有经验的开发者带来了不少启示。书中对于Linux系统架构和Linux内核源代码的分析,对于读者深入理解Linux内核工作原理和应用具有非常重要的参考价值。 本书主要围绕内核调试、进程管理、内存管理、文件系统和网络协议栈等方面进行详细的讲解。值得一提的是,书中对于内核的调试章节非常详细,包括了内存泄露、死锁、oops等常见问题的分析与解决方法。另外,书中还有一些经典的案例分析,如进程调度、文件系统实现、网络协议栈实现等,让读者更加深入地了解Linux内核的实现细节以及内核开发者实现的思路。 总之,《Linux内核情景分析》是一本十分经典、权威的Linux内核书籍,对于任何想深入学习Linux内核的开发者以及系统管理员都是一本必读之作。它的内容结构严密、内容丰富、通俗易懂,可以帮助读者快速掌握Linux内核的工作原理和开发技术。 ### 回答3: 《Linux内核情景分析》是由赵炯、张锟著作的一本介绍Linux内核的技术书籍,该书分为三个部分,分别是系统调用、内存管理和进程管理等方面的内容,涵盖了Linux内核的基础知识和高级技术。 书中详细介绍了Linux内核的结构、架构和实现原理,而且通过一系列的案例分析和代码实现,让读者深入了解Linux内核的不同模块,包括进程调度、文件系统、网络等等。通过这些案例,读者能够更好地了解内核的设计和实现方式,同时也能够学会如何利用Linux内核提供的特性进行应用开发和系统优化。 此外,该书还包括了一些高级主题,如虚拟化、调试、性能优化等等。这些主题可以让读者更全面地了解Linux内核的实现细节,并深入研究Linux内核的高级特性。 总之,《Linux内核情景分析》是一本全面介绍Linux内核的技术书籍。它不仅适合Linux内核开发人员、系统管理员和运维人员阅读,也适合对Linux内核有兴趣的读者阅读。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值