溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

使用FreeRTOS遇到死等異常怎么解決

發(fā)布時間:2022-04-08 10:08:14 來源:億速云 閱讀:766 作者:iii 欄目:開發(fā)技術

本篇內容介紹了“使用FreeRTOS遇到死等異常怎么解決”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!

問題場景:

在使用apollo3時,調試時發(fā)現(xiàn)在ADC中斷中一發(fā)送信號量就卡住。

追溯代碼:

追溯代碼發(fā)現(xiàn)其實是在ADC中斷中調用xQueueGenericSendFromISR就卡住,卡住位置如下

使用FreeRTOS遇到死等異常怎么解決

這個宏定義如下

使用FreeRTOS遇到死等異常怎么解決


繼續(xù)往里看,發(fā)現(xiàn)卡在下面位置

使用FreeRTOS遇到死等異常怎么解決

此斷言如下

使用FreeRTOS遇到死等異常怎么解決

所以打印看到的條件是0>=128,所以就while(1);卡在這里了

分析代碼

使用FreeRTOS遇到死等異常怎么解決

使用FreeRTOS遇到死等異常怎么解決

這是獲得ipsr寄存器的值,保存在ulCurrentInterrupt變量,那ipsr寄存器代表的是什么呢,這里有寫https://blog.csdn.net/weixin_41572450/article/details/105027244
表示中斷編號,而這個宏

使用FreeRTOS遇到死等異常怎么解決

表示用戶中斷編號是從16開始,1-15就是我們熟悉的內核中斷編號,如下

使用FreeRTOS遇到死等異常怎么解決

使用FreeRTOS遇到死等異常怎么解決

apollo的中斷編號如下

使用FreeRTOS遇到死等異常怎么解決

可以看到內核部分也是16個,其中ADC的中斷編號編到32(注意這里要加上內核的16個編號),
所以

if( ulCurrentInterrupt >= portFIRST_USER_INTERRUPT_NUMBER )

這個條件是說當產(chǎn)生了外部中斷,就走if條件里面,

使用FreeRTOS遇到死等異常怎么解決

使用FreeRTOS遇到死等異常怎么解決

使用FreeRTOS遇到死等異常怎么解決

歸納下就是

ucCurrentPriority = ( uint8_t * )(0xE000E3F0+ulCurrentInterrupt)
即
ucCurrentPriority = ( uint8_t * )(0xE000E3F0+32)
即
ucCurrentPriority = ( uint8_t * )(0xE000E400+16)

其中,0xE000E400是NVIC->IP寄存器地址

使用FreeRTOS遇到死等異常怎么解決

這里存放的外部中斷的中斷優(yōu)先級,如下

使用FreeRTOS遇到死等異常怎么解決

所以這里的0>=128的0是IP[ADC]寄存器復位值,就是把ADC中斷優(yōu)先級設置成0了,說明初始化時沒有設置ADC優(yōu)先級,檢查下果然漏了,添加下面設置就沒問題了

使用FreeRTOS遇到死等異常怎么解決

那128是怎么來的?如下

使用FreeRTOS遇到死等異常怎么解決

使用FreeRTOS遇到死等異常怎么解決

使用FreeRTOS遇到死等異常怎么解決

所以是128.

最后發(fā)現(xiàn)之前大段英文注釋有說這個問題,最后還有網(wǎng)址
https://www.freertos.org/FAQHelp.html
如下說明

使用FreeRTOS遇到死等異常怎么解決

“使用FreeRTOS遇到死等異常怎么解決”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關的知識可以關注億速云網(wǎng)站,小編將為大家輸出更多高質量的實用文章!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內容。

AI