使用FreeRTOS遇到死等异常的解决
目录
- 问题场景:
- 追溯代码:
- 分析代码
问题场景: 在使用apollo3时,调试时发现在ADC中断中一发送信号量就卡住。
追溯代码: 追溯代码发现其实是在ADC中断中调用
xQueueGenericSendFromISR
就卡住,卡住位置如下【使用FreeRTOS遇到死等异常的解决】
文章图片
这个宏定义如下
文章图片
继续往里看,发现卡在下面位置
文章图片
此断言如下
文章图片
所以打印看到的条件是
0>=128
,所以就while(1);
卡在这里了分析代码
文章图片
文章图片
这是获得
ipsr
寄存器的值,保存在ulCurrentInterrupt
变量,那ipsr
寄存器代表的是什么呢,这里有写https://blog.csdn.net/weixin_41572450/article/details/105027244表示中断编号,而这个宏
文章图片
表示用户中断编号是从16开始,1-15就是我们熟悉的内核中断编号,如下
文章图片
文章图片
apollo的中断编号如下
文章图片
可以看到内核部分也是16个,其中ADC的中断编号编到32(注意这里要加上内核的16个编号),
所以
if( ulCurrentInterrupt >= portFIRST_USER_INTERRUPT_NUMBER )这个条件是说当产生了外部中断,就走if条件里面,
文章图片
文章图片
文章图片
归纳下就是
ucCurrentPriority = ( uint8_t * )(0xE000E3F0+ulCurrentInterrupt)即ucCurrentPriority = ( uint8_t * )(0xE000E3F0+32)即ucCurrentPriority = ( uint8_t * )(0xE000E400+16)
其中,0xE000E400是NVIC->IP寄存器地址
文章图片
这里存放的外部中断的中断优先级,如下
文章图片
所以这里的0>=128的0是IP[ADC]寄存器复位值,就是把ADC中断优先级设置成0了,说明初始化时没有设置ADC优先级,检查下果然漏了,添加下面设置就没问题了
文章图片
那128是怎么来的?如下
文章图片
文章图片
文章图片
所以是128.
最后发现之前大段英文注释有说这个问题,最后还有网址
https://www.freertos.org/FAQHelp.html
如下说明
文章图片
以上就是使用FreeRTOS遇到死等异常的解决的详细内容,更多关于FreeRTOS死等问题的资料请关注脚本之家其它相关文章!
推荐阅读
- 最佳实践 | 微搭低代码使用 Excel 创建应用
- 一场由TiCDC异常引发的GC不干活导致的Tikv硬盘使用问题
- 技能类相关|【工具使用】SecureCRT的下载、安装图文详细过程介绍
- Vue中使用jsencrypt进行RSA非对称加密的操作方法
- FreeRTOS实时操作系统空闲任务的阻塞延时实现
- vue中computed和watch的使用实例代码解析
- Vue使用MD5对前后端进行加密的实现
- mosquitto使用与常用配置
- 使用|使用 LOAD DATA LOCAL INFILE,sysbench 导数速度提升30%
- 电源自动切换电路