99精品伊人亚洲|最近国产中文炮友|九草在线视频支援|AV网站大全最新|美女黄片免费观看|国产精品资源视频|精彩无码视频一区|91大神在线后入|伊人终合在线播放|久草综合久久中文

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

中斷里面這樣延時,有點猛~

嵌入式情報局 ? 來源:TopSemic嵌入式 ? 2023-11-12 11:40 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

最近一工程師向我反饋一個問題,Ta說:我程序會死在這一行,大概是什么原因?

828abfec-803f-11ee-939d-92fbcf53809c.png

以下是Ta所說程序會死的地方,

8295b14a-803f-11ee-939d-92fbcf53809c.png

用過HAL庫的童鞋應(yīng)該比較熟悉這個函數(shù),它是延時函數(shù)。

82aca7c4-803f-11ee-939d-92fbcf53809c.png

拿到工程代碼后我就開始Debug之旅了,現(xiàn)象確實如Ta所說,剛開始Hal_delay函數(shù)調(diào)用沒問題,但是過了幾秒之后就卡住了。因為該函數(shù)的計時是依賴Systick中斷,這個現(xiàn)象說明Systick中斷進(jìn)不去了,通過debug模式下Systick中斷服務(wù)函數(shù)里加斷點,可以驗證這一點。但是為什么剛開始好好的,后面就進(jìn)不去中斷了呢?最初我想是不是Systick中斷被關(guān)掉了,通過查看Systick寄存器,發(fā)現(xiàn)并沒有,Systick依然在計時并且中斷使能也沒有關(guān)。

程序里初始化時開啟了RTC中斷,周期是1s,Systick中斷周期是1ms。剛開始時這兩個中斷都能進(jìn),幾秒之后這倆中斷就都進(jìn)不去了。

82b81e9c-803f-11ee-939d-92fbcf53809c.png

這個現(xiàn)象看起來確實挺詭異,因為給我的代碼里糅雜了很多業(yè)務(wù)代碼,寫的也有點亂,看的我很煩躁,后來還是靜下心來仔細(xì)的分析,找到了問題所在。

原因是這樣:Ta在RTC的中斷服務(wù)函數(shù)里,在某個分支函數(shù)里調(diào)用了Hal_delay函數(shù)。因為RTC的中斷優(yōu)先級和Systick中斷優(yōu)先級一樣,所以Systick中斷就進(jìn)不去了,導(dǎo)致Hal_delay函數(shù)也就執(zhí)行不過去了,所以就出現(xiàn)了所謂的卡死現(xiàn)象。之所以剛開始沒問題,過了幾秒才出問題,是因為剛開始前幾秒的RTC中斷服務(wù)函數(shù)里沒有進(jìn)到調(diào)用Hal_delay函數(shù)的那個分支處理里,Ta是在初始化幾秒之后,設(shè)置了一個標(biāo)志位,導(dǎo)致后來RTC中斷處理里調(diào)用了Hal_delay函數(shù)。

問題找到了,如何解決呢?

最簡單的方法是,把Systick和RTC的中斷優(yōu)先級設(shè)置不一樣,讓Systick優(yōu)先級比RTC高一點,這樣可以保證Systick中斷能夠打斷RTC中斷,從而不會卡死。

ARM Cortex MCU的中斷控制器英文名叫做NVIC,Nested Vectored Interrupt Controller,翻譯過來就是嵌套向量中斷控制器,所謂中斷嵌套是指當(dāng)正在執(zhí)行一個中斷服務(wù)程序時,這時如果來了優(yōu)先級更高的中斷,新來的中斷會打斷原來還沒有處理完的中斷服務(wù)程序,等新中斷處理完畢之后再回到原中斷服務(wù)繼續(xù)處理。

Cortex-M0/M0+中斷優(yōu)先級設(shè)置非常簡單,只需要通過CMSIS標(biāo)準(zhǔn)接口函數(shù)__NVIC_SetPriority(IRQn_Type IRQn, uint32_t priority)即可完成,優(yōu)先級只有4個,分別為0、1、2、3,數(shù)字越小優(yōu)先級越高。

問題解決了,總結(jié)不能少:

1)我當(dāng)時找這個問題花了較長時間,反思一下,其實是可以更快的定位問題的。當(dāng)卡死在Hal_delay函數(shù)時,首先應(yīng)該去分析是哪里調(diào)用這個函數(shù)導(dǎo)致卡死的,因為工程里調(diào)用的地方有好多處,可以通過在可能出現(xiàn)問題的調(diào)用前給一個全局變量賦不同的值,卡住時看全局變量,就可以定位到是從哪里進(jìn)去的。這樣倒著往前推,可以更快的定位問題。

2)通常情況下中斷服務(wù)函數(shù)應(yīng)該盡可能的短,最好不要在中斷里做延時之類的占用CPU時間長的工作。

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 寄存器
    +關(guān)注

    關(guān)注

    31

    文章

    5434

    瀏覽量

    124459
  • 函數(shù)
    +關(guān)注

    關(guān)注

    3

    文章

    4381

    瀏覽量

    64857
  • Systick
    +關(guān)注

    關(guān)注

    0

    文章

    63

    瀏覽量

    13593

原文標(biāo)題:中斷里面這樣延時,有點猛~

文章出處:【微信號:嵌入式情報局,微信公眾號:嵌入式情報局】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    STM32C031C6在按鍵中斷處理程序中使用HAL_Delay()延時函數(shù),程序則無法運行怎么解決?

    測試STM32C031C6開發(fā)板的長短按鍵,在按鍵中斷處理程序中使用HAL_Delay()延時函數(shù),程序則無法運行,類似進(jìn)入了死循環(huán),于是則添加了延時函數(shù)如下: /[i
    發(fā)表于 03-07 06:50

    斷電延時繼電器的應(yīng)用

    延時繼電器作為一種重要的電氣控制元件,在現(xiàn)代電氣系統(tǒng)中發(fā)揮著不可或缺的作用。其基于一個或多個可調(diào)的計時器電路,通過與繼電器相連的控制電路,實現(xiàn)了在電路中定時閉合或斷開控制的功能。 一、工作原理 延時
    的頭像 發(fā)表于 02-07 16:07 ?1149次閱讀

    串口中斷是內(nèi)部中斷還是外部中斷,串口中斷是怎么觸發(fā)的

    串口中斷通常被視為外部中斷。雖然串口控制器(如USART、UART等)可能集成在微控制器或處理器的內(nèi)部,但從中斷的角度來看,串口中斷是由處理器外部的通信事件觸發(fā)的。這些事件包括數(shù)據(jù)的接
    的頭像 發(fā)表于 01-29 15:03 ?1792次閱讀

    延時繼電器功能匯總與應(yīng)用

    延時繼電器是一種在電氣系統(tǒng)中廣泛應(yīng)用的控制元件,在電路中實現(xiàn)定時閉合或斷開控制,為各種應(yīng)用場景提供靈活的時間管理功能。 通常,聚英延時繼電器由一個控制電壓引發(fā),該控制電壓可以是任何符合電器設(shè)備功能
    的頭像 發(fā)表于 01-17 16:03 ?674次閱讀

    延時繼電器應(yīng)用場景

    延時繼電器是一種在電氣系統(tǒng)中廣泛應(yīng)用的控制元件,通過引入延時功能,實現(xiàn)了在電路中定時閉合或斷開控制的重要任務(wù)。 延時繼電器的工作原理,基于一個或多個可調(diào)的計時器電路,2路/4路/8路電路與繼電器相連
    的頭像 發(fā)表于 01-16 16:27 ?649次閱讀

    力源電池-紐扣電池系列:CR系列鋰扣式產(chǎn)品介紹

    深圳鴻合智遠(yuǎn)|力源電池-紐扣電池系列:CR系列鋰扣式產(chǎn)品介紹
    的頭像 發(fā)表于 12-02 11:03 ?806次閱讀
    力源電池-紐扣電池系列:CR系列鋰<b class='flag-5'>猛</b>扣式產(chǎn)品介紹

    FPGA延時Verilog HDL實現(xiàn)

    可以在任意時刻啟動,可以重復(fù)啟動,延時時長可調(diào),單位可切換(ms/us),在50MHz時鐘下的延時范圍是1ms-85899ms/1us-85899us。
    的頭像 發(fā)表于 11-05 11:26 ?825次閱讀

    延時開關(guān)需要零線嗎為什么

    延時開關(guān)是一種常見的電氣控制元件,廣泛應(yīng)用于各種電氣設(shè)備和系統(tǒng)中。它的作用是在電路中引入一定的延時,以實現(xiàn)對電路的控制和保護(hù)。延時開關(guān)的種類很多,包括機(jī)械式延時開關(guān)、電子式
    的頭像 發(fā)表于 08-19 15:56 ?1070次閱讀

    延時開關(guān)接線技巧與注意事項有哪些

    延時開關(guān)的接線技巧與注意事項是確保延時開關(guān)正確安裝和穩(wěn)定運行的關(guān)鍵。 一、延時開關(guān)接線技巧 1. 理解延時開關(guān)的基本結(jié)構(gòu) 延時開關(guān)通常包含多
    的頭像 發(fā)表于 08-19 15:54 ?2510次閱讀

    延時開關(guān)改手動開關(guān)怎么接線

    延時開關(guān)和手動開關(guān)是兩種不同類型的開關(guān),它們的工作原理和接線方式也有所不同。在某些情況下,我們可能需要將延時開關(guān)改為手動開關(guān),以滿足特定的使用需求。 一、延時開關(guān)和手動開關(guān)的區(qū)別 工作原理
    的頭像 發(fā)表于 08-19 15:49 ?1602次閱讀

    延時開關(guān)怎么調(diào)時間長短

    延時開關(guān)是一種常見的電子控制設(shè)備,廣泛應(yīng)用于各種場合,如照明、空調(diào)、風(fēng)扇等。它可以根據(jù)用戶的需求,設(shè)定一定的延時時間,實現(xiàn)自動控制。 一、延時開關(guān)的工作原理 延時開關(guān)的基本組成
    的頭像 發(fā)表于 08-19 15:46 ?4994次閱讀

    延時開關(guān)上l和a是什么意思

    延時開關(guān)是一種常見的電子控制元件,廣泛應(yīng)用于各種電子設(shè)備和系統(tǒng)中。它可以實現(xiàn)對電路的自動控制,使電路在一定的延時后自動接通或斷開。在延時開關(guān)的標(biāo)識中,L和A通常代表不同的意義。 一、延時
    的頭像 發(fā)表于 08-19 15:45 ?8118次閱讀

    2024這款A(yù)IPC迷你主機(jī)有點

    。未來,隨著AI技術(shù)的不斷發(fā)展和普及,我們有理由相信,像華碩PN65這樣的高性能迷你主機(jī)將會更加普及,成為更多用戶的心儀之選。 不管你是玩游戲,直播,視頻剪輯還是正常辦公或者你正在尋找一款既小巧又強(qiáng)大的電腦主機(jī),那么華碩PN65絕對值得你深入了解和考慮。
    的頭像 發(fā)表于 07-30 17:35 ?803次閱讀
    2024這款A(yù)IPC迷你主機(jī)<b class='flag-5'>有點</b><b class='flag-5'>猛</b>

    揭秘:單片機(jī)硬件與軟件延時之大不同!

    在嵌入式項目中,軟件開發(fā)基本上都會使用到延時,那么,該用軟件延時還是硬件延時?它們又有什么區(qū)別呢?今天就來講講關(guān)于硬件延時和軟件延時的內(nèi)容,
    的頭像 發(fā)表于 07-25 08:11 ?1387次閱讀
    揭秘:單片機(jī)硬件與軟件<b class='flag-5'>延時</b>之大不同!

    斷電延時繼電器的實際應(yīng)用

    斷電延時繼電器作為一種常見的電器設(shè)備,在現(xiàn)代生活中有著廣泛的應(yīng)用。它通過控制電路的開關(guān)時間來實現(xiàn)電器設(shè)備的延時關(guān)閉,從而達(dá)到省電、安全等目的。以下將結(jié)合多個應(yīng)用實例,詳細(xì)闡述斷電延時繼電器的實際應(yīng)用。
    的頭像 發(fā)表于 07-17 16:51 ?2282次閱讀