那曲檬骨新材料有限公司

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

關于如何判斷CPU是否正在執行中斷函數?

黃工的嵌入式技術圈 ? 來源:黃工的嵌入式技術圈 ? 2020-03-12 11:25 ? 次閱讀

1.這是一個有許多經驗的攻城獅都遇到過的坑,本文教你正確繞過這個坑;

2.教大家了解__get_CONTROL的用法,及xQueueSend和xQueueSendFromISR的區別;

Ⅰ問題來源

今天在FreeRTOS系統上移植了部分別人寫的代碼,移植前仔細看了下源碼,確認沒問題后,編譯,下載,運行,突然“死機了”······

于是,我又再次確認了移植的代碼,沒有發現Bug所在。此時,我開啟了在線調試功能,發現程序死在了“vPortEnterCritical”函數中的斷言語句里。如下:

Ⅱ解決問題的過程

我解決問題還是按照常規思維,一步一步跟蹤,很多問題其實都是類似道理,有規律可循。

1.查看configASSERT斷言做了什么事?

跟蹤代碼:

#define configASSERT( x ) if( ( x ) == 0 ) { taskDISABLE_INTERRUPTS(); for( ;; ); }

其中,里面taskDISABLE_ INTERRUPTS();就是關中斷的意思。緊跟著后面執行了for( ;; );

看到這里,我明白了一點,就是死在for( ;; );里面了。

2.進一步查找問題

我又開始了思考,為什么會執行到這里來呢?為什么會執行portDISABLE_INTERRUPTS(); uxCriticalNesting++; if( uxCriticalNesting == 1 )等這些語句呢?

這就是我們常說的“臨界段”,這一點我學習RTOS的時候已經明白了,這一個函數肯定會被調用。于是,我把目標鎖定了portNVIC_INT_CTRL_REG這個參數

#define portNVIC_INT_CTRL_REG ( * ( ( volatile uint32_t * ) 0xe000ed04 ) )

0xe000ed04? 這個地址,相信之前了解過NVIC的都知道,就是Interrupt control state register.即中斷控制狀態寄存器。

3.確定問題點

從上面的分析,其實問題都已經浮現出來了。于是查看了【Cortex-M3權威指南】中相關的內容。(PS:這本手冊真的能解決很多問題,翻譯成中文,對大部分朋友來說是一件好事)

其實,有這個一個寄存器:控制寄存器(CONTROL),里面講述的非常清楚:

看上圖,大概意思就是:在中斷模式下,CONTROL[1]為0。于是,又把思路轉向了core_cm3.c文件中的源碼:

__ASM uint32_t __get_CONTROL(void){ mrs r0, control bx lr}

懂一點匯編的,相信在這里都已經明白,大概意思就是過去控制寄存器狀態,這也是我開篇說的,讓大家了解的__get_CONTROL。

4.在線調試,分析結論

上面分析出來控制寄存器CONTROL,那么我們需要驗證是否符合我們預期的效果,通過在線調試,斷電就可得出,如下面兩圖:

a.在非中斷情況下的值0x02

b.在中斷情況下的值0x00

至此,問題已經查明就是CONTROL。

Ⅲget_CONTROL的應用

一般在RTOS實時操作系統中,常常使用隊列來處理我們的數據,也就是常說的FIFO(先入先出)。

比如:我們在FreeRTOS系統中,要將UART發送、或者接收的數據加入隊列:在中斷里加入隊列,在非中斷里加入隊列。這個時候,就需要使用get_CONTROL來判斷當前是否處于中斷函數里。

當然,類似的情況很多,像CAN、I2C、SPI等一樣的道理。

舉例,CAN總線發送數據加入隊列:

Ⅳ多說兩句

以上的分析,看似很簡單,其實包含的內容很多,可能有很多人覺得:這些問題對于我來說是小菜一碟。

說句實話,我和大家一樣,都是慢慢學習過來的,這里面跳過的坑其實很多,是因為我跳過了太多的坑,所以才會對一些問題更加了解。

上面類似的問題,在我學習RTOS、移植CANOpen等等那些時候都有遇到過,想要知道我遇到那些問題,處理起來難不難,明確回答:很多問題在初學的時候都很難,但我還是走過來了。

說到這里,多說一句,關于問問題的話,后臺每天都有許多人問我問題,但是有些問題其實真的很簡單,比如:編譯有個變量未調用的警告、重復定義,多了一個分號等,這些看一下提示都知道。不要告訴我你英語差,我英語初高中從來都沒有及格過,依然還是得看英文手冊。確實不懂,安裝一個翻譯軟件不難吧。

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • cpu
    cpu
    +關注

    關注

    68

    文章

    10904

    瀏覽量

    213024
  • RTOS
    +關注

    關注

    22

    文章

    819

    瀏覽量

    119889
  • FreeRTOS
    +關注

    關注

    12

    文章

    484

    瀏覽量

    62398
收藏 人收藏

    評論

    相關推薦

    如何判斷電路是否為高頻電路

    在數字電路中,工程師需要判斷該電路是否高頻電路,以此確保電路性能穩定、減少信號失真和避免傳輸線效應,本文將分享如何判斷電路是否為高頻電路。 1、信號的上升沿/下降沿時間(Tr) 若信號
    的頭像 發表于 01-20 10:49 ?175次閱讀

    全面解析:如何精準判斷SMT貼片打樣是否合格?

    一站式PCBA智造廠家今天為大家講講SMT貼片打樣是否合格如何判斷?判斷SMT貼片打樣是否合格的方法。在電子設備制造領域,SMT貼片打樣是產品開發和生產過程中的關鍵環節。合格的SMT貼
    的頭像 發表于 01-07 09:29 ?95次閱讀

    c51單片機中斷

    優先級的中斷正在處理,CPU 會暫停當前正在執行的指令,將程序計數器(PC)等關鍵寄存器的值保存到堆棧中,然后根據
    發表于 11-25 21:43

    關于中斷知識學習總結筆記

    可以對變量進行賦值、進行條件判斷并根據結果執行不同分支代碼等。 函數調用能力 它們都具備調用其他函數的能力。在一個復雜的項目中,無論是普通函數
    發表于 11-23 11:23

    如何判斷繼電器是否正常工作

    判斷繼電器是否正常工作是一個涉及多個方面的過程,主要包括外觀檢查、電氣性能測試以及實際應用中的表現等。以下將從這些方面詳細闡述如何判斷繼電器是否正常工作。
    的頭像 發表于 09-10 11:06 ?1136次閱讀

    【「ARM MCU嵌入式開發 | 基于國產GD32F10x芯片」閱讀體驗】+閱讀中斷

    進行通信的機制,外部通過中斷的方式來通知處理器有事情發生了,而處理器有專門的模塊根據發生的事情的緊急程序來決定是否要暫停正在執行的程序來響應中斷
    發表于 09-01 23:59

    求助,關于PSoC6在CM0+中用于進入休眠和深度休眠的函數的問題

    : \" 執行 WFI 指令時,CPU 進入休眠或深度休眠狀態(取決于 SCR 寄存器的 SLEEPDEEP 位),并在中斷請求(優先級高于當前優先級)或調試請求時喚醒。 WFE 指令與 WFI 類似
    發表于 07-05 06:27

    STM32L151低功耗運行模式CPU是否正在運行?

    在使得CPU處于LPRUN Mode時,翻轉LED,LED不能正常翻轉,因此請教一下網友們,STM32L151低功耗運行模式CPU是否正在運行
    發表于 07-05 06:17

    ESP32S2如何判斷當前代碼是否中斷?

    問題是,我怎么判斷當前代碼是否中斷執行? rt_err_t IRAM_ATTR rt_event_send(rt_event_t event, rt_uint32_t set
    發表于 06-21 06:30

    PLC出現問題時如何快速判斷CPU異常

    CPU異常是較為常見且影響較大的問題之一。本文將從多個方面探討如何快速判斷PLC出現問題時是否CPU異常,并提供相應的解決方法和建議。
    的頭像 發表于 06-12 11:13 ?989次閱讀

    對于中斷,先執行中斷服務函數還是先清理中斷標志?

    對于中斷,先執行中斷服務函數還是先清理中斷標志?開始學習固件庫的時候,差不多是先進入服務函數在清
    發表于 05-22 07:20

    求助,幫忙判斷下對ADC DMA回調函數的理解是否正確?

    但是結束完回調函數后,不管 DMA1 的 CH1 的優先級 是否比 DMA1 的 CH2 優先級高,都會重新 ADC1 的掃描,ADC2 的掃描永遠不會進行,自然也不會 DMA1 CH2 的中斷
    發表于 05-06 09:24

    如果單片機的程序正在執行中斷服務程序,期間又有比正在執行中斷級別高的中斷結果會如何?

    請教一下,如果單片機的程序正在執行中斷服務程序,期間又有比正在執行中斷級別高的
    發表于 04-09 07:46

    執行判斷CPU怎么設計?

    需要使用JUMP函數跳出嗎,還是可以在EXE階段的乘法器后面的精確乘法器上加一個使能段,根據預測結果判斷要不要激活精確乘法器。但是這樣會不會讓EXE階段的時鐘周期過長?
    發表于 03-30 18:18

    CPU中斷程序:從硬件看什么是中斷?

    CPU響應中斷轉去執行中斷服務程序前,需要把被中斷程序的現場信息保存起來,以便執行
    發表于 03-26 11:36 ?4186次閱讀
    <b class='flag-5'>CPU</b><b class='flag-5'>中斷</b>程序:從硬件看什么是<b class='flag-5'>中斷</b>?
    澳门葡京赌场图片| 百家乐在线投注系统| 百家乐官网高手论| 2402 房号 风水| 德州百家乐赌博规则| 362百家乐的玩法技巧和规则| 威尼斯人娱乐城打造| 中国足球竞猜| 马牌百家乐官网娱乐城| 圣安娜百家乐官网包杀合作| 百家乐官网最好投| 平注打百家乐的方法| 红桃K百家乐娱乐城| bet365娱乐官网| 百家乐官网注册开户| 致胜百家乐官网下载| 玩百家乐新太阳城| 威尼斯人娱乐网网上百家乐| 优博在线娱乐| 百家乐官网统计| 百家乐官网策略介绍| 百家乐官网详情| 新锦江百家乐娱乐网| 大发娱乐场| 百家乐官网一般多大码| 澳门百家乐公试打法| 大发888娱乐城下| 百家乐官网的代理办法| 做生意大门方位风水| 威尼斯人娱乐场官网网站是多少| 禹州市| 百家乐棋牌游| 555棋牌游戏| 恒和国际| 百家乐官网五湖四海赌场娱乐网规则 | 大发888娱乐城亚付宝| 百家乐官网破解版下载| 百家乐的嬴钱法| 全讯网赢足一世| 澳门百家乐官网游戏皇冠网| 百家乐筹码方形筹码|