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

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

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

構(gòu)建RTOS Kernel指南 (上)

恩智浦MCU加油站 ? 來(lái)源:未知 ? 2023-08-03 08:45 ? 次閱讀

1前言試想與我們相伴的MCU如若只存在裸機(jī)程序,那么運(yùn)行到一個(gè)包含延時(shí)的線程時(shí),我們的CPU就開始“摸魚”了。為了最大化運(yùn)行CPU,就需要用到RTOS(RealTime Operating System). 簡(jiǎn)單來(lái)說(shuō),RTOS是一個(gè)調(diào)度一切可利用的資源完成實(shí)時(shí)任務(wù),并控制所有實(shí)時(shí)任務(wù)協(xié)調(diào)一致運(yùn)行的操作系統(tǒng),或者說(shuō),其內(nèi)核是一個(gè)任務(wù)管理的框架。

市面上已存有許多優(yōu)秀的RTOS,如FreeRTOS、Zephyr、RT-Thread等。許多小伙伴可能在最初接觸RTOS時(shí)怯于其超厚的配套書籍或其龐大的代碼,但不用害怕,像小編一樣庖丁解牛般邊學(xué)習(xí)邊構(gòu)建一個(gè)自己的RTOS是一個(gè)很好的學(xué)習(xí)方法,讓我們踏上RTOS的學(xué)習(xí)之旅! wKgaomToOvKAc6OSAADetuivD1w567.png

圖1 RTOS版本

就好像要蓋一座高樓,必然先得考察地勢(shì)地貌,地基穩(wěn)固,才能逐漸添磚加瓦。構(gòu)建一個(gè)RTOS也是同樣道理,需要知道它運(yùn)行在一個(gè)怎樣的架構(gòu)上,以NXP的RT系列芯片為例,我們需要了解學(xué)習(xí)ARM Cortex-M系列的架構(gòu)內(nèi)容。這是一個(gè)非常龐大的體系,這里推薦《ARM Cortex-M3 Cortex-M4權(quán)威指南》,是一本不錯(cuò)的參考書籍。下文將列舉構(gòu)建一個(gè)RTOS所需要的最為核心的內(nèi)容。 wKgaomToOvKAPWsgAAEDZ-tJBPc915.png圖2《ARM 圖2 Cortex-M3 Cortex-M4權(quán)威指南》

2ARM處理器架構(gòu)相關(guān)內(nèi)容

2.1 操作模式和狀態(tài)wKgaomToOvKAZRhTAAEn-l5RC5k593.png? ? ? ? ? ? ? ? ?? ??圖3操作模式和狀態(tài)

Cortex-M系列有兩種操作狀態(tài)和兩種模式,并可以區(qū)分特權(quán)和非特權(quán)訪問等級(jí)。其中調(diào)試狀態(tài)只在連接調(diào)試器的時(shí)候起作用,若處理器在執(zhí)行程序代碼,則處于Thumb狀態(tài),Cortex-M處理器不支持ARM狀態(tài),所以ARM狀態(tài)不存在。

兩種模式為處理模式線程模式處理模式用作異常處理,并總具有特權(quán)訪問等級(jí);在執(zhí)行普通的應(yīng)用程序代碼時(shí),處理器處于線程模式,此時(shí)可能處于特權(quán)訪問等級(jí)也可能處于非特權(quán)訪問等級(jí),前者可向后者切換,但是后者向前者切換則需要借用異常機(jī)制。

2.2 寄存器

Cortex-M處理器在內(nèi)核中具有多個(gè)執(zhí)行數(shù)據(jù)處理和控制的寄存器,這些寄存器大都以寄存器組的形式進(jìn)行了分組。以cortex-M4處理器為例,寄存器組中有16個(gè)寄存器。wKgaomToOvOAd-CzAAHTXPSpwzU129.png? ? ? ? ? ? ?? ? ? ? ??圖4 寄存器組中寄存器其中R0-R12為通用寄存器,R13為棧指針,用于實(shí)現(xiàn)棧存儲(chǔ)的訪問。物理上存在兩個(gè)棧指針:主棧指針(MSP)用于處理模式,以及進(jìn)程棧指針(PSP)只能用于線程模式。R14也被稱為鏈接寄存器,用于函數(shù)或子程序調(diào)用時(shí)返回地址的保存。R15為程序計(jì)數(shù)器。除了寄存器組中的寄存器之外,處理器中還存在多個(gè)特殊的寄存器。下面為幾個(gè)較為典型的特殊寄存器: wKgaomToOvOAQGDFAACYHdicB_o486.png? ? ? ? ? ? ? ? ? ? ? ? ?? ?? ? ?圖5 特殊寄存器 其中,程序狀態(tài)寄存器包含三個(gè)狀態(tài)寄存器,用于保存處理的狀態(tài)信息。PRIMASK、FAULTMASK、BASEPRI寄存器都用于異?;蛑袛嗥帘危珻ONTROL寄存器則用于棧指針的選擇和線程模式的訪問等級(jí)。

2.3 向量表和系統(tǒng)控制塊

當(dāng)Cortex-M處理器接受了某種異常請(qǐng)求后,處理器需要確定該異常處理的起始地址,該信息位于存儲(chǔ)器內(nèi)的向量表中。構(gòu)建RTOS用到的最為核心的異常為PendSV,其優(yōu)先級(jí)最低,可以被其他中斷打斷,因此通常用作上下文的切換,也就是任務(wù)的切換。wKgaomToOvOATR4NAAFvTZLr7sc572.png? ? ? ? ? ? ? ? ? ? ? ? ?圖6 中斷向量表

系統(tǒng)控制塊(SCB)中包含了若干用于中斷控制的寄存器,其中有一個(gè)與RTOS密切相關(guān)的為中斷控制和狀態(tài)寄存器(ICSR),通過(guò)將第28位進(jìn)行使能操作,可以觸發(fā)我們需要的PendSV中斷異常。

wKgaomToOvOAH9iVAADzepuMCcI861.png? ? ? ? ? ?? ?圖7 中斷控制和狀態(tài)寄存器(ICSR)

3任務(wù)切換的實(shí)現(xiàn)

上述背景知識(shí)是為構(gòu)建RTOS而提煉的內(nèi)容,作者在這里建議在開發(fā)學(xué)習(xí)過(guò)程中帶著疑問前進(jìn),邊學(xué)習(xí)邊擴(kuò)展。下面就可以對(duì)RTOS的最基本功能——任務(wù)切換進(jìn)行實(shí)現(xiàn)。首先我們需要知道,不同于裸機(jī)程序,RTOS的每個(gè)任務(wù)都有獨(dú)立的上下文環(huán)境,在發(fā)生任務(wù)切換時(shí),需對(duì)每個(gè)任務(wù)的狀態(tài)數(shù)據(jù)進(jìn)行保存,那么需要為每個(gè)任務(wù)配備有獨(dú)立的棧空間。

當(dāng)觸發(fā)任務(wù)切換時(shí),需要首先暫停當(dāng)前任務(wù)的執(zhí)行,并保存當(dāng)前任務(wù)的狀態(tài)數(shù)據(jù)到任務(wù)對(duì)應(yīng)的棧空間,再將棧指針更新到切換的目標(biāo)任務(wù)的棧空間,最后從該棧空間中恢復(fù)其狀態(tài)數(shù)據(jù),至此完成了任務(wù)的切換。wKgaomToOvOAHvVHAAD3mNaiefI740.png 圖8 任務(wù)切換的步驟

需要注意的是,當(dāng)PendSV異常觸發(fā)時(shí),硬件系統(tǒng)會(huì)自動(dòng)保存xPSR、LC、R12、R3-R0寄存器,R11-R4的壓棧需要代碼實(shí)現(xiàn)。除此之外,在任務(wù)初始化的時(shí)候,也需要對(duì)棧空間進(jìn)行初始化,并且在系統(tǒng)運(yùn)行第一個(gè)任務(wù)時(shí),無(wú)需進(jìn)行壓棧的操作,因此需要判斷任務(wù)是否為初始任務(wù),一個(gè)較為簡(jiǎn)單的辦法是在運(yùn)行初始任務(wù)之前將PSP置0用于判斷,但這樣對(duì)系統(tǒng)的運(yùn)行效率有一定影響,較為成熟的RTOS中有更為巧妙的處理辦法,有興趣的讀者可以自行查閱。

wKgaomToOvOAXEgDAADtvW9c_MM468.png?圖9上下文切換的流程

實(shí)現(xiàn)到這里,一個(gè)RTOS的地基已經(jīng)鑄成,請(qǐng)繼續(xù)翻看下集學(xué)習(xí): 優(yōu)先級(jí)查找,優(yōu)先級(jí)反轉(zhuǎn),臨界區(qū)保護(hù)和線程同步功能的詳細(xì)介紹哦!

END

更多恩智浦AI-IoT市場(chǎng)和產(chǎn)品信息,邀您同時(shí)關(guān)注“NXP客棧”微信公眾號(hào)

wKgaomToOvSAeEyxAABCdkRE230598.jpg ? ? ?

NXP客棧


恩智浦致力于打造安全的連接和基礎(chǔ)設(shè)施解決方案,為智慧生活保駕護(hù)航。

長(zhǎng)按二維碼,關(guān)注我們

恩智浦MCU加油站


這是由恩智浦官方運(yùn)營(yíng)的公眾號(hào),著重為您推薦恩智浦MCU的產(chǎn)品信息、開發(fā)技巧、教程文檔、培訓(xùn)課程等內(nèi)容。

wKgaomToOvSAfqN9AAATNlPH08Y848.jpg ?

長(zhǎng)按二維碼,關(guān)注我們


原文標(biāo)題:構(gòu)建RTOS Kernel指南 (上)

文章出處:【微信公眾號(hào):恩智浦MCU加油站】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。


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

    關(guān)注

    146

    文章

    16804

    瀏覽量

    349386
  • 恩智浦
    +關(guān)注

    關(guān)注

    14

    文章

    5807

    瀏覽量

    105976

原文標(biāo)題:構(gòu)建RTOS Kernel指南 (上)

文章出處:【微信號(hào):NXP_SMART_HARDWARE,微信公眾號(hào):恩智浦MCU加油站】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    深入解析Zephyr RTOS的技術(shù)細(xì)節(jié)

    Zephyr是一個(gè)針對(duì)資源受限設(shè)備優(yōu)化的小型、可縮放、多體系架構(gòu)實(shí)時(shí)操作系統(tǒng)(RTOS)。Zephyr由Linux基金會(huì)維護(hù)[1],是一個(gè)以構(gòu)建業(yè)界最佳的RTOS為目標(biāo)的開源合作項(xiàng)目。近年來(lái)
    的頭像 發(fā)表于 10-22 16:47 ?108次閱讀
    深入解析Zephyr <b class='flag-5'>RTOS</b>的技術(shù)細(xì)節(jié)

    RTOS在TI 66AK2H設(shè)備實(shí)現(xiàn)FTP服務(wù)器應(yīng)用說(shuō)明

    電子發(fā)燒友網(wǎng)站提供《用RTOS在TI 66AK2H設(shè)備實(shí)現(xiàn)FTP服務(wù)器應(yīng)用說(shuō)明.pdf》資料免費(fèi)下載
    發(fā)表于 09-13 10:03 ?0次下載
    用<b class='flag-5'>RTOS</b>在TI 66AK2H設(shè)備<b class='flag-5'>上</b>實(shí)現(xiàn)FTP服務(wù)器應(yīng)用說(shuō)明

    freertos和rtos區(qū)別是什么

    FreeRTOS 和 RTOS(實(shí)時(shí)操作系統(tǒng))是兩個(gè)不同的概念,但它們之間有緊密的聯(lián)系。FreeRTOS 是一個(gè)特定的開源實(shí)時(shí)操作系統(tǒng),而 RTOS 是實(shí)時(shí)操作系統(tǒng)的一般概念。 概念定義 RTOS
    的頭像 發(fā)表于 09-02 14:18 ?655次閱讀

    RTOS的特性和類型

    。通常,這些應(yīng)用程序在幾微秒內(nèi)響應(yīng)輸入,并在內(nèi)存小于1MB的小型嵌入式設(shè)備運(yùn)行。在本節(jié)中,您將詳細(xì)了解什么是RTOS以及RTOS類型和架構(gòu)。
    的頭像 發(fā)表于 08-20 11:29 ?392次閱讀

    在Ubuntu電腦使用CYW4373A0,構(gòu)建btusb驅(qū)動(dòng)程序時(shí),出現(xiàn)了構(gòu)建錯(cuò)誤如何解決?

    你好,我想在 Ubuntu 電腦使用 CYW4373A0。 當(dāng)我嘗試構(gòu)建 btusb 驅(qū)動(dòng)程序時(shí),出現(xiàn)了構(gòu)建錯(cuò)誤。 如何解決? 下面是 Ubuntu 的錯(cuò)誤信息。 謝謝! make -C
    發(fā)表于 07-24 06:34

    如何在ESP8266使用SSDP,并使用RTOS SDK?

    我正在嘗試在 ESP8266 使用 SSDP,并使用 RTOS SDK。
    發(fā)表于 07-18 08:23

    是否可以擴(kuò)展esp_iot_rtos_sdk以具有api功能來(lái)進(jìn)行云更新?

    是否可以擴(kuò)展esp_iot_rtos_sdk以具有 api 功能來(lái)進(jìn)行云更新?SDK 編程指南(盡管我認(rèn)為它不適用于 rtos sdk)表明存在
    發(fā)表于 07-15 08:19

    ESP8266_RTOS_SDK LWIP構(gòu)建失敗怎么解決?

    然后我克隆了 ESP8266_RTOS_SDK 的 release/v3.3 分支。這導(dǎo)致我的項(xiàng)目生成失敗,并出現(xiàn)以下情況: 抄送構(gòu)建/lwip/lwip/src/api/if_api.o 在
    發(fā)表于 07-09 08:01

    ESP8266_RTOS_SDK-v3.4的構(gòu)建錯(cuò)誤如何解決?

    我嘗試將 SDK3.4 導(dǎo)入 Aithinker windows IDE 程序,然后構(gòu)建它。不幸的是,我收到以下錯(cuò)誤: LD /d/8266/ESP8266_RTOS
    發(fā)表于 07-08 07:59

    請(qǐng)問cyw20719或cyw20721是否支持RTOS?

    請(qǐng)確認(rèn) cyw20719 或 cyw20721 是否支持 RTOS? 我們希望使用 RTOS 控制外設(shè) SPI、I2C、PWM、ADC 等。 如果有,您有移植指南嗎?
    發(fā)表于 05-20 06:39

    kernel到android核心啟動(dòng)過(guò)程

    總結(jié)一個(gè)圖:kernel 到android核心啟動(dòng)過(guò)程 kernel鏡像執(zhí)行跳轉(zhuǎn)到start_kernel開始執(zhí)行,在rest_init會(huì)創(chuàng)建兩個(gè)kernel 進(jìn)程(線程),其分別是為
    的頭像 發(fā)表于 12-04 16:59 ?781次閱讀
    <b class='flag-5'>kernel</b>到android核心啟動(dòng)過(guò)程

    kernel的啟動(dòng)分為哪兩個(gè)階段

    設(shè)計(jì)。在運(yùn)行過(guò)程中運(yùn)行地址和加載地址一致(如果不明白的話建議先參考一下《[kernel 啟動(dòng)流程] 前篇——vmlinux.lds分析》)。 (一篇
    的頭像 發(fā)表于 12-04 16:45 ?547次閱讀

    微軟開源Azure RTOS,并更名為Eclipse ThreadX

    Azure RTOS 是一個(gè)帶有 ThreadX 實(shí)時(shí)操作系統(tǒng)(RTOS)的嵌入式開發(fā)套件。ThreadX 是一個(gè)普及性很高的小型 RTOS,可為資源受限的設(shè)備提供可靠、超快的性能;目前已部署在全球超過(guò) 120 億臺(tái)設(shè)備
    的頭像 發(fā)表于 12-01 16:17 ?724次閱讀
    微軟開源Azure <b class='flag-5'>RTOS</b>,并更名為Eclipse ThreadX

    kernel日志寫入logd介紹

    kernel日志寫入logd介紹 通過(guò)logcat命令獲取kernel日志比較特殊,故作為一個(gè)例子進(jìn)行梳理。 2.3.1 整體流程 2.3.2 命令打印kernel日志 通過(guò)logcat -b
    的頭像 發(fā)表于 11-23 17:11 ?556次閱讀
    <b class='flag-5'>kernel</b>日志寫入logd介紹

    RTOS相比裸機(jī)有什么優(yōu)點(diǎn)?RTOS相比裸機(jī)更方便嗎?

    RTOS相比裸機(jī)有什么優(yōu)點(diǎn)?RTOS相比裸機(jī)更方便嗎? RTOS代表實(shí)時(shí)操作系統(tǒng),專門為需要高可靠性和可預(yù)測(cè)性的系統(tǒng)設(shè)計(jì)。相比之下,裸金屬或“裸”系統(tǒng)的硬件或軟件層最少,嚴(yán)重依賴開發(fā)人員的代碼來(lái)處
    的頭像 發(fā)表于 10-29 16:33 ?1498次閱讀