使用FreeRTOS遇到死等異常的解決
問題場景:
在使用apollo3時,調(diào)試時發(fā)現(xiàn)在ADC中斷中一發(fā)送信號量就卡住。
追溯代碼:
追溯代碼發(fā)現(xiàn)其實是在ADC中斷中調(diào)用xQueueGenericSendFromISR
就卡住,卡住位置如下
這個宏定義如下
繼續(xù)往里看,發(fā)現(xiàn)卡在下面位置
此斷言如下
所以打印看到的條件是0>=128
,所以就while(1);
卡在這里了
分析代碼
這是獲得ipsr
寄存器的值,保存在ulCurrentInterrupt
變量,那ipsr
寄存器代表的是什么呢,這里有寫https://blog.csdn.net/weixin_41572450/article/details/105027244
表示中斷編號,而這個宏
表示用戶中斷編號是從16開始,1-15就是我們熟悉的內(nèi)核中斷編號,如下
apollo的中斷編號如下
可以看到內(nèi)核部分也是16個,其中ADC的中斷編號編到32(注意這里要加上內(nèi)核的16個編號),
所以
if( ulCurrentInterrupt >= portFIRST_USER_INTERRUPT_NUMBER )
這個條件是說當(dāng)產(chǎn)生了外部中斷,就走if條件里面,
歸納下就是
ucCurrentPriority = ( uint8_t * )(0xE000E3F0+ulCurrentInterrupt) 即 ucCurrentPriority = ( uint8_t * )(0xE000E3F0+32) 即 ucCurrentPriority = ( uint8_t * )(0xE000E400+16)
其中,0xE000E400是NVIC->IP寄存器地址
這里存放的外部中斷的中斷優(yōu)先級,如下
所以這里的0>=128的0是IP[ADC]寄存器復(fù)位值,就是把ADC中斷優(yōu)先級設(shè)置成0了,說明初始化時沒有設(shè)置ADC優(yōu)先級,檢查下果然漏了,添加下面設(shè)置就沒問題了
那128是怎么來的?如下
所以是128.
最后發(fā)現(xiàn)之前大段英文注釋有說這個問題,最后還有網(wǎng)址
https://www.freertos.org/FAQHelp.html
如下說明
以上就是使用FreeRTOS遇到死等異常的解決的詳細內(nèi)容,更多關(guān)于FreeRTOS死等問題的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
FreeRTOS實時操作系統(tǒng)空閑任務(wù)的阻塞延時實現(xiàn)
這篇文章主要為大家介紹了FreeRTOS實時操作系統(tǒng)空閑任務(wù)的阻塞延時實現(xiàn),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步早日升職加薪2022-04-04FreeRTOS實時操作系統(tǒng)內(nèi)核配置說明
這篇文章主要為大家介紹了FreeRTOS實時操作系統(tǒng)內(nèi)核配置及說明,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步早日升職加薪2022-04-04FreeRTOS實時操作系統(tǒng)的列表與列表項操作示例
這篇文章主要為大家介紹了FreeRTOS實時操作系統(tǒng)的列表與列表項操作示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步早日升職加薪2022-04-04FreeRTOS實時操作系統(tǒng)在Cortex-M3上的移植過程
這篇文章主要為大家介紹了FreeRTOS實時操作系統(tǒng)在Cortex-M3上的移植過程的示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步早日升職加薪2022-04-04FreeRTOS實時操作系統(tǒng)的內(nèi)存管理分析
這篇文章主要為大家介紹了FreeRTOS實時操作系統(tǒng)的內(nèi)存管理的示例分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步早日升職加薪2022-04-04