一次mmc0: Timeout waiting for hardware interrupt问题分析过程

在Xilinx Zynq7Z15 SoC平台上,搭载Arm Cortex A9双核处理器,使用emmc和btrfs文件系统的设备遇到了mmc0超时等待硬件中断的问题。测试过程中,系统出现异常打印,虽然大多数时候btrfs仍可使用,但偶尔会导致文件系统无法挂载或系统挂死。通过分析驱动、寄存器配置、排除其他外设影响以及中断线程化的影响,发现问题与内核版本3.10的实时调度和中断线程化设置有关,特别是在运行高优先级任务时会触发该问题。
摘要由CSDN通过智能技术生成

1、单板环境

xilinx zynq7z15 soc,Arm cortex A9双核。外设:mmc、emmc、spi、qspi、i2c、gpio、can、uart、cdns-gem(网口)、dsp、usb等。

其中emmc来自arasan,文件系统选用btrfs。内核版本3.10


2、问题现象

开源测试套件在btrfs文件系统中运行(由于单板内存较低),出现如下异常打印:

[sched_delayed] sched: RT throttling activated
mmc0: Timeout waiting for hardware interrupt.
mmc0: Timeout waiting for hardware interrupt.
mmcblk0: error -110 sending status command, retrying
mmc0: Timeout waiting for hardware interrupt.
mmcblk0: error -110 sending status command, retrying
mmc0: Timeout waiting for hardware interrupt.
mmcblk0: error -110 sending status command, aborting
mmc0: Timeout waiting for hardware interrupt.
mmc0: Timeout waiting for hardware interrupt.
mmc0: Timeout waiting for hardware interrupt.
mmc0: Timeout waiting for hardware interrupt.
btrfs: bdev /dev/mmc1 errs: wr 0, rd 1, flush 0, corrupt 0, gen 0
mmc0: card 0001 removed
btrfs: bdev
  • 0
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
Guru Meditation Error: Core 1 panic'ed (Interrupt wdt timeout on CPU1).这个错误的原因是中断看门狗在CPU1上超时。中断看门狗是一种用于监视程序运行情况的机制,当程序在规定的时间内没有完成任务时,中断看门狗会触发重启系统。在这种情况下,可能是由于中断函数中的阻塞操作导致了中断看门狗的超时。根据错误信息显示,在中断函数`onTimer()`中使用了阻塞性函数`Serial.println()`,推测是由于中断阻塞导致没有及时喂狗而触发了重启。此外,错误信息中还提到了调试异常的原因是堆栈金丝雀(watchpoint)触发了,这可能是由于任务(task_name)的堆栈溢出导致的。为了解决这个问题,我们可以考虑以下解决方案: 1. 在中断函数中尽量避免使用阻塞性函数,特别是在低优先级的中断服务程序中 2. 确保中断服务程序尽快完成任务,以避免中断看门狗的超时 3. 检查任务的堆栈使用情况,确保没有堆栈溢出的问题 4. 调整中断看门狗的超时时间,使其能够适应程序的运行情况 5. 可以考虑使用RTOS的任务管理机制,以提高系统的稳定性和可靠性 通过以上的解决方案,我们可以尝试修复Guru Meditation Error: Core 1 panic'ed (Interrupt wdt timeout on CPU1)这个错误。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [[esp32] Guru Meditation 错误解析及解决方案](https://blog.csdn.net/weixin_42942530/article/details/103975237)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [【踩坑日记】ESP32触发定时器中断后无限重启](https://blog.csdn.net/Beihai_Van/article/details/125793806)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值