Linux fdisk -l引起内核死锁分析

2024-04-24 19:08

本文主要是介绍Linux fdisk -l引起内核死锁分析,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Linux fdisk -l查看分区,结果打印一个分区后引起内核死锁。

打印

root@www:~# fdisk -lDisk /dev/mtdblock0: 2 MB, 2621440 bytes
255 heads, 63 sectors/track, 0 cylinders
Units = cylinders of 16065 * 512 = 8225280 bytesDisk /dev/mtdblock0 doesn't contain a valid partition tableINFO: task update_mcu.sh:254 blocked for more than 120 seconds.Not tainted 3.18.20 #2
"echo 0 > /proc/sys/kernel/hung_task_timeout_secs" disables this message.
update_mcu.sh   D c0887e9c     0   254      1 0x00000000
Backtrace: 
[<c0887b60>] (__schedule) from [<c08880f4>] (schedule+0xa0/0xa4)r10:019b00ec r9:00000002 r8:ffffffff r7:cb0c2200 r6:ce94d448 r5:cd81a018r4:cd81a000
[<c0888054>] (schedule) from [<c08883e4>] (schedule_preempt_disabled+0x30/0x40)
[<c08883b4>] (schedule_preempt_disabled) from [<c0889c3c>] (__mutex_lock_slowpath+0xc0/0x188)r4:ce94d444 r3:00000001
[<c0889b7c>] (__mutex_lock_slowpath) from [<c0889d3c>] (mutex_lock+0x38/0x3c)r9:ce94d444 r8:cf844590 r7:cf844500 r6:cd81b938 r5:cf8449f4 r4:ce94d010
[<c0889d04>] (mutex_lock) from [<c03c8f74>] (msm_nand_read_oob+0x3f0/0x8fc)
[<c03c8b84>] (msm_nand_read_oob) from [<c03c95c8>] (msm_nand_read_partial_page+0x148/0x22c)

分析

可以看到是内核死锁超时2分钟打印出backtrace,死锁函数msm_nand_read_oob中的mutex_lock锁等待超时死锁,通过Linux下使用额外增加文件方式查看debug信息添加开关代码如下:

static int msm_nand_read_oob(struct mtd_info *mtd, loff_t from,struct mtd_oob_ops *ops)
{if(1 == io_run_num) {printk(KERN_ERR "eason in\n");}mutex_lock(&info->lock);if(1 == io_run_num) {printk(KERN_ERR "eason out\n");}

fdisk -l死锁后打印如下:

eason in
eason out
QCMAP:bringup v6
enter sleep, msm_uport->obs: 0
msm_hs_pm_resume(): jun test1
resule from sleep, msm_uport->obs: 0
eason in
enter sleep, msm_uport->obs: 0
没有out出

移远回复说不支持查看nand flash,如果有其他设备可以使用fdisk /dev/*进行查看,原因未告知,且暂不解决;我个人认为这不合理的,其他设备上面fdisk就可以查看flash,且导致了内核死锁应该就是可以查看原因和解决的。

原因待继续查。。。

这篇关于Linux fdisk -l引起内核死锁分析的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/932589

相关文章

Linux系统中卸载与安装JDK的详细教程

《Linux系统中卸载与安装JDK的详细教程》本文详细介绍了如何在Linux系统中通过Xshell和Xftp工具连接与传输文件,然后进行JDK的安装与卸载,安装步骤包括连接Linux、传输JDK安装包... 目录1、卸载1.1 linux删除自带的JDK1.2 Linux上卸载自己安装的JDK2、安装2.1

Linux卸载自带jdk并安装新jdk版本的图文教程

《Linux卸载自带jdk并安装新jdk版本的图文教程》在Linux系统中,有时需要卸载预装的OpenJDK并安装特定版本的JDK,例如JDK1.8,所以本文给大家详细介绍了Linux卸载自带jdk并... 目录Ⅰ、卸载自带jdkⅡ、安装新版jdkⅠ、卸载自带jdk1、输入命令查看旧jdkrpm -qa

Linux samba共享慢的原因及解决方案

《Linuxsamba共享慢的原因及解决方案》:本文主要介绍Linuxsamba共享慢的原因及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux samba共享慢原因及解决问题表现原因解决办法总结Linandroidux samba共享慢原因及解决

Spring事务中@Transactional注解不生效的原因分析与解决

《Spring事务中@Transactional注解不生效的原因分析与解决》在Spring框架中,@Transactional注解是管理数据库事务的核心方式,本文将深入分析事务自调用的底层原理,解释为... 目录1. 引言2. 事务自调用问题重现2.1 示例代码2.2 问题现象3. 为什么事务自调用会失效3

新特性抢先看! Ubuntu 25.04 Beta 发布:Linux 6.14 内核

《新特性抢先看!Ubuntu25.04Beta发布:Linux6.14内核》Canonical公司近日发布了Ubuntu25.04Beta版,这一版本被赋予了一个活泼的代号——“Plu... Canonical 昨日(3 月 27 日)放出了 Beta 版 Ubuntu 25.04 系统镜像,代号“Pluc

找不到Anaconda prompt终端的原因分析及解决方案

《找不到Anacondaprompt终端的原因分析及解决方案》因为anaconda还没有初始化,在安装anaconda的过程中,有一行是否要添加anaconda到菜单目录中,由于没有勾选,导致没有菜... 目录问题原因问http://www.chinasem.cn题解决安装了 Anaconda 却找不到 An

Spring定时任务只执行一次的原因分析与解决方案

《Spring定时任务只执行一次的原因分析与解决方案》在使用Spring的@Scheduled定时任务时,你是否遇到过任务只执行一次,后续不再触发的情况?这种情况可能由多种原因导致,如未启用调度、线程... 目录1. 问题背景2. Spring定时任务的基本用法3. 为什么定时任务只执行一次?3.1 未启用

Linux安装MySQL的教程

《Linux安装MySQL的教程》:本文主要介绍Linux安装MySQL的教程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux安装mysql1.Mysql官网2.我的存放路径3.解压mysql文件到当前目录4.重命名一下5.创建mysql用户组和用户并修

Linux上设置Ollama服务配置(常用环境变量)

《Linux上设置Ollama服务配置(常用环境变量)》本文主要介绍了Linux上设置Ollama服务配置(常用环境变量),Ollama提供了多种环境变量供配置,如调试模式、模型目录等,下面就来介绍一... 目录在 linux 上设置环境变量配置 OllamPOgxSRJfa手动安装安装特定版本查看日志在

Linux系统之主机网络配置方式

《Linux系统之主机网络配置方式》:本文主要介绍Linux系统之主机网络配置方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、查看主机的网络参数1、查看主机名2、查看IP地址3、查看网关4、查看DNS二、配置网卡1、修改网卡配置文件2、nmcli工具【通用