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

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

3天內不再提示

分析一下CesiμmRTOS與FreeRTOS的差異

麥克泰技術 ? 來源:麥克泰技術 ? 2023-02-12 10:17 ? 次閱讀

μC/OS的商業(yè)版Cesiμm RTOS,和FreeRTOS是嵌入式軟件領域流行的兩種實時內核。雖然這兩款RTOS功能相似,并且具有可比較的執(zhí)行指標,但它們都有各自的優(yōu)點和缺點,本文將分析一下其差異。

功能區(qū)別

Cesiμm RTOS和FreeRTOS的API之間存在比較大的差異。以信號量創(chuàng)建為例,F(xiàn)reeRTOS提供了下列對象創(chuàng)建函數(shù):

1d7e0cf0-a983-11ed-bfe3-dac502259ad0.png

與信號量創(chuàng)建函數(shù)一樣,互斥信號量和隊列也使用類似的函數(shù)變體,而非一個統(tǒng)一的函數(shù)來創(chuàng)建這些內核對象,導致用戶必須熟悉更多的API。

雖然FreeRTOS這些函數(shù)使得在應用程序中查找相應的信號量創(chuàng)建函數(shù)更容易,但用戶需要付出更多努力理解每個函數(shù)的具體用途。相反,使用Cesiμm RTOS,信號量或互斥量創(chuàng)建更簡單。

1d931ab4-a983-11ed-bfe3-dac502259ad0.png

傳遞給函數(shù)的參數(shù)將決定用戶創(chuàng)建的對象類型。這種方法非常簡單,用戶不需要象FreeRTOS一樣,在調試時執(zhí)行多個重定向創(chuàng)建函數(shù)。

通過OSSemCreate()函數(shù),根據(jù)參數(shù)值可以創(chuàng)建二值、計數(shù)或靜態(tài)信號量,設置初始計數(shù)并將信號量數(shù)據(jù)對象定義為靜態(tài)變量或非靜態(tài)變量。

通過傳入創(chuàng)建函數(shù)的不同參數(shù),創(chuàng)建與FreeRTOS相同類型的對象,而無需為每個對象單獨提供函數(shù)。

從使用上講,Cesiμm RTOS的功能沒有缺失,但調試時需要了解、管理和維護的API更少。

調試特性

FreeRTOS中,信號量創(chuàng)建函數(shù)將映射到等效隊列函數(shù)實例中。例如:

1da2c090-a983-11ed-bfe3-dac502259ad0.png

隨著函數(shù)嵌套深度的增加,在調試期間跟蹤錯誤將變得更加困難。而在Cesiμm RTOS中調試信號量、隊列或互斥信號量的創(chuàng)建更簡單,更容易找到故障點或錯誤配置。

例如xSemaphoreTake()函數(shù)將調用xQueueSemaphoreTake()函數(shù),后者將根據(jù)調用來自信號量還是隊列,實現(xiàn)后續(xù)操作。

額外的條件處理使函數(shù)在調試時的跟蹤更加復雜。相比之下,Cesiμm RTOS中的創(chuàng)建函數(shù)更直接、簡短,并且能更快的調試并識別問題。

在性能方面,兩者幾乎相同,但從開發(fā)人員的角度來看,Cesiμm RTOS代碼將更容易跟蹤。

特性區(qū)別

盡管兩個內核提供的功能相似,但Cesiμm RTOS提供了更高的代碼質量和一些獨特的特性。

其中包括更具描述性的錯誤返回代碼、與現(xiàn)成的Cesiμm軟件棧的兼容性以及整體代碼的清潔度。

錯誤返回碼

FreeRTOS函數(shù)返回碼非常簡單。通常會給出兩個返回代碼值給其調用API。大多數(shù)函數(shù)的返回值為pdPASS, pdFAIL, pdTRUE和pdFALSE。

對于描述性稍強的返回代碼,一些函數(shù)可能返回值errCOULD_NOT_ALLOCATE_REQUIRED_

MEMORY、errQUEUE_BLOCKED、errQUEUE_YIELD、errQUEUE_BLOCKED或errQUEUE_YIELD。

當試圖檢測代碼以實現(xiàn)故障恢復或更復雜的錯誤處理時,這些返回值無法提供更多詳細的反饋。

如vSemaphoreDelete(),這個函數(shù)調用了vQueueDelete(),其返回代碼是void,這使得測試該函數(shù)的結果是成功還是失敗變得很棘手。

1db4266e-a983-11ed-bfe3-dac502259ad0.png

相比之下,Cesiμm RTOS提供了豐富的錯誤返回值和消息,供開發(fā)人員在API中使用。所有用戶調用的OS函數(shù)都提供了(OS_ERR *)類型參數(shù)。

該變量在執(zhí)行完成時被賦予一個值來反映成功或失敗的原因。這些細節(jié)可以提供更精確的調試體驗。

當調試一個大型應用程序時,這個特性將顯著影響開發(fā)時間。

vSemaphoreDelete()的等效函數(shù),在Cesiμm RTOS 為OSSemDel(),此函數(shù)接受(OS_ERR *)類型參數(shù),該參數(shù)可以返回以下值之一。

1dc6c1a2-a983-11ed-bfe3-dac502259ad0.png

支持的軟件棧

Cesiμm RTOS的另一個優(yōu)勢是其豐富的中間件支持。中間件與RTOS基于相同的規(guī)范設計和標準。使開發(fā)人員的學習體驗更加順暢。

廣泛使的用FreeRTOS,也支持許多第三方軟件棧。然而,這些產品具有不同的代碼設計標準,使得產品集成更具挑戰(zhàn)性。開發(fā)人員不僅要學習新產品,還必須熟悉其代碼風格。移植和集成工作更具挑戰(zhàn)性。Cesiμm RTOS全系列軟件產品在設計時考慮到了互操作性。這有助于加快開發(fā)人員在集成新軟件堆棧時的學習曲線。Cesiμm RTOS提供以下產品棧:

· 文件系統(tǒng)Cs/FS

· 網(wǎng)絡協(xié)議棧Cs/NET,其中應用協(xié)議如HTTP、DHCP等

· USB設備棧Cs/USBD

· USB主機棧Cs/USBH

· Modbus棧Cs/Modbus

此時,Cesiμm還支持SSL解決方案、圖形用戶接口和其他第三方產品。

潔凈的代碼

在查看代碼時,將代碼和注釋混合在一起時中,將很難將兩者分開并只關注其中一個。因此,Cesiμm RTOS代碼被劃分為左邊的代碼和右邊的注釋。當然,這并沒有真正的改進性能,完全是為了用戶體驗。結構越清晰,就越容易學習、使用和支持。這使得理解Cesiμm RTOS代碼更容易,從而節(jié)省了進入開發(fā)階段的時間。

雖然FreeRTOS和Cesiμm RTOS解決方案在性能和功能上相似,但Cesium RTOS提供了的更佳的用戶體驗。為應用程序選擇最佳的RTOS涉及許多因素,例如性能、功能和可靠性。對開發(fā)人員來說,同樣重要的是精通RTOS特性所需的努力程度及其易用性(其中包括應用程序調試,這是開發(fā)周期中經常被忽視的階段)。

隨著應用的增長,會添加新的特性集,整個項目的復雜性也會增加。Cesiμm RTOS內置的用戶體驗增強功能使用戶在復雜應用程序中更高效,并幫助提高工作效率。







審核編輯:劉清

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

    關注

    21

    文章

    808

    瀏覽量

    119314
  • FreeRTOS
    +關注

    關注

    12

    文章

    483

    瀏覽量

    61875
  • Err
    Err
    +關注

    關注

    0

    文章

    6

    瀏覽量

    6494
  • API串口
    +關注

    關注

    0

    文章

    13

    瀏覽量

    4832

原文標題:【內核對比】CesiμmRTOS vs FreeRTOS

文章出處:【微信號:麥克泰技術,微信公眾號:麥克泰技術】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    分析一下uC/OS-III和FreeRTOS的區(qū)別

    樣的,但是有個任務比較重要,我們希望讓它的CPU占用率高點,這時只要把它的時間片設置得大點即可。而在FreeRTOS中同優(yōu)先級的每個任務對CPU的占用率都只能是
    發(fā)表于 12-17 10:31

    supervisor的第三方軟件Web統(tǒng)管理界面cesi

    supervisor進程管理(三_II):Web統(tǒng)管理界面cesi
    發(fā)表于 04-02 11:48

    關于FreeRTOS內存管理的疑問誰來解答一下

    今天看了原子哥講的FreeRTOS關于內存管理方面的書和視頻,看完之后有個疑問直不明白,貼出來大家分析一下。原子哥也講了,實際在應用中,尤其是簡單的單片機應用中,用的最多的內存管理方
    發(fā)表于 06-16 04:35

    請問一下FreeRTOS系統(tǒng)的LwIP-1.4.1是怎樣移植的

    請問一下FreeRTOS系統(tǒng)的LwIP-1.4.1是怎樣移植的?有哪些移植過程?
    發(fā)表于 11-03 07:06

    梳理一下FreeRTOS任務管理單元實現(xiàn)思路

    關注、星標嵌入式客棧,精彩及時送達[導讀] 學習梳理一下FreeRTOS任務管理單元實現(xiàn)思路,代碼分析基于V10.4.3。從本文開始計劃寫個圖解freeRTOS內核系列筆記分享給朋友們
    發(fā)表于 01-13 07:08

    梳理一下FreeRTOS內核代碼規(guī)范

    [導讀] 遇到些朋友感覺FreeRTOS內核代碼看起來很不習慣,不習慣其編碼風格,本文就來梳理一下其代碼規(guī)范,便于提高閱讀其代碼的效率。代碼基于FreeRTOS V10.4.3。FreeR...
    發(fā)表于 03-01 07:33

    能否幫忙介紹一下FreeRTOS分配SRAM和DDR的功能是什么,是如何工作的?

    能否幫忙介紹一下FreeRTOS分配SRAM和DDR的功能是什么,是如何工作的?
    發(fā)表于 04-28 07:00

    FreeRTOS對lwIP的移植程序

    FreeRTOS對 lwIP的移植程序。
    發(fā)表于 10-29 10:58 ?11次下載

    談談FreeRTOS及其授權方式

    FreeRTOS及其授權方式如果需要了解的可以看一下!
    發(fā)表于 01-04 18:12 ?0次下載

    電磁爐加熱一下就停一下什么原因及解決辦法

    電磁爐有時會出現(xiàn)加熱故障,現(xiàn)象是熱一下一下在熱一下又停一下,基本隔
    發(fā)表于 03-18 09:02 ?27.3w次閱讀

    電磁爐加熱一下就停一下什么原因

    電磁爐加熱一下就停一下什么原因。
    的頭像 發(fā)表于 06-04 10:01 ?3.8w次閱讀

    初入FreeRTOS

    源碼3、FreeRTOS移植操作三、在STM32完成個基于FreeRTOS的多任務程序1、任務要求2、任務實施3、任務結果四、總結、
    發(fā)表于 12-06 21:06 ?40次下載
    初入<b class='flag-5'>FreeRTOS</b>

    圖解FreeRTOS 原理系列之任務管理器基本框架

    [導讀] 學習梳理一下FreeRTOS任務管理單元實現(xiàn)思路,代碼分析基于V10.4.3。從本文開始計劃寫個圖解freeRTOS內核系列筆記分享給朋友們,...
    發(fā)表于 01-25 19:49 ?4次下載
    圖解<b class='flag-5'>FreeRTOS</b> 原理系列之任務管理器基本框架

    FreeRTOS高級篇2---FreeRTOS任務創(chuàng)建分析

    FreeRTOS基礎系列《FreeRTOS系列第10篇---FreeRTOS任務創(chuàng)建和刪除》中介紹了任務創(chuàng)建API函數(shù)xTaskCreate(),我們這里先回顧一下這個函...
    發(fā)表于 01-26 17:42 ?23次下載
    <b class='flag-5'>FreeRTOS</b>高級篇2---<b class='flag-5'>FreeRTOS</b>任務創(chuàng)建<b class='flag-5'>分析</b>

    分析一下SR鎖存器的原理

    作為電路設計者,鎖存器很多場合都會用到,今天和大家分析一下SR鎖存器的原理。
    的頭像 發(fā)表于 08-20 17:30 ?6751次閱讀
    <b class='flag-5'>分析</b><b class='flag-5'>一下</b>SR鎖存器的原理