精品国产人成在线_亚洲高清无码在线观看_国产在线视频国产永久2021_国产AV综合第一页一个的一区免费影院黑人_最近中文字幕MV高清在线视频

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

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

3天內不再提示

內核使用FreeRTOS的特別注意事項有哪些?

安芯教育科技 ? 來源:極術社區 ? 作者:朱工 ? 2021-02-01 10:21 ? 次閱讀

在閱讀本文之前,有兩個定義在FreeRTOSConfig.h中的宏,你必須先明白它們是什么意思,《FreeRTOS內核配置說明》一文中,講解了這兩個宏:

configKERNEL_INTERRUPT_PRIORITY

configMAX_SYSCALL_INTERRUPT_PRIORITY

FreeRTOS與Cortex-M內核可謂是絕配,以至于讓移植和使用FreeRTOS都變得更簡單起來。根據FreeRTOS官方反饋,在Cortex-M內核上使用FreeRTOS大多數的問題點是由不正確的優先級設置引起的。這個問題也是在意料之中的,因為盡管Cortex-M內核的中斷模式是非常強大的,但對于那些使用傳統中斷優先級架構的工程師來說,Cortex-M內核中斷機制也有點笨拙(或者是說使用比較繁瑣),并且違反直覺(這個主要是因為Cortex-M中斷優先級數值越大代表的優先級反而越小)。本章打算描述Cortex-M的中斷優先級機制,并描述怎樣結合RTOS內核使用。

說明:雖然Cortex-M內核的優先級方案看上去比較復雜,但每一個官方發布的FreeRTOS 接口包(在FreeRTOSV7.2.0FreeRTOSSourceportable文件夾中,一般為port.c)內都會有正確配置的演示例程,可以以此為參考。

1.有效優先級

1.1Cortex-M 硬件詳述

首先需要清楚有效優先級的總數,這取決于微控制器制造商怎么使用Cortex內核。所以,并不是所有的Cortex-M內核微處理器都具有相同的中斷優先級級別。 Cortex-M構架自身最多允許256級可編程優先級(優先級配置寄存器最多8位,所以優先級范圍從0x00~0xFF),但是絕大多數微控制器制造商只是使用其中的一部分優先級。比如,TI Stellaris Cortex-M3和Cortex-M4微控制器使用優先級配置寄存器的3個位,能提供8級優先級。再比如,NXP LPC17xx Cortex-M3微控制器使用優先級配置寄存器的5個位,能提供32級優先級。

1.2應用到RTOS

RTOS中斷嵌套方案將有效的中斷優先級分成兩組:一組可以通過RTOS臨界區屏蔽,另一組不受RTOS影響,永遠都是使能的。宏configMAX_SYSCALL_INTERRUPT_PRIORITY在FreeRTOSConfig.h中配置,定義兩組中斷優先級的邊界。邏輯優先級高于此值的中斷不受RTOS影響。最優值取決于微控制器使用的優先級配置寄存器的位數。

2.與數值相反的優先級值和邏輯優先級設置

2.1Cortex-M 硬件詳述

有必要先解釋一下優先級值和邏輯優先級:在Cortex-M內核中,假如有8級優先級,我們說優先級值是0~7,但數值最大的優先級7卻代表著最低的邏輯優先級。很多使用傳統傳統中斷優先級架構的工程師會覺得這樣比較繞,違反直覺。以下內容提到的優先級要仔細區分是優先級數值還是邏輯優先級。 接下來需要清楚的是,在Cortex-M內核中,一個中斷的優先級數值越低,邏輯優先級卻越高。比如,中斷優先級為2的中斷可以搶占中斷優先級為5的中斷,但反過來就不行。換句話說,中斷優先級2比中斷優先級5的優先級更高。 這是Cortex-M內核最容易讓人犯錯之處,因為大多數的非Cortex-M內核微控制器的中斷優先級表述是與之相反的。

2.2應用到 RTOS

以“FromISR”結尾的FreeRTOS函數是具有中斷調用保護的(執行這些函數會進入臨界區),但是就算是這些函數,也不可以被邏輯優先級高于configMAX_SYSCALL_INTERRUPT_PRIORITY的中斷服務函數調用。(宏configMAX_SYSCALL_INTERRUPT_PRIORITY定義在頭文件FreeRTOSConfig.h中)。因此,任何使用RTOSAPI函數的中斷服務例程的中斷優先級數值大于等于configMAX_SYSCALL_INTERRUPT_PRIORITY宏的值。這樣就能保證中斷的邏輯優先級等于或低于configMAX_SYSCALL_INTERRUPT_PRIORITY。 Cortex中斷默認情況下有一個數值為0的優先級。大多數情況下0代表最高級優先級。因此,絕對不可以在優先級為0的中斷服務例程中調用RTOSAPI函數。

3.Cortex-M 內部優先級概述

3.1Cortex-M 硬件詳述

Cortex-M內核的中斷優先級寄存器是以最高位(MSB)對齊的。比如,如果使用了3位來表達優先級,則這3個位位于中斷優先級寄存器的bit5、bit6、bit7位。剩余的bit0~bit4可以設置成任何值,但為了兼容,最好將他們設置成1. Cortex-M優先級寄存器最多有8位,如果一個微控制器只使用了其中的3位,那么這3位是以最高位對齊的,見下圖:

e848f658-6258-11eb-8b86-12bb97331649.png

某微控制器只使用了優先級寄存器中的3位,下圖展示了優先級數值5(二進制101B)是怎樣在優先級寄存器中存儲的。如果優先級寄存器中未使用的位置1,下圖也展示了為什么數值5(二進制0000 0101B)可以看成數值191(二進制1011 1111)的。

e8830032-6258-11eb-8b86-12bb97331649.png

某微控制器只使用了優先級寄存器中的4位,下圖展示了優先級數值5(二進制101B)是怎樣在優先級寄存器中存儲的。如果優先級寄存器中未使用的位置1,下圖也展示了為什么數值5(二進制0000 0101B)可以看成數值95(二進制0101 1111)的。

e8beedc2-6258-11eb-8b86-12bb97331649.png

3.2應用到 RTOS

上文中已經描述,那些在中斷服務例程中調用RTOS API函數的中斷邏輯優先級必須低于或等于configMAX_SYSCALL_INTERRUPT_PRIORITY(低邏輯優先級意味著高優先級數值)。 CMSIS以及不同的微控制器供應商提供了可以設置某個中斷優先級的庫函數。一些庫函數的參數使用最低位對齊,另一些庫函數的參數可能使用最高位對齊,所以,使用時應該查閱庫函數的應用手冊進行正確設置。 可以在FreeRTOSConfig.h中設置宏configMAX_SYSCALL_INTERRUPT_PRIORITY和configKERNEL_INTERRUPT_PRIORITY的值。這兩個宏需要根據Cortex-M內核自身的情況進行設置,要以最高有效位對齊。比如某微控制器使用中斷優先級寄存器中的3位,設置configKERNEL_INTERRUPT_PRIORITY的值為5,則代碼為:

#defineconfigKERNEL_INTERRUPT_PRIORITY(5<<(8-3))? 宏configKERNEL_INTERRUPT_PRIORITY指定RTOS內核使用的中斷優先級,因為RTOS內核不可以搶占用戶任務,因此這個宏一般設置為硬件支持的最小優先級。對于Cortex-M硬件,RTOS使用到硬件的PendSV和SysTick硬件中斷,在函數xPortStartScheduler()中(該函數在port.c中,由啟動調度器函數vTaskStartScheduler()調用),將PendSV和SysTick硬件中斷優先級寄存器設置為宏configKERNEL_INTERRUPT_PRIORITY指定的值。 ? 有關代碼如下(位于port.c):?/*PendSV優先級設置寄存器地址為0xe000ed22 ?SysTick優先級設置寄存器地址為0xe000ed23*/ #define?portNVIC_SYSPRI2_REG?????(?*?(?(?volatile?uint32_t?*?)?0xe000ed20?)) ? #define?portNVIC_PENDSV_PRI?(?(?(uint32_t)configKERNEL_INTERRUPT_PRIORITY?)?<

4.臨界區

4.1Cortex-M 硬件詳述

RTOS內核使用Cortex-M內核的BASEPRI寄存器來實現臨界區(注:BASEPRI為優先級屏蔽寄存器,優先級數值大于或等于該寄存器的中斷都會被屏蔽,優先級數值越大,邏輯優先級越低,但是為零時不屏蔽任何中斷)。這允許RTOS內核可以只屏蔽一部分中斷,因此可以提供一個靈活的中斷嵌套模式。 那些需要在中斷調用時保護的API函數,FreeRTOS使用寄存器BASEPRI實現中斷保護臨界區。當進入臨界區時,將寄存器BASEPRI的值設置成configMAX_SYSCALL_INTERRUPT_PRIORITY,當退出臨界區時,將寄存器BASEPRI的值設置成0。很多Bug反饋都提到,當退出臨界區時不應該將寄存器設置成0,應該恢復它之前的狀態(之前的狀態不一定是0)。但是Cortex-M NVIC決不會允許一個低優先級中斷搶占當前正在執行的高優先級中斷,不管BASEPRI寄存器中是什么值。與進入臨界區前先保存BASEPRI的值,退出臨界區再恢復的方法相比,退出臨界區時將BASEPRI寄存器設置成0的方法可以獲得更快的執行速度。

4.2應用到RTOS kernel

RTOS內核通過寫configMAX_SYSCALL_INTERRUPT_PRIORITY的值到BASEPRI寄存器的方法創建臨界區。中斷優先級0(具有最高的邏輯優先級)不能被BASEPRI寄存器屏蔽,因此,configMAX_SYSCALL_INTERRUPT_PRIORITY絕不可以設置成0。

原文標題:Cortex-M內核使用FreeRTOS特別注意事項

文章出處:【微信公眾號:安芯教育科技】歡迎添加關注!文章轉載請注明出處。

責任編輯:haq

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

    關注

    3

    文章

    1363

    瀏覽量

    40228
  • RTOS
    +關注

    關注

    21

    文章

    809

    瀏覽量

    119433
  • FreeRTOS
    +關注

    關注

    12

    文章

    483

    瀏覽量

    62010

原文標題:Cortex-M內核使用FreeRTOS特別注意事項

文章出處:【微信號:Ithingedu,微信公眾號:安芯教育科技】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    繞線電感定制的注意事項

    電子發燒友網站提供《繞線電感定制的注意事項.docx》資料免費下載
    發表于 09-20 11:24 ?0次下載

    故障電容器檢查時的注意事項

    在檢查故障電容器時,必須特別注意安全和準確的診斷。以下是一些關鍵注意事項: 1、斷電操作 確保電源關閉 :在開始檢查前,務必確保相關電路斷電,并且電容器已經完全放電。 放電處理 :電容器在斷電后仍可
    的頭像 發表于 08-22 14:04 ?359次閱讀

    TLV9062在運放選型時有沒有什么特別注意事項

    如下圖所示的V-I轉換電路,在運放選型時有沒有什么特別注意事項?如電壓反饋型運放還是電流反饋型運放
    發表于 07-31 08:08

    4芯M16公頭插座在設備上使用時的注意事項

     德索工程師說道4芯M16公頭插座在設備上使用時,為確保其性能穩定、安全可靠,需要特別注意以下幾個方面的事項。以下是對這些注意事項的詳細分析和歸納:   質量可靠:優先選擇知名品牌、經過嚴格質量檢測的4芯M16公頭插座,確
    的頭像 發表于 06-21 11:56 ?345次閱讀
    4芯M16公頭插座在設備上使用時的<b class='flag-5'>注意事項</b>

    FMD LINK 使用注意事項

    電子發燒友網站提供《FMD LINK 使用注意事項.pdf》資料免費下載
    發表于 05-06 10:11 ?0次下載

    使用ST-LINK對STM32G030K8T6TR進行燒錄,什么特別注意事項嗎?

    燒錄時有什么特別注意事項嗎? 3)另外STM32G030K8T6TR的GPIO口內部是否帶上拉到VDD的保護二極管?GPIO口可承受的最大電壓是多少?
    發表于 03-12 06:32

    浪涌抑制器的應用及注意事項

    浪涌抑制器的應用及注意事項?|深圳比創達電子
    的頭像 發表于 01-19 09:55 ?686次閱讀
    浪涌抑制器的應用及<b class='flag-5'>注意事項</b>?

    射頻電纜組件的使用方法和注意事項

    射頻電纜組件的使用方法和注意事項? 射頻電纜組件是一類廣泛應用于通信系統、無線電設備和其他射頻設備中的重要電子組件。它們在傳輸高頻信號時扮演著關鍵的角色,因此使用和安裝時需要特別注意一些事項。本文將
    的頭像 發表于 01-05 15:08 ?598次閱讀

    高壓衰減棒即高壓探頭在使用中的注意事項

    高壓衰減棒是在高壓測試中不可或缺的一項工具。然而,如果不正確使用,高壓衰減棒可能會引起損壞,影響工作效果。因此,在使用高壓衰減棒時,一些重要事項需要特別注意。接下來PRBTEK就來為您分享一下高壓
    的頭像 發表于 12-29 10:33 ?448次閱讀
    高壓衰減棒即高壓探頭在使用中的<b class='flag-5'>注意事項</b>

    DC電源模塊哪些注意事項和使用技巧?

    DC電源模塊哪些注意事項和使用技巧?
    的頭像 發表于 12-25 13:59 ?575次閱讀
    DC電源模塊<b class='flag-5'>有</b>哪些<b class='flag-5'>注意事項</b>和使用技巧?

    使用AD9230什么要特別注意的地方嗎?

    各位好, 最近要做的一個接收機中頻采樣要用到AD9230這款芯片, 之前一直用AD6645,不知道AD9230在使用上有什么要特別注意的地方嗎? 如果有設計過ad9230電路的朋友能否給提供以下建議,多謝!
    發表于 12-21 08:28

    霍爾元件使用的注意事項

    使用壽命,一些注意事項需要牢記。本文將詳細介紹霍爾元件使用的注意事項。 一、安裝注意事項 1. 霍爾元件需要正確安裝在電路板上,確保其與周圍元件之間的間距適宜,以避免信號干擾。 2.
    的頭像 發表于 12-18 14:56 ?1228次閱讀

    電流互感器的使用注意事項

    當談到電流互感器的使用時,一些重要的注意事項需要我們牢記。在本文中,我們將探討這些注意事項,為您提供詳細和全面的信息。
    的頭像 發表于 12-15 10:34 ?1375次閱讀
    電流互感器的使用<b class='flag-5'>注意事項</b>

    數據采集設備測試哪些注意事項

    數據采集設備測試哪些注意事項
    的頭像 發表于 12-05 10:05 ?552次閱讀

    聯軸器使用哪些注意事項

    聯軸器在實際應用中根據所傳遞轉矩大小可分為重型、中型、小型和輕型。那么怎么選擇合適聯軸器,使用的時候又有哪些注意事項呢?
    發表于 11-30 09:21 ?887次閱讀
    聯軸器使用<b class='flag-5'>有</b>哪些<b class='flag-5'>注意事項</b>?