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

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

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

裸機與RTOS的理解和并發(fā)帶來的問題

Q4MP_gh_c472c21 ? 來源:最后一個bug ? 作者:bug菌 ? 2021-06-13 15:13 ? 次閱讀

1

裸機與RTOS的理解

首先這里只針對單核CPU架構(gòu)的芯片展開討論,大部分是MCU吧,而多核CPU的討論相對比較復(fù)雜,暫不涉及~玩RTOS的朋友都知道,裸機與OS的最大區(qū)別就是實現(xiàn)多任務(wù)的并發(fā),其實你說裸機就不能實現(xiàn)任務(wù)的并發(fā)嗎 ? 這個需要看所站的角度吧,只是說RTOS并發(fā)的粒度可以更加細,因為你把裸機的任務(wù)拆分成多塊運行,其實也是一種并發(fā)方式。從宏觀上雖然RTOS的每個任務(wù)都是在并發(fā)執(zhí)行,其實微觀上還是一條一條指令在順序執(zhí)行著。

而對于目前主流的RTOS,如UCOS或者FreeRTOS,所實現(xiàn)的都是多任務(wù),更多的是一種多線程的并發(fā)執(zhí)行而非多進程,所以對應(yīng)到Linux平臺上稱他們?yōu)閠hread

2

并發(fā)帶來的問題

并發(fā)的好處就是能夠在更細的粒度來盡可能的提高CPU的利用率,這里不能說使用了多線程就一定能提高,這與你所設(shè)計的任務(wù)劃分和處理有著直接的關(guān)系,只能說多線程相比裸機更有這個能力。

而任何事物都有其利弊,多個任務(wù)在沒有同步處理的情況下,任務(wù)之間是無序運行的,無序也就意味著狀態(tài)的多樣性和復(fù)雜度。

當然bug菌這里所說的無序是一個相對的過程,比如對于CPU而言,它就是順序的去執(zhí)行一條一條的指令,所以在這個層面它是有序的、確定的。

而我們把過程放大,比如執(zhí)行一條C語言語句,一般它是由多條匯編指令組成,對于目前的搶占式內(nèi)核,在一段時間內(nèi)其多個任務(wù)就有可能指令交替執(zhí)行,當這些指令都去操作同一塊內(nèi)存,那么內(nèi)存的最終結(jié)果由于順序不同而不同,最終難以確定。

狀態(tài)的不確定就有可能造成異常行為,也就是大家經(jīng)常遇到的:“怎么跑著跑著就有問題,還沒啥規(guī)律~”,“這段代碼怎么看也沒問題呀~”

所以對比看來RTOS確實會帶來編程上的難度~

3

臨界區(qū)

既然有難度,我們就要解決,把不確定性部分通過一些手段來變得確定,而造成這些不確定因素的動力是什么呢?是中斷~

bug菌一直覺得,其實對于裸機而言,如果把中斷服務(wù)函數(shù)看成一個更高優(yōu)先級的搶占式任務(wù),其實裸機主任務(wù)與中斷任務(wù)就形成了一種兩任務(wù)的并發(fā),所以中斷與任務(wù)之間也是有共享問題需要類似處理的。

為了解決這些不確定因素,我們只需要在這段代碼區(qū)域限制中斷的發(fā)生即可,這一段區(qū)域就是臨界區(qū),說得直白點 : 關(guān)中斷與開中斷。

1ENTER_CRITICAL();//進入臨界區(qū)23//臨界區(qū)代碼45EXIT_CRITICAL();//退出臨界區(qū)

4

臨界區(qū)嵌套

臨界區(qū)的使用沒啥可說的,但是在你的代碼中怎么加臨界區(qū)確實一門技巧,可是說很多3~5年的工程師也并不一定處理得好,本文暫不展開,后面bug菌整理以后再分享給大家,今天只聊聊臨界區(qū)嵌套使用的問題,畢竟很多朋友在這里掉過坑~

參考偽代碼:

1/********************************************* 2 * Function: Fuction1 3 * Description:功能函數(shù)

4 * Author: bug菌 5 ********************************************/ 6void Fuction1(void)7{ 8 ENTER_CRITICAL();//進入臨界區(qū) 910 //do something~1112 EXIT_CRITICAL();//退出臨界區(qū)

13} 14/********************************************* 15 * Function: Fuction2 16 * Description: 功能函數(shù) 17 * Author: bug菌 18 ********************************************/19void Fuction2(void) 20{ 21 ENTER_CRITICAL();//進入臨界區(qū)2223... 24 Fuction1(); 2526. 27 //do something~2829 EXIT_CRITICAL();//退出臨界區(qū)30}

這種臨界區(qū)的使用是很多朋友常犯的錯誤,當然這里的臨界區(qū)操作僅僅只是開關(guān)中斷,許多自己公司寫的,或者裁剪的都是這種簡約開關(guān)中斷版本,所以當調(diào)用Function1函數(shù)以后,后面的代碼就不在臨界區(qū)內(nèi)了,此時就有可能會存在共享問題。

當然目前的開源OS都會提供一種把相關(guān)嵌套標記保存在局部變量中的處理方式,如下代碼所示:

1//來源于ucos源碼 2#define OS_ENTER_CRITICAL() (cpu_sr = OSCPUSaveSR()) 3#define OS_EXIT_CRITICAL()

(OSCPURestoreSR(cpu_sr)) 4 5/*********************************************6 * Function: Fuction1 7 * Description:功能函數(shù) 8 * Author: bug菌 9 ********************************************/10void Fuction1(void) 11{ 12 int cpu_sr; 1314 OS_ENTER_CRITICAL();//進入臨界區(qū)

1516 //do something~1718 OS_EXIT_CRITICAL();//退出臨界區(qū)

19} 2021/********************************************* 22 * Function: Fuction2 23 * Description: 功能函數(shù) 24 * Author: bug菌

25 ********************************************/26void Fuction2(void) 27{ 28 int cpu_sr; 2930 OS_ENTER_CRITICAL();//進入臨界區(qū)3132 Fuction1(void); 3334 OS_EXIT_CRITICAL();//退出臨界區(qū)

3536}

為了更好的理解,我寫了一下下面的偽代碼,供大家參數(shù)~

1//中斷寄存器register原本是1, 向register寫0關(guān)中斷,向register寫1開中斷 2 3void Fuction2(void) 4{ 5 int cpu_sr1 = 0; 6 7 cpu_sr1 = register; 8 register = 0;

//register == 0;

cpu_sr1 == 1; 910 void Fuction1(void) 11 { 12 int cpu_sr1 = 0; 1314 cpu_sr2 = register; 15 register = 0; //register == 0;cpu_sr2 == 0;

161718 register = cpu_sr2; 19 cpu_sr2 = 0;//register == 0;

cpu_sr2 == 0;20 } 2122 register = cpu_sr1; 23 cpu_sr1 = 0;//register == 1;cpu_sr1 == 0;2425}

不同的OS可能具體實現(xiàn)有所差異,大體上都一樣~

原文標題:同事在RTOS“臨界區(qū)嵌套使用”栽了跟頭~

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

責任編輯:haq

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

    關(guān)注

    68

    文章

    10807

    瀏覽量

    210853
  • RTOS
    +關(guān)注

    關(guān)注

    21

    文章

    809

    瀏覽量

    119362
  • 裸機程序
    +關(guān)注

    關(guān)注

    0

    文章

    4

    瀏覽量

    6983

原文標題:同事在RTOS"臨界區(qū)嵌套使用"栽了跟頭~

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

收藏 人收藏

    評論

    相關(guān)推薦

    韓國裸機云服務(wù)器是什么?

    韓國裸機云服務(wù)器是一種結(jié)合了裸機服務(wù)器與云端技術(shù),提供多IP地址分配和高性能網(wǎng)絡(luò)服務(wù)的云計算解決方案。主機推薦小編為您整理發(fā)布韓國裸機云服務(wù)器的詳細解釋。
    的頭像 發(fā)表于 11-06 10:11 ?54次閱讀

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

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

    freertos和裸機有什么區(qū)別

    的、搶占式實時操作系統(tǒng)(RTOS),適用于微控制器和小型處理器。它提供了多任務(wù)處理、任務(wù)優(yōu)先級、時間管理、內(nèi)存管理、同步機制等功能,使得開發(fā)者能夠更容易地編寫復(fù)雜的實時應(yīng)用程序。 1.2 裸機編程 裸機編程是指在沒有操作系統(tǒng)的情
    的頭像 發(fā)表于 09-02 14:13 ?918次閱讀

    RTOS的特性和類型

    實時操作系統(tǒng)(RTOS)是一種可運行實時計算應(yīng)用程序的軟件平臺,用于處理具有明確時間約束的事件和數(shù)據(jù)。與通用操作系統(tǒng)(GPOS)不同,RTOS必須在有限的硬件資源上調(diào)度應(yīng)用程序之間的處理和數(shù)據(jù)共享
    的頭像 發(fā)表于 08-20 11:29 ?463次閱讀

    RTOS開發(fā)最佳實踐

    基于RTOS編寫應(yīng)用程序時,有一些要注意事項。在本節(jié)中,您將學習RTOS開發(fā)最佳實踐,例如POSIX合規(guī)性、安全性和功能安全認證。
    的頭像 發(fā)表于 08-20 11:24 ?372次閱讀

    東京裸機云多IP服務(wù)器全面分析

    東京裸機云多IP服務(wù)器是一種提供多IP地址分配和高性能網(wǎng)絡(luò)服務(wù)的云計算解決方案,廣泛應(yīng)用于需要多IP管理和高穩(wěn)定性的網(wǎng)絡(luò)應(yīng)用。下面將從幾個方面具體介紹東京裸機云多IP服務(wù)器,rak部落為您整理發(fā)布東京裸機云多IP服務(wù)器的全面分析
    的頭像 發(fā)表于 07-22 09:49 ?274次閱讀

    洛杉磯裸機云大寬帶服務(wù)器的特性和優(yōu)勢

    洛杉磯裸機云大寬帶服務(wù)器是結(jié)合了物理服務(wù)器性能和云服務(wù)靈活性的高性能計算服務(wù),為用戶提供高效、安全的計算和存儲能力。在了解如何使用洛杉磯裸機云大寬帶服務(wù)器之前,需要了解其基本特性和優(yōu)勢。以下是對洛杉磯裸機云大寬帶服務(wù)器的具體分析
    的頭像 發(fā)表于 07-08 10:11 ?214次閱讀

    STM32mp135裸機開發(fā)無法使用DDR嗎?

    /STM32CubeMP13_Package_-_Getting_started#Integrating_AzureRTOS_middleware 咨詢一下關(guān)于DDR的使用問題: 1.只有RTOS的才能對DDR進行配置嗎? 2.單純裸機開發(fā)(無
    發(fā)表于 03-11 07:01

    基于RTOS的應(yīng)用進程中的典型線程

    RTOS中的關(guān)鍵因素是最小的中斷延遲和最小的線程切換延遲。RTOS的價值在于它的響應(yīng)速度或可預(yù)測性,而不是它在給定時間段內(nèi)可以執(zhí)行的工作量。
    發(fā)表于 03-05 09:32 ?498次閱讀
    基于<b class='flag-5'>RTOS</b>的應(yīng)用進程中的典型線程

    爆蘋果正在探索開發(fā)帶攝像頭的AirPods

    據(jù)知名蘋果爆料記者馬克?古爾曼消息,蘋果正在探索開發(fā)帶攝像頭的AirPods。
    的頭像 發(fā)表于 02-27 15:04 ?771次閱讀

    何時選擇裸機?何時選擇RTOS?何時選擇GPOS?

    在每個開發(fā)項目的初期,你都必須選擇軟件開發(fā)的基礎(chǔ)。雖然有很多選擇,但它們通常分為三類:裸機、實時操作系統(tǒng)(RTOS)或通用操作系統(tǒng)(GPOS)。
    的頭像 發(fā)表于 02-27 11:42 ?987次閱讀

    分享幾點RTOS相比裸機的優(yōu)勢

    嵌入式系統(tǒng)中,有很多方式實現(xiàn)任務(wù)調(diào)度。功能有限的小系統(tǒng)中,無限循環(huán)足夠?qū)崿F(xiàn)小系統(tǒng)的功能。當軟件設(shè)計變得龐大且復(fù)雜時,開發(fā)者應(yīng)該考慮使用實時操作系統(tǒng)RTOS。
    的頭像 發(fā)表于 01-24 18:23 ?1514次閱讀
    分享幾點<b class='flag-5'>RTOS</b>相比<b class='flag-5'>裸機</b>的優(yōu)勢

    幾點RTOS相比裸機的優(yōu)勢分享

    相比前后臺系統(tǒng)中后臺順序執(zhí)行的程序主體,在多線程系統(tǒng)中,根據(jù)程序的功能,我們把這個程序主體分割成一個個獨立的,無限循環(huán)且不能返回的小程序,這個小程序我們稱之為線程。
    發(fā)表于 01-24 18:21 ?747次閱讀
    幾點<b class='flag-5'>RTOS</b>相比<b class='flag-5'>裸機</b>的優(yōu)勢分享

    如何在裸機系統(tǒng)中集成SystemView

    SystemView是嵌入式系統(tǒng)可視化分析工具,提供了對應(yīng)用程序的完整洞察,包括時間軸、CPU負載、運行時間信息、上下文運行時信息等可視化窗口,能夠幫助開發(fā)者獲得對應(yīng)用運行時行為的深入理解。除μC
    的頭像 發(fā)表于 12-29 11:07 ?1863次閱讀
    如何在<b class='flag-5'>裸機</b>系統(tǒng)中集成SystemView

    “國產(chǎn)雙系統(tǒng)”出爐,RK3568J非對稱AMP:Linux+RTOS/裸機

    多處理架構(gòu)?!胺菍ΨQAMP”雙系統(tǒng)是指多個核心相對獨立運行不同的操作系統(tǒng)或裸機應(yīng)用程序,如Linux + RTOS/裸機,但需一個主核心來控制整個系統(tǒng)以及其它從核心。每個處理器核心相互隔離,擁有屬于自己的內(nèi)存
    發(fā)表于 12-01 09:35