吴忠躺衫网络科技有限公司

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

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

3天內不再提示

嵌入式實時操作系統:RTOS和PC上的區別

h1654155971.7688 ? 來源:未知 ? 作者:李倩 ? 2018-04-09 09:38 ? 次閱讀

嵌入式實時系統中采用的操作系統我們稱為嵌入式實時操作系統,它既是嵌入式操作系統,又是實時操作系統。作為一種嵌入式操作系統,它具有嵌入式軟件共有的可裁剪、低資源占用、低功耗等特點;而作為一種實時操作系統(本文對實時操作系統特性的討論僅限于強實時操作系統,下面提到的實時操作系統也均指強實時操作系統),它與通用操作系統(如Windows、Unix、Linux等)相比有很大的差別,下面我們將通過比較這兩種操作系統之間的差別來逐步描述實時操作系統的主要特點。我們在日常工作學習環境中接觸最多的是通用操作系統,通用操作系統是由分時操作系統發展而來,大部分都支持多用戶和多進程,負責管理眾多的進程并為它們分配系統資源。分時操作系統的基本設計原則是:盡量縮短系統的平均響應時間并提高系統的吞吐率,在單位時間內為盡可能多的用戶請求提供服務。由此可以看出,分時操作系統注重平均表現性能,不注重個體表現性能。如對于整個系統來說,注重所有任務的平均響應時間而不關心單個任務的響應時間,對于某個單個任務來說,注重每次執行的平均響應時間而不關心某次特定執行的響應時間。通用操作系統中采用的很多策略和技巧都體現出了這種設計原則,如虛存管理機制中由于采用了LRU等頁替換算法,使得大部分的訪存需求能夠快速地通過物理內存完成,只有很小一部分的訪存需求需要通過調頁完成,但從總體上來看,平均訪存時間與不采用虛存技術相比沒有很大的提高,同時又獲得了虛空間可以遠大于物理內存容量等好處,因此虛存技術在通用操作系統中得到了十分廣泛的應用。類似的例子還有很多,如Unix文件系統中文件存放位置的間接索引查詢機制等,甚至硬件設計中的Cache技術以及CPU的動態分支預測技術等也都體現出了這種設計原則。由此可見,這種注重平均表現,即統計型表現特性的設計原則的影響是十分深遠的。



而對于實時操作系統,前面我們已經提到,它除了要滿足應用的功能需求以外,更重要的是還要滿足應用提出的實時性要求,而組成一個應用的眾多實時任務對于實時性的要求是各不相同的,此外實時任務之間可能還會有一些復雜的關聯和同步關系,如執行順序限制、共享資源的互斥訪問要求等,這就為系統實時性的保證帶來了很大的困難。因此,實時操作系統所遵循的最重要的設計原則是:采用各種算法和策略,始終保證系統行為的可預測性(predictability)。可預測性是指在系統運行的任何時刻,在任何情況下,實時操作系統的資源調配策略都能為爭奪資源(包括CPU、內存、網絡帶寬等)的多個實時任務合理地分配資源,使每個實時任務的實時性要求都能得到滿足。與通用操作系統不同,實時操作系統注重的不是系統的平均表現,而是要求每個實時任務在最壞情況下都要滿足其實時性要求,也就是說,實時操作系統注重的是個體表現,更準確地講是個體最壞情況表現。舉例來說,如果實時操作系統采用標準的虛存技術,則一個實時任務執行的最壞情況是每次訪存都需要調頁,如此累計起來的該任務在最壞情況下的運行時間是不可預測的,因此該任務的實時性無法得到保證。從而可以看出在通用操作系統中廣泛采用的虛存技術在實時操作系統中不宜直接采用。由于實時操作系統與通用操作系統的基本設計原則差別很大,因此在很多資源調度策略的選擇上以及操作系統實現的方法上兩者都具有較大的差異,這些差異主要體現在以下幾點:

(1) 任務調度策略:

通用操作系統中的任務調度策略一般采用基于優先級的搶先式調度策略,對于優先級相同的進程則采用時間片輪轉調度方式,用戶進程可以通過系統調用動態地調整自己的優先級,操作系統也可根據情況調整某些進程的優先級。實時操作系統中的任務調度策略目前使用最廣泛的主要可分為兩種,一種是靜態表驅動方式,另一種是固定優先級搶先式調度方式。靜態表驅動方式是指在系統運行前工程師根據各任務的實時要求用手工的方式或在輔助工具的幫助下生成一張任務的運行時間表,這張時間表與列車的運行時刻表類似,指明了各任務的起始運行時間以及運行長度,運行時間表一旦生成就不再變化了,在運行時調度器只需根據這張表在指定的時刻啟動相應的任務即可。靜態表驅動方式的主要優點是:

運行時間表是在系統運行前生成的,因此可以采用較復雜的搜索算法找到較優的調度方案;運行時調度器開銷較小;

系統具有非常好的可預測性,實時性驗證也比較方便;

這種方式主要缺點是不靈活,需求一旦發生變化,就要重新生成整個運行時間表。由于具有非常好的可預測性,這種方式主要用于航空航天、軍事等對系統的實時性要求十分嚴格的領域。固定優先級搶先式調度方式則與通用操作系統中采用的基于優先級的調度方式基本類似,但在固定優先級搶先式調度方式中,進程的優先級是固定不變的,并且該優先級是在運行前通過某種優先級分配策略(如Rate-Monotonic、Deadline-Monotonic等)來指定的。這種方式的優缺點與靜態表驅動方式的優缺點正好完全相反,它主要應用于一些較簡單、較獨立的嵌入式系統,但隨著調度理論的不斷成熟和完善,這種方式也會逐漸在一些對實時性要求十分嚴格的領域中得到應用。目前市場上大部分的實時操作系統采用的都是這種調度方式。

(2) 內存管理:

關于虛存管理機制我們在上面已經進行了一些討論。為解決虛存給系統帶來的不可預測性,實時操作系統一般采用如下兩種方式:

在原有虛存管理機制的基礎上增加頁面鎖功能,用戶可將關鍵頁面鎖定在內存中,從而不會被swap程序將該頁面交換出內存。這種方式的優點是既得到了虛存管理機制為軟件開發帶來的好處,又提高了系統的可預測性。缺點是由于TLB等機制的設計也是按照注重平均表現的原則進行的,因此系統的可預測性并不能完全得到保障;

采用靜態內存劃分的方式,為每個實時任務劃分固定的內存區域。這種方式的優點是系統具有較好的可預測性,缺點是靈活性不夠好,任務對存儲器的需求一旦有變化就需要重新對內存進行劃分,此外虛存管理機制所帶來的好處也喪失了。

目前市場上的實時操作系統一般都采用第一種管理方式。

(3) 中斷處理:

在通用操作系統中,大部分外部中斷都是開啟的,中斷處理一般由設備驅動程序來完成。由于通用操作系統中的用戶進程一般都沒有實時性要求,而中斷處理程序直接跟硬件設備交互,可能有實時性要求,因此中斷處理程序的優先級被設定為高于任何用戶進程。但對于實時操作系統采用上述的中斷處理機制是不合適的。首先,外部中斷是環境向實時操作系統進行的輸入,它的頻度是與環境變化的速率相關的,而與實時操作系統無關。如果外部中斷產生的頻度不可預測,則一個實時任務在運行時被中斷處理程序阻塞的時間開銷也是不可預測的,從而使任務的實時性得不到保證;如果外部中斷產生的頻度是可預測的,一旦某外部中斷產生的頻度超出其預測值(如硬件故障產生的虛假中斷信號或預測值本身有誤)就可能會破壞整個系統的可預測性。其次,實時操作系統中的各用戶進程一般都有實時性要求,因此中斷處理程序優先級高于所有用戶進程的優先級分配方式是不合適的。一種較適合實時操作系統的中斷處理方式為:除時鐘中斷外,屏蔽所有其它中斷,中斷處理程序變為周期性的輪詢操作,這些操作由核心態的設備驅動程序或由用戶態的設備支持庫來完成。采用這種方式的主要好處是充分保證了系統的可預測性,主要缺點是對環境變化的響應可能不如上述中斷處理方式快,另外輪詢操作在一定程度上降低了CPU的有效利用率。另一種可行的方式是:對于采用輪詢方式無法滿足需求的外部事件,采用中斷方式,其它時間仍然采用輪詢方式。但此時中斷處理程序與所以其它任務一樣擁有優先級,調度器根據優先級對處于就緒態的任務和中斷處理程序統一進行處理器調度。這種方式使外部事件的響應速度加快,并避免了上述中斷方式帶來第二個問題,但第一個問題仍然存在。此外為提高時鐘中斷響應時間的可預測性,實時操作系統應盡可能少地屏蔽中斷。

(4) 共享資源的互斥訪問:

通用操作系統一般采用信號量機制來解決共享資源的互斥訪問問題。對于實時操作系統,如果任務調度采用靜態表驅動方式,共享資源的互斥訪問問題在生成運行時間表時已經考慮到了,在運行時無需再考慮。如果任務調度采用基于優先級的方式,則傳統的信號量機制在系統運行時很容易造成優先級倒置問題(PriorityInversion),即當一個高優先級任務通過信號量機制訪問共享資源時,該信號量已被一低優先級任務占有,而這個低優先級任務在訪問共享資源時可能又被其它一些中等優先級的任務搶先,因此造成高優先級任務被許多具有較低優先級的任務阻塞,實時性難以得到保證。因此在實時操作系統中,往往對傳統的信號量機制進行了一些擴展,引入了如優先級繼承協議(PriorityInheritanceProtocol)、優先級頂置協議(PriorityCeilingProtocol)以及StackResourcePolicy等機制,較好地解決了優先級倒置的問題。

(5) 系統調用以及系統內部操作的時間開銷:

進程通過系統調用得到操作系統提供的服務,操作系統通過內部操作(如上下文切換等)來完成一些內部管理工作。為保證系統的可預測性,實時操作系統中的所有系統調用以及系統內部操作的時間開銷都應是有界的,并且該界限是一個具體的量化數值。而在通用操作系統中對這些時間開銷則未做如此限制。

(6) 系統的可重入性:

在通用操作系統中,核心態系統調用往往是不可重入的,當一低優先級任務調用核心態系統調用時,在該時間段內到達的高優先級任務必須等到低優先級的系統調用完成才能獲得CPU,這就降低了系統的可預測性。因此,實時操作系統中的核心態系統調用往往設計為可重入的。

(7) 輔助工具:

實時操作系統額外提供了一些輔助工具,如實時任務在最壞情況下的執行時間估算工具、系統的實時性驗證工具等,可幫助工程師進行系統的實時性驗證工作。此外,實時操作系統對系統硬件設計也提出了一些要求,其中一些要求為:(1) DMADMA是一種數據交換協議,主要作用是在無需CPU參與的情況下將數據在內存與其它外部設備間進行交換。DMA最常用的一種實現方式被稱為周期竊取(CycleStealing)方式,即首先通過總線仲裁協議與CPU競爭總線控制權,在獲得控制權后再根據用戶預設的操作指令進行數據交換。由于這種周期竊取方式會給用戶任務帶來不可預測的額外阻塞開銷,所以實時操作系統往往要求系統設計時不采用DMA或采取一些可預測性更好的DMA實現方式,如Time-slicemethod等。(2)CacheCache的主要作用是采用容量相對較小的快速存儲部件來彌補高性能CPU與相對來說性能較低的存儲器之間的性能差異,由于它可以使系統的平均表現性能得到大幅提高,因此在硬件設計中得到了極為廣泛的應用。但實時操作系統注重的不是平均表現性能,而是個體最壞情況表現,因此在對系統進行實時性驗證時必須考慮實時任務運行的最壞情況,即每次訪存都沒有命中Cache情況下的運行時間,所以在利用輔助工具估算實時任務在最壞情況下的執行時間時,應將系統中所有的Cache功能暫時關閉,在系統實際運行時再將Cache功能激活。除此以外,另一種較極端的做法則是在硬件設計中完全不采用Cache技術。

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

    關注

    5092

    文章

    19177

    瀏覽量

    307682
  • RTOS
    +關注

    關注

    22

    文章

    819

    瀏覽量

    119888
  • 嵌入式實時操作系統

    關注

    1

    文章

    127

    瀏覽量

    7872

原文標題:都叫操作系統 RTOS和PC上的到底有啥不同?

文章出處:【微信號:weixin21ic,微信公眾號:21ic電子網】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    【安富萊】【RTX操作系統教程】第2章 嵌入式實時操作系統介紹

    一樣都是出自Segger公司。2.1.4STM32嵌入式實時操作系統解決方案 ST公司有一個手冊是專門講嵌入式解決方案的,這里就把RTOS
    發表于 01-15 15:35

    嵌入式操作系統的FreeRTOS操作系統分析

    嵌入式領域中,嵌入式實時操作系統正得到越來越廣泛的應用。采用嵌入式實時
    發表于 07-01 08:19

    嵌入式實時操作系統Small RTOS51怎么樣?

    ,重點介紹了適合于小RAM單片機的嵌入式實時操作系統Small RTOS51,以及基于8位單片機的硬件和軟件的設計方法和過程。
    發表于 11-07 07:42

    嵌入式實時操作系統如何簡化應用軟件的設計

    嵌入式領域中,嵌入式實時操作系統RTOS)正得到越來越廣泛的應用。采用嵌入式
    發表于 11-25 06:48

    嵌入式實時操作系統RTOS

    前言自20世紀90年代,鑒于多任務支持、開發便捷、便于維護等特性,同時能夠提高系統的穩定性和可靠性,嵌入式實時操作系統RTOS)逐漸為廣大
    發表于 08-05 06:14

    怎樣去更好地使用嵌入式實時操作系統RTOS

    為什么嵌入式實時操作系統RTOS會被廣泛使用?怎樣去更好地使用嵌入式實時
    發表于 11-02 06:41

    嵌入式實時操作系統rtems的特點是什么

    嵌入式實時操作系統rtems的特點及研究現狀RTEMS簡介1RTEMS是一個開源的無版稅實時嵌入操作系統
    發表于 12-14 07:12

    嵌入式實時操作系統FreeRTOS基本概述

    嵌入式實時操作系統FreeRTOS基本概述在嵌入式領域當中,實時操作系統的應用越來越廣泛了,目前
    發表于 02-16 07:12

    嵌入式實時操作系統教程

    嵌入式實時操作系統教程:以VRTX為對象詳細介紹了嵌入式實時操作系統的原理和應用,特別是第一部分
    發表于 04-19 21:55 ?44次下載
    <b class='flag-5'>嵌入式</b><b class='flag-5'>實時</b><b class='flag-5'>操作系統</b>教程

    嵌入式實時操作系統設計方案

    本文提出了一種航空電子嵌入式實時操作系統(A-RTOS,Avionics RTOS)的一種設計思路,并在具有MMU和支持高級保護模式的目標板
    發表于 11-21 11:43 ?1195次閱讀
    <b class='flag-5'>嵌入式</b><b class='flag-5'>實時</b><b class='flag-5'>操作系統</b>設計方案

    不同的實時嵌入式Linux操作系統有什么差異

    嵌入式實時操作系統(Embedded Real-time Operation System,RTOS)。嵌入式
    發表于 11-06 11:36 ?1329次閱讀

    嵌入式實時操作系統FreeRTOS在ARM7移植實現

    嵌入式實時操作系統FreeRTOS在ARM7移植實現(嵌入式開發工程師待遇)-嵌入式
    發表于 07-30 12:05 ?21次下載
    <b class='flag-5'>嵌入式</b><b class='flag-5'>實時</b><b class='flag-5'>操作系統</b>FreeRTOS在ARM7<b class='flag-5'>上</b>移植實現

    詳解目前主流的嵌入式操作系統RTOS操作系統

    滿足實時控制要求的嵌入式操作系統RTOS操作系統,以下介紹14種主流的RTOS,分別為μCl
    發表于 10-20 12:36 ?16次下載
    詳解目前主流的<b class='flag-5'>嵌入式</b><b class='flag-5'>操作系統</b>(<b class='flag-5'>RTOS</b>)<b class='flag-5'>操作系統</b>

    嵌入式實時操作系統

    14 種主流的嵌入式實時操作系統 RTOS,分別為μClinux、μC/OS-II、eCos、FreeRTOS、mbed OS、RTX、Vxworks、QNX、NuttX,而國產的
    發表于 10-20 14:05 ?17次下載
    <b class='flag-5'>嵌入式</b><b class='flag-5'>實時</b><b class='flag-5'>操作系統</b>

    再談嵌入式實時操作系統

    等領域。嵌入式實時操作系統RTOS)構造簡單、功能齊全、便于使用,特別適合各類應用場景,因此它在軟件應用程序開發中發揮著重要的作用,使嵌入式
    的頭像 發表于 04-09 17:27 ?856次閱讀
    再談<b class='flag-5'>嵌入式</b><b class='flag-5'>實時</b><b class='flag-5'>操作系統</b>
    冠通棋牌大厅下载| 迪威百家乐现场| 南涧| 迷你百家乐的玩法技巧和规则| 百家乐官网走势图解| 皇冠现金投注网| 百家乐群html| 现场百家乐官网玩法| 易胜博娱乐| 百家乐屏风| 新东方百家乐官网的玩法技巧和规则| 滕州市| 幸运水果机游戏下载| 澳门百家乐赢钱秘诀| 现金百家乐官网技巧| 六合彩 开奖| 百家乐奥| 百家乐官网官网网址| 百家乐官网视频二人雀神| 娱乐城送钱| 百家乐规| 百家乐客户端下载| 百家乐官网ag厅投注限额| 六合彩网站| 百家乐开户| 最好的百家乐好评平台都有哪些| 百家乐官网这样赢保单分析| 鹤岗市| 大发888官方lc8| 真人百家乐做假| 362百家乐官网的玩法技巧和规则| 百家乐官网视频软件| 大发88817| 百家乐娱乐城地址| 东营区百家乐官网艺术团| 方城县| 德州扑克 技巧| 去澳门百家乐的玩法技巧和规则| 网络百家乐的陷阱| 百家乐官网路书| 百家乐官网必胜课|