Guru Meditation Error: Core 1 panic‘ed (LoadProhibited). Exception was unhandled.

使用esp32(ESP32-D0WD-V3 (revision v3.1))时, 出现以下错误导致异常重启:

Guru Meditation Error: Core  1 panic'ed (LoadProhibited). Exception was unhandled.
Core 1 register dump:
PC      : 0x400d3488  PS      : 0x00060030  A0      : 0x800d355c  A1      : 0x3ffb1bb0  
A2      : 0x00000000  A3      : 0x3ffb1bff  A4      : 0x00000001  A5      : 0x00000001  
A6      : 0x00000000  A7      : 0x00000000  A8      : 0x00000000  A9      : 0x00000000  
A10     : 0x00000000  A11     : 0x3ffcb8fc  A12     : 0x00000050  A13     : 0x00000001  
A14     : 0x00000000  A15     : 0x00000000  SAR     : 0x0000000a  EXCCAUSE: 0x0000001c  
EXCVADDR: 0x00000008  LBEG    : 0x4000c2e0  LEND    : 0x4000c2f6  LCOUNT  : 0xffffffff

找了相关资料, 大家推测可能是访问/写入了错误的内存导致:
尝试了修改了一些代码, 发现是将一个指针声明为非局部变量导致, 具体原因没有找到, 令人费解…
我将以下写法:

SharedParams* sp1 = nullptr;

在这里插入图片描述

修改为:

有些太离谱了
在这里插入图片描述

在此之前, 我可以保证sp1是在task中初始化的, 且类型正确, 因为部分访问sp1代可以正常运行.
最最重要的是, 这个异常是在我访问sp1完成之后出现的.
除非断电, 否则sp1永不销毁.
等以后再补充吧, 目前找不出具体原因了…

再来看一段代码吧, 这是在Core0上运行的, 完全没有一点问题.
Core1的sp1和Core0的sp是同一个指针…
结果Core1先崩溃了:
在这里插入图片描述
在这里插入图片描述

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
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 ]
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值