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

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

3天內不再提示

裸奔和RTOS下的嵌入式開發(fā)有什么區(qū)別

GReq_mcu168 ? 來源:fqj ? 2019-05-30 17:53 ? 次閱讀

嵌入式設備網絡化、u盤化、功能復雜化的趨勢,使越來越多的、過去可以用裸奔實現的嵌入式產品,產生了應用操作系統的需求。

而人力成本的持續(xù)上升、芯片成本的連續(xù)下降,以及cpu性能的迅速提高,又為大面積應用操作系統提供了物質基礎。

本文和大家一起討論一下,從裸奔到操作系統,我們將面對什么挑戰(zhàn)。

1、速度

我們首先面對的,將是cpu運行速度的問題,毋庸置疑,操作系統調度需要cpu開銷,需要cpu有更高的速度來彌補;再者,嵌入式系統經常用于實時控制,需要較高的定時精度,縮短tick時間間隔有利于提高控制精度,嵌入式系統中經常使用1mS甚至更短的tick間隔。然而,tick間隔越短,調度開銷就越高,同樣需要更高的cpu速度來彌補。當前日益提高的嵌入式cpu的性能,甚至單片機都32位了,很好地回答了這個問題。

2、內存容量

先討論一個問題,一個原先需要50K內存的裸奔程序,如果移植到自身開銷1K內存的RTOS下面,需要增加多少內存?是51K嗎?

有許多嵌入式操作系統,都把運行操作系統的內存開銷作為主要性能指標,有些甚至聲稱不到1K內存就可以運行。但我們千萬不要被誤導,以為用操作系統需要的內存與裸機差不多,只要比裸奔程序多那么1K、2K就行了。操作系統會使應用程序所需要的內存暴增,使用操作系統所增加的內存需求,主要來自以下方面:

1) 運行操作系統本身需要的內存。2) 創(chuàng)建線程控制塊、消息控制塊等操作系統組件需要的內存。3) 每個線程配置獨立的棧所增加的內存需求。

其中第一項很好理解,幾乎所有操作系統都會給出這個指標。第二項也容易理解,不用操作系統的情況下,我們常常定義標志位或全局變量來在不同模塊之間傳遞信息,需要的內存就很少。而操作系統模式下,需要用到同步、互斥、線程間交換數據等,這就需要使用信號量、郵箱等操作系統組件,信號量需要分配信號量控制塊,郵箱需要分配郵箱控制塊……,這些,都需要消耗可觀的內存。許多操作系統標明的,僅僅是OS本身運行需要的內存,并不包括信號量控制塊拉、郵箱控制塊拉等等這些操作系統組件需要的內存。


我們知道,一個僅運行OS的系統,是毫無意義的,真正實現產品功能的,是應用程序。而djyos的si版本,大約需要的10K內存,則包含了一定數量的事件控制塊、信號量控制塊等操作系統組件所需內存的條件下的,完全滿足一個小型系統所需。

說了半天,其實也只講了操作系統對內存需求的冰山一角,OS下編程,對內存需求的影響最大的,當屬OS的多線程并發(fā)特性,這使得我們要為每一個線程分配獨立的棧。下面我們定性分析一下棧獨立化帶來的內存需求變化。棧是用來保存函數參數和局部變量的,可以說,有函數調用,就有局部變量。在單線程環(huán)境下,應用程序需要的棧,幾乎就是main函數需要的棧,而在多線程環(huán)境下,每個線程的棧是獨立的,分別等于該線程的線程執(zhí)行函數所需要的棧,而系統總的棧需求,就是所有線程的棧需求之和。

在超級循環(huán)中,分別調用了func1~func5這5個函數,他們的棧需求分別是10K、5K、9K、8K、9K。調用func1時,系統分配10K的ram作為棧,func1函數返回,這10K空間將被釋放,并且再次分配給func2使用,所以,整個程序的棧需求,就是這5個函數中需要棧最多的那個函數需要的??臻g:10K。

如果要把這個程序移植到OS下,最簡單的方法就是創(chuàng)建5個線程來調用func1~5這5個函數,這5個線程需要的棧分別是10K、5K、9K、8K、9K,而這5個棧是獨立的,不能共用,程序總共需要的??臻g是(10+5+9+8+9)=41K,線程棧一般是從堆中動態(tài)分配的,考慮到動態(tài)分配本身的開銷,硬件須準備50K以上的內存用于程序的運行棧。一下子增長到5倍,沒想到吧。

可見,上操作系統,雖然操作系統本身不需要很大內存,但會極度增加應用程序的內存需求。做項目時,一是不要盲目上OS,要根據需求綜合考慮,二是設計硬件系統時,應該充分考慮到內存方面的需求,配置充足的內存。

3、人

任何產品都是由人開發(fā)的,所以,討論嵌入式產品開發(fā)的任何話題,都不能離開人的因素,科技以人為本嘛!從裸奔到操作系統,那么程序員,也將由編寫裸奔程序轉為在操作系統下編程。這些迅速、大量增加的程序員,他們可能習慣了在裸奔環(huán)境下編程,他們可能是化工、建筑、地質等不同行業(yè)的專家,他們也許已經上了年紀,沒有太多的精力學習多線程編程等知識。然而,涉及到專業(yè)的程序,仍然離不開他們,如何從技術上降低他們的入門門檻,是一個亟需考慮的問題。但是,普通的操作系統下,你不掌握線程控制技術,就無法編寫正確的程序。djyos允許你按事件編程,沒有任何跟線程相關的api函數,無需程序員掌握線程技術,客觀上降低了裸奔到OS編程的轉換技術門檻。

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

    關注

    5059

    文章

    18975

    瀏覽量

    302069
  • 內存
    +關注

    關注

    8

    文章

    2976

    瀏覽量

    73815

原文標題:裸奔和RTOS下的嵌入式開發(fā),有啥不同

文章出處:【微信號:mcu168,微信公眾號:硬件攻城獅】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    RTOS與Linux到底有什么區(qū)別

    很多做嵌入式開發(fā)的小伙伴都存在這樣的疑惑:RTOS與Linux到底有什么區(qū)別?
    的頭像 發(fā)表于 10-29 09:53 ?220次閱讀

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

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

    恩智浦加速嵌入式AI創(chuàng)新應用開發(fā)

    在AI應用飛速發(fā)展的今天,如何能夠將AI與嵌入式系統開發(fā)有機結合起來,營造新的開發(fā)生態(tài),打造與眾不同的創(chuàng)新用例,一直是嵌入式開發(fā)者追求的目標。
    的頭像 發(fā)表于 08-27 09:46 ?776次閱讀

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

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

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

    嵌入式開發(fā)前景非常廣闊,這主要得益于物聯網、人工智能、大數據等技術的快速發(fā)展,以及嵌入式系統在各個領域的廣泛應用。以下是對嵌入式開發(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

    stm32的寄存器開發(fā)和庫開發(fā)有什么區(qū)別?到底哪個更好?

    stm32的寄存器開發(fā)和庫開發(fā)有什么區(qū)別,到底哪個更好?
    發(fā)表于 05-13 08:24

    fpga是嵌入式開發(fā)

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

    fpga與嵌入式區(qū)別 嵌入式和fpga開發(fā)有什么關系

    fpga與嵌入式區(qū)別 FPGA與嵌入式系統在設計和應用上存在一些關鍵的區(qū)別,具體如下: 靈活性:FPGA具有高度的靈活性,可以根據需要重新編程以實現不同的功能。而
    的頭像 發(fā)表于 03-14 17:04 ?6673次閱讀

    嵌入式軟件開發(fā)和軟件開發(fā)區(qū)別

    之間的區(qū)別。 硬件環(huán)境和資源限制: 嵌入式系統通常運行在資源有限的嵌入式設備上,如單片機、嵌入式開發(fā)板或微控制器等。這些設備通常具有有限的處理能力、存儲容量以及功耗要求。相比之下,計算
    的頭像 發(fā)表于 01-22 15:27 ?2125次閱讀

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

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

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

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

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

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

    嵌入式開發(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>學習路線分享