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

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

3天內不再提示

嵌入式開發(fā)用RTOS的優(yōu)勢在哪?

STM32嵌入式開發(fā) ? 來源:STM32嵌入式開發(fā) ? 作者:STM32嵌入式開發(fā) ? 2022-04-13 11:40 ? 次閱讀

嵌入式開發(fā)中可能面臨的問題

1 并發(fā)性問題

程序并發(fā)工作效率低在寫裸機軟件時,不可避免的在主程序中會有一個超級大的 while(1) 循環(huán),這里面幾乎包含整個項目的所有業(yè)務邏輯。因為每個業(yè)務邏輯里面都會有 delay 這樣的循環(huán)等待函數,這樣導致了所有的業(yè)務邏輯幾乎都是串行起來工作的。這個時候 CPU 就會有很多時間都浪費在了延時函數里,一直在空轉,導致軟件的并發(fā)效率非常差。

2 模塊化:高內聚、低耦合的原則

從軟件工程的角度,我們在做軟件開發(fā)時,都會強調高內聚、低耦合的原則。而裸機的模塊化開發(fā)難度非常大,模塊間的耦合較重,這也導致了無法在大型項目使用裸機來開發(fā)。

還是剛才 main 函數中大 while(1) 的例子,可以想象到那么多功能都緊緊的擠在一個函數里,不可拆分,模塊化開發(fā)的困難重重。

舉一個非常貼切的例子,在一些使用看門狗的項目中,如果使用 delay 延時函數,那得注意點,萬一延時過長,主函數來不及喂狗,看門狗就被觸發(fā)了。最后會產生這樣一種感覺,一個簡簡單單的 delay 還得考慮喂狗功能,裸機開發(fā)時操的心太多了,自然無法應用在大型項目中。

3 生態(tài):很多高級軟件組件,必須依賴于操作系統(tǒng)來實現(xiàn)

比如說,我前些年開源過一個基于 FreeModbus 的 Modbus 主機協(xié)議棧,因為要考慮各個平臺適配問題,原本計劃支持各種各樣的操作系統(tǒng),甚至是裸機平臺。在各個操作系統(tǒng)上的適配都非常容易,但再去嘗試著適配裸機時,發(fā)現(xiàn)難度重重,有一些函數在裸機上實現(xiàn)起來非常復雜,而且針對于不同的裸機環(huán)境,幾乎沒有通用性可言,太耗費精力了。所以我最終就放棄了裸機適配,一直到現(xiàn)在,在裸機上還是沒法用這個 Modbus 主機協(xié)議棧。

還有一些軟件無法運行在裸機上,比如:樂鑫、Realtek、 ti聯(lián)發(fā)科 提供的 WIFi SOC SDK ,一些藍牙 SOC 的 SDK 也都是只支持操作系統(tǒng),所以,如果你不了解、不會使用操作系統(tǒng),這些芯片也就玩不轉了。

4 實時性:功能復雜的情況下,實時性無法保證

軟件的實時性在一些領域會有一定的要求,軟件的每個步驟必須在指定的時間被觸發(fā)。工控領域就是最常見到的場景,如果實時性無法保證,機械設備可能就無法按照指定時序要求去動作,以至于發(fā)生機械事故,甚至會威脅到人的生命?;剡^來接著看裸機軟件,如果軟件變得龐大以后,可以想象到,主程序中那么大的一個 while(1) 循環(huán),代碼耦合嚴重,到處都是 delay 延時,要保證實時性幾乎是不可能的。

5 可重用性:軟件可重用性差,總是重復造輪子

可重用性與模塊化程度有直接的關系。相信大家每個人在工作中都不想做很多重復性的工作,同樣在寫代碼時,也想著盡可能少寫一些功能相似的代碼。但在這個嵌入式碎片化極其嚴重的時代,各式各樣的芯片,想要讓同樣的代碼,在裸機環(huán)境下同時適配不同的硬件,難度非常大。這樣也就導致了裸機的代碼會過多的依賴于底層硬件,重復造輪子的過程也就不可避免。

RTOS帶來的優(yōu)勢

第一次接觸操作系統(tǒng),是在 2010 年左右,那時 STM32 已經開始流行起來,這么強大的單片機,有很多人都在上面跑操作系統(tǒng),我也跟著移植了 ucos ,在上面還跑了 ucgui ,這個時候寫應用完全是一種全新的體驗,爽了很多,玩了一年了 ucos ,后來接觸到咱們國產的 RT-Thread ,在它上面有很多現(xiàn)成的、拿來即用組件,試用以后發(fā)現(xiàn)更爽,就一直用到了今天,大概有 8 年了。也跟大家也聊一聊操作系統(tǒng)的優(yōu)勢:

線程方式的并發(fā)任務處理,解決模塊化問題,同時保證實時性

1 模塊化

使用了操作系統(tǒng)以后,整個軟件的工作被拆分成了由多個任務來構成(也會被稱為線程),每個線程有自己獨立的運行空間,即線程堆棧:線程、進程、多線程、多進程和多任務之間的關系?這個時候每個線程你玩你的,我做我的,咱們大家互補干涉,模塊化程度得到很好的提高。

2 并發(fā)性

從并發(fā)的角度來看,各個線程在使用 delay/事件等待 這類函數時,會自動的讓出 CPU 給其他有需要的線程,不僅書寫 delay 延時函數操的心少了,整個 CPU 的利用率也得到了提高,最終提升并發(fā)性。

3 實時性

再來看實時性,像 ucos/RT-Thread 這些 RTOS 本身就被設計為實時的操作系統(tǒng),各個線程都有不同的優(yōu)先級別,重要的線程可以設為高優(yōu)先級,不重要的線程可以降低優(yōu)先級,做好全局的統(tǒng)籌規(guī)劃后,這樣整個軟件的實時性也能得到保證。

4 開發(fā)效率

由于操作系統(tǒng)提供了統(tǒng)一的抽象接口層,方便了可重用組件的積累,提高開發(fā)效率

操作系統(tǒng)其實是一群軟件大牛們智慧的結晶,他們站在應用軟件、底層驅動的開發(fā)角度,對很多常見的軟件功能進行了封裝、抽象,比如:信號量、事件通知、郵箱、環(huán)形緩沖區(qū)、單向鏈表/雙向鏈表等等,這些功能拿來即用,對于開發(fā)者方便極了

還有一些操作系統(tǒng),比如:Linux 和我們國產的 RT-Thread ,他們這些系統(tǒng)對碎片化的硬件,統(tǒng)一封裝了一套標準的硬件操作接口,一般稱為設備驅動框架。這樣我們的應用軟件工程師,就可以專攻應用的工作,再也不用怕更換硬件,又需要重復造輪子了。

5 軟件生態(tài)

生態(tài)的豐富帶來了量變到質變的過程:

從自己玩,轉變?yōu)榇蠹乙黄鹜妗?/p>

使用操作系統(tǒng)所帶來的軟件可模塊化、重用性的提升,也使得我們自己在做軟件開發(fā)時,可以封裝一套基于操作系統(tǒng)、適合嵌入式的可重用組件,這些組件不僅可以用在自己的項目中,還能開源出來分享給更多有需要的嵌入式開發(fā)者,把軟件的價值最大化。

個人感覺這是一件蠻有意義事情,我自己本身也是一名開源極客,也有在 GitHub 上開源一些嵌入式軟件

說實話在做開源軟件前,能夠深入交流嵌入式軟件的地方非常少,畢竟大家的代碼不是芯片不一樣,就是硬件不一樣,你的代碼給了他,也不一定能運行起來。但是自從用了操作系統(tǒng)后,軟件的可重用性提高了,能夠讓更多的人很迅速的用起來我的開源軟件,這個時候能夠有更多的人可以一起交流,還接觸到了很多的大牛們,甚至是國外的朋友。俗話說:水漲船高,我的能力也從此得到了快速的提升。所以總結下來,有一個能一起交流嵌入式軟件圈子還是蠻重要的,自己閉門造車,可能都是在重復造輪子。

常見RTOS對比

ucos/freertos/RT-Thread,選擇這三款 OS 的原因是,它們的年限都比較長了,在市面上都蠻有知名度,用過的人比較多,更有說服力。

值得一提的是,在CubeMX工具中有FreeRTOS,支持很方便。如果是STM32開發(fā)的話,F(xiàn)reeRTOS基本是入門RTOS的首選了。

1 基本功能、性能

各家 RTOS 差異很小,可比性并不是很大。

2 易用性/可讀性

這塊 FreeRTOS 應該說是最差,奇葩的匈牙利命名法,代碼實現(xiàn)用了很多宏,可讀性非常差。ucos 可讀性還可以,注釋也很全。這塊做的比較好的是 RT-Thread ,它是類 Linux 的代碼風格,面向對象的設計模式,代碼簡潔易懂。在保證了體積(最小 ROM:3K RAM:1.5K)的同時,還借鑒了 Linux 的設備驅動框架、虛擬文件系統(tǒng)、Shell 等功能,設計更加優(yōu)雅。

3 組件豐富性

RT-Thread 比起傳統(tǒng) UCOS、FreeRTOS 不僅僅在基礎功能上多而全,多達 50 個以上的可重用軟件組件,還有很多物聯(lián)網組件,對于物聯(lián)網產品幾乎做到開箱即用。RT-Thread 還可以運行 Python、Java、Lua 這些高級語言的腳本,進一步降低開發(fā)難度。

4 開發(fā)資料

這塊 ucos 做的最好,還有配套相關的書籍,F(xiàn)reeRTOS 屬于后起之秀,網上也有很多相關資料。RT-Thread 這塊之前還是略顯薄弱的,不過現(xiàn)在 RT-Thread 對這塊非常重視,最直觀的可以看到官網上的應用筆記越來越多了,還有一些配套教學視頻。

5 版權

ucos 商業(yè)是要收費的,F(xiàn)reeRTOS 和 RT-Thread 版權都很寬松,特別是RT-Thread剛剛使用了Apache許可協(xié)議。

6 社區(qū)生態(tài)

這三款 RTOS 的社區(qū)都比較活躍,現(xiàn)在可以感覺到 ucos 慢慢的用的人越來越少了,RT-Thread 和 FreeRTOS 用的人都在增多。RT-Thread 也是開發(fā)者最多的國產 RTOS,并且還擁有國內最大的嵌入式開源軟件社區(qū)。

審核編輯 :李倩

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

    關注

    18

    文章

    1018

    瀏覽量

    47473
  • 模塊化
    +關注

    關注

    0

    文章

    328

    瀏覽量

    21323

原文標題:嵌入式開發(fā)用RTOS的優(yōu)勢在哪?

文章出處:【微信號:c-stm32,微信公眾號:STM32嵌入式開發(fā)】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    嵌入式開發(fā)常見問題排查

    嵌入式開發(fā)問題排查很多人認為嵌入式開發(fā)很難,主要是因為在這個過程中常常會遇到各式各樣的問題。這些問題的復雜性和多樣性使得許多人感到困惑和無所適從。然而,如果將這些問題逐一拆解,實際上大部分都可以
    的頭像 發(fā)表于 09-22 08:04 ?240次閱讀
    <b class='flag-5'>嵌入式開發(fā)</b>常見問題排查

    聚焦嵌入式開發(fā)中的合規(guī)性工具、項目管理工具、版本迭代工具應用

    日前,龍智攜嵌入式開發(fā)及管理解決方案亮相2024上海國際嵌入式展(embedded world China 2024)。展會期間,我們對話了多位龍智資深DevSecOps顧問及技術支持專家
    的頭像 發(fā)表于 07-29 15:15 ?440次閱讀

    從菜鳥到大牛!嵌入式完整學習路線:STM32單片機-RTOS-Linux

    ?嵌入式系統(tǒng)是許多現(xiàn)代電子設備和智能系統(tǒng)的核心,掌握嵌入式系統(tǒng),意味著能夠設計和開發(fā)更加智能化的產品。本文為所有想進入嵌入式領域的初學者提供一個完整系統(tǒng)學習的路線圖,按照“STM32單
    的頭像 發(fā)表于 07-23 16:11 ?3388次閱讀
    從菜鳥到大牛!<b class='flag-5'>嵌入式</b>完整學習路線:STM32單片機-<b class='flag-5'>RTOS</b>-Linux

    嵌入式開發(fā)前景怎么樣?

    嵌入式開發(fā)前景非常廣闊,這主要得益于物聯(lián)網、人工智能、大數據等技術的快速發(fā)展,以及嵌入式系統(tǒng)在各個領域的廣泛應用。以下是對嵌入式開發(fā)前景的詳細分析
    的頭像 發(fā)表于 07-10 09:00 ?2353次閱讀
    <b class='flag-5'>嵌入式開發(fā)</b>前景怎么樣?

    嵌入式開發(fā)就業(yè)前景怎么樣?

    嵌入式開發(fā)就業(yè)前景怎么樣?隨著科技的飛速發(fā)展,嵌入式開發(fā)在各個領域的應用越來越廣泛,因此嵌入式開發(fā)的就業(yè)前景也備受關注。今天將從智能家居、醫(yī)療設備、工業(yè)控制、汽車電子、航空航天等方面,探討嵌入
    發(fā)表于 06-07 14:51

    ARM Cortex-A53嵌入式開發(fā)平臺Android手冊

    電子發(fā)燒友網站提供《ARM Cortex-A53嵌入式開發(fā)平臺Android手冊.pdf》資料免費下載
    發(fā)表于 04-28 15:10 ?0次下載

    fpga是嵌入式開發(fā)

    FPGA(現(xiàn)場可編程門陣列)與嵌入式開發(fā)之間確實存在一定的關聯(lián),但它們在本質上是兩個不同的領域。
    的頭像 發(fā)表于 03-15 14:18 ?942次閱讀

    嵌入式開發(fā)常見的C語言技巧與方法分享

    嵌入式開發(fā)中,常常要操作寄存器,對寄存器進行寫入,讀出等等操作。每個寄存器都有自己固有的地址,通過C語言訪問這些地址就變得尤為重要。
    的頭像 發(fā)表于 12-26 09:55 ?1030次閱讀

    嵌入式開發(fā)學習的十三法則分享

    嵌入式開發(fā)學習是一個不斷積累和總結的過程,來自一個嵌入式開發(fā)高級工程師為我們總結的關于嵌入式開發(fā)學習的十三法則,大家不妨參考一下: 一、冗余度法則 在嵌入式系統(tǒng)具有足夠的冗余度
    發(fā)表于 12-21 06:32

    嵌入式開發(fā)測試秘訣

    。 多年前,一位工程師為了對嵌入式擁有更深層次理解的追求,曾發(fā)出這樣的疑問:“我怎么才能知道并懂得我的系統(tǒng)到底在干些什么呢?”。同時代的嵌入式開發(fā)人員問得最多的問題大都圍繞“我怎么才能使程序跑得更快”、“什么編譯器最
    的頭像 發(fā)表于 11-24 16:18 ?485次閱讀

    嵌入式C語言的結構特點

    嵌入式開發(fā)中既有底層硬件的開發(fā)又涉及上層應用的開發(fā),即涉及系統(tǒng)的硬件和軟件,C語言既具有匯編語言操作底層的優(yōu)勢,又具有高級語言功能性強的特點,當之無愧地成為
    的頭像 發(fā)表于 11-24 16:16 ?621次閱讀
    <b class='flag-5'>嵌入式</b>C語言的結構特點

    c語言嵌入式開發(fā)

    電子發(fā)燒友網站提供《c語言嵌入式開發(fā).zip》資料免費下載
    發(fā)表于 11-17 14:11 ?2次下載
    c語言<b class='flag-5'>嵌入式開發(fā)</b>

    嵌入式開發(fā)系統(tǒng)基礎知識

    電子發(fā)燒友網站提供《嵌入式開發(fā)系統(tǒng)基礎知識.pdf》資料免費下載
    發(fā)表于 11-17 10:59 ?11次下載
    <b class='flag-5'>嵌入式開發(fā)</b>系統(tǒng)基礎知識

    嵌入式開發(fā)學習路線

    電子發(fā)燒友網站提供《嵌入式開發(fā)學習路線.doc》資料免費下載
    發(fā)表于 11-17 10:13 ?13次下載
    <b class='flag-5'>嵌入式開發(fā)</b>學習路線

    嵌入式開發(fā)學習路線分享

    的實際應用范疇,可以說目前市場上對嵌入式開發(fā)人才的需求越來越大,很多小伙伴都想通過培訓學習的方式走向嵌入式開發(fā)相關的崗位。下面,小編就給各位小伙伴介紹一個簡單易懂的學
    的頭像 發(fā)表于 11-15 11:51 ?1277次閱讀
    <b class='flag-5'>嵌入式開發(fā)</b>學習路線分享