《電子技術應用》
您所在的位置:首頁 > 嵌入式技術 > 設計應用 > 嵌入式Linux實時性能提高方案
嵌入式Linux實時性能提高方案
摘要:  Linux作為一個通用操作系統,主要考慮的是調度的公平性和吞吐量等指標。然而,在實時方面它還不能很好地滿足實時系統方面的需要,其本身僅僅提供了一些實時處理的支持,這包括支持大部分POSIX標準中的實時功能,支持多任務、多線程,具有豐富的通信機制等;同時也提供了符合POSIX標準的調度策略,包括FIFO調度策略、時間片輪轉調度策略和靜態優先級搶占式調度策略。Linux區分實時進程和普通進程,并采用不同的調度策略。
Abstract:
Key words :

1 引言

  分析了Linux的實時性,針對其在實時應用中的技術障礙,在參考了與此相關研究基礎上,從三方面提出了改善Linux實時性能的改進措施。為提高嵌入式應用響應時間精度,提出兩種細化Linux時鐘粒度方法;為增強系統內核對實時任務的響應能力,采用插入搶占點和修改內核法增強Linux內核的可搶占性;為保證硬實時任務的時限要求,把原Linux的單運行隊列改為雙運行隊列,硬實時任務單獨被放在一個隊列中,并采用MLF調度算法代替原內核的FIFO" title="FIFO">FIFO調度算法。本文分析了標準Linux在實時應用中的技術障礙,參考了修改核方法的思想,從內核時鐘管理、內核的搶占性、內核調度算法三方面論述了改善標準Linux實時性能的方法。

  2 Linux 在實時應用中的技術障礙

  2.1 Linux的實時性分析

  Linux作為一個通用操作系統,主要考慮的是調度的公平性和吞吐量等指標。然而,在實時方面它還不能很好地滿足實時系統方面的需要,其本身僅僅提供了一些實時處理的支持,這包括支持大部分POSIX標準中的實時功能,支持多任務、多線程,具有豐富的通信機制等;同時也提供了符合POSIX標準的調度策略,包括FIFO調度策略、時間片輪轉調度策略和靜態優先級搶占式調度策略。Linux區分實時進程和普通進程,并采用不同的調度策略。

  為了同時支持實時和非實時兩種進程,Linux的調度策略簡單講就是優先級加上時間片。當系統中有實時進程到來時,系統賦予它最高的優先級。體現在實時性上,Linux采用了兩種簡單的調度策略,即先來先服務調度(SCHED-FIFO)和時間片輪轉調度(SCHED-RR)。具體是將所有處于運行狀態的任務掛接在一個run-queue 隊列中,并將任務分成實時和非實時任務,對不同的任務,在其任務控制塊task-struct中用一個policy屬性來確定其調度策略。對實時性要求較嚴的硬實時任務采用SCHED-FIFO調度,使之在一次調度后運行完畢。對普通非實時進程,Linux采用基于優先級的輪轉策略。

  2.2 Linux在實時應用中的技術障礙

  盡管Linux本身提供了一些支持實時性的機制,然而,由于Linux系統是以高的吞吐量和公平性為追求目標,基本上沒有考慮實時應用所要滿足的時間約束,它只是提供了一些相對簡單的任務調度策略。因此,實時性問題是將Linux應用于嵌入式系統開發的一大障礙,無法在硬實時系統中得到應用。 Linux在實時應用中的技術障礙具體表現在:

  (1)Linux系統時鐘精度太過粗糙,時鐘中斷周期為10ms,使得其時間粒度過大,加大了任務響應延遲。

  (2) Linux的內核是不可搶占的, 當一個任務通過系統調用進入內核態運行時,一個具有更高優先級的進程,只有等待處于核心態的系統調用返回后方能執行,這將導致優先級逆轉。實時任務執行時間的不確定性,顯然不能滿足硬實時應用的要求。

  (3) Linux采用對臨界區操作時屏蔽中斷的方式,在中斷處理中是不允許進行任務調度的,從而抑制了系統及時響應外部操作的能力。

  (4) 缺乏有效的實時任務調度機制和調度算法。

  針對這些問題,利用Linux作為底層操作系統,必須增強其內核的實時性能,從而構建出一個具有實時處理能力的嵌入式系統,適應嵌入式領域應用的需要。2.3 當前增強Linux內核實時性的主流技術

 

  近年來,人們對于Linux內核實時性改造提出了一些方法和設想,它們采用了不同的思路和技術方案。歸納總結,支持Linux的硬實時性一般有兩種策略[5]:一種是直接修改Linux內核,重新編寫一個由優先級驅動的實時調度器(Real-time Scheduler),替換原有內核中的進程調度器sched.c,KURT是采用這一方案較為成功的實時Linux操作系統;另外一種是在Linux內核之外, 以可加載內核模塊(Loadable Kernel Module)的形式添加實時內核,確保其高響應特性,實時內核接管來自硬件的所有中斷,并依據是否是實時任務決定是否直接響應。新墨西哥科技大學的 RT-Linux,就是基于這種策略而開發的。以上兩種策略有其借鑒之處,但如果綜合考慮任務響應、內核搶占性、實時調度策略等幾個影響操作系統實時性能的重要方面,它們還不能很好的滿足實時性問題。為了增強嵌入式Linux" title="嵌入式Linux">嵌入式Linux實時性能,下文將就內核時鐘精度、內核的搶占性以及內核調度算法等相關問題重點研究相應的解決方法。

  3 改善嵌入式Linux實時性能的方法

  針對Linux在實時應用中的技術障礙,將Linux改造成為支持實時任務的嵌入式操作系統, 主要從下面三個方面進行著手。

  3.1細化時鐘粒度

  精確的計時是實時調度器正確操作所必須的,調度器通常要求在一個特定的時刻進行任務切換,計時的錯誤將導致背離計劃的調度,引起任務釋放抖動。標準 Linux系統時鐘精度太過粗糙,時鐘中斷周期為10ms,不能滿足特定嵌入式應用領域中對于響應時間精度的要求。因此,在實時Linux應用中,需要細化其時鐘粒度,具體有兩種方式可以解決時鐘粒度問題:一是通過直接修改內核定時參數HZ的初值來細化時鐘粒度,如將標準Linux中內核定時參數HZ改為10000, 則時鐘粒度可以達到100us,這種方式雖然會增加一些系統開銷,但在強周期性環境下,對定時器的設置只需初始化一次,在一定程度上保證了處理效率;二是通過對可編程中斷定時器8254或先進的可編程中斷控制器進行編程來改進Linux時鐘機制,以提高其時鐘的分辨率,使毫秒級的粗粒度定時器變成微秒級的細粒度定時器。

  3.2 增強Linux內核的搶占性

  標準Linux內核是不可搶占的,導致較大的延遲,增強內核的可搶占性能,可提高系統內核對實時任務的響應能力。目前,有兩種方法修改Linux內核以提高實時任務搶占非實時任務的能力:一是在內核中增加搶占點的方法;二是直接將Linux內核改造成可搶占式內核。插入搶占點方法是在Linux內核中插入一些搶占點,當一個系統調用執行到搶占點時,如果有更高優先級的實時進程正在等待運行,那么正在執行系統調用的內核進程將會把CPU的控制權轉交給等待運行的實時進程;如果沒有更高優先級的實時進程等待,則當前進程將繼續執行,此時系統增加的開銷僅僅是檢測一下調度標志。將Linux內核改造成可搶占式內核方法的基本思想是產生運行調度器的機會,縮短任務發生到調度函數運行的時間間隔。這種方法修改了Linux源代碼中的自旋鎖宏以避免競爭,并在其中引入一個稱作搶占鎖計數器(PLC)的新的計數信號允許內核代碼搶占,當它為0時,允許搶占;當其為大于0的任何值時,禁止搶占。目前,針對這兩種修改 Linux內核的方法,已經有兩種比較成熟的Linux內核補丁被研制出來:搶占式補丁和低時延補丁。其中,搶占式補丁是Monta Vista開發的,它修改了內核代碼中的spinlock宏和中斷返回代碼,使得當前進程可被安全搶占,當自旋鎖釋放或者中斷線程完成時,調度器就有機會執行調度;低時延補丁是由Ingo Malnor提出,該方法只是在執行時間長的代碼塊上搶占,不采用強制式搶占,因此,如何找到延時長的代碼塊是解決問題的關鍵。

  3.3 改善Linux內核實時調度器的調度策略

  將進入系統的所有任務按實時性分成三類:硬實時、軟實時、非實時任務[6]。硬實時要求系統確保任務執行最壞情況下的執行時間,即必須滿足實時事件的響應時間的截止期限,否則,將引發致命的錯誤;軟實時是指統計意義上的實時,一般整體吞吐量大或整體響應速度快,但不能保證特定任務在指定時期內完成。針對不同的實時性任務,分別采用不同的調度方法進行處理。

  為了嚴格保證硬實時任務的時限要求,改善的Linux內核實時調度器采用了優先級調度算法,目前最小松弛時間優先調度算法MLF(Minimum- Laxity-First Scheduling Algorithm)是動態優先級調度最常見的實時調度策略。它在系統中為每一個任務設定松弛時間(任務的松弛時間等于任務的截止期減去任務執行時間、當前時間)即: laxity= deadline―current_time―CPU_time_needed,系統優先執行具有最小松弛時間的任務。根據就緒隊列的各任務的松弛時間來分配優先級,松弛時間最小的任務具有最高的優先級。為了提高Linux的實時性,我們設計了MLF調度器,并把它作為可加載模塊加入Linux內核中,在實現中需對內核進行相應的修改。為了區分任務的類型,對基本Linux的task_struct屬性進行改進,在其中增加SCHED_MLF調度策略,并按task_struct中的policy的取值來進行區分, 分別用SCHED_MLF,SCHED_RR,SCHED_OTHER來標識硬實時、軟實時、非實時任務。將處于運行狀態的三類任務放入兩個隊列,硬實時任務放入hard_real_queue隊列, 采用MLF調度算法,軟實時和非實時任務放入non_real_queue隊列(空閑任務也在其中),沿用原內核的RR調度算法。這兩個隊列可以用一個 run_queue[2]的指針數組來指向,如圖1 所示。

  

 

  圖1 雙對列任務運行

  雙隊列任務運行過程與原內核的單運行隊列執行流程的主要區別在:首先,各硬實時任務采用了MLF調度算法代替原內核的FIFO調度,提高了 Linux系統的實時性能。其次,在判斷是否有軟中斷需要處理之前需判斷硬實時任務隊列是否為空,如果不為空,即使存在中斷的后半部分需要處理,也要先調度硬實時任務投入運行,在硬實時隊列為空的條件下才去處理中斷的后半部分(因為中斷的后半部分沒有硬實時任務緊急)。最后,如果沒有硬實時任務存在,則說明只有run_queue [1]隊列中有軟實時或非實時任務存在,這時的處理方法和原內核對單運行隊列的處理方法相同。這樣改進后,可以明顯提高硬實時任務的調度效率,而在沒有硬實時任務時,系統性能沒有變化。

  4 結束語

  本文在分析Linux實時性的同時,探討了其本身提供的一些支持實時性的機制以及在實時應用中的技術障礙。而后,基于增強Linux內核實時性的主流技術,從細化時鐘粒度、增強內核搶占性及實時調度策略三方面入手,提出了改善Linux實時性能的優化方法。

此內容為AET網站原創,未經授權禁止轉載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
嫩草国产精品入口| 国产精品日韩在线一区| 亚洲欧美日韩天堂一区二区| 99精品国产高清一区二区| 亚洲二区在线| 亚洲国产日韩在线| 91久久国产自产拍夜夜嗨| 久久成人精品视频| 久久精品视频免费观看| 亚洲福利视频专区| 亚洲经典在线看| 亚洲另类黄色| 一卡二卡3卡四卡高清精品视频| 亚洲精品在线视频| 99这里有精品| 亚洲午夜视频在线| 香蕉久久国产| 久久人人97超碰人人澡爱香蕉| 久久一本综合频道| 欧美国产三级| 欧美色图麻豆| 国产精品一区二区三区乱码| 国产亚洲欧美日韩一区二区| 国产一区二区三区黄视频| 国产综合精品一区| 亚洲二区在线| 99这里只有精品| 亚洲欧美另类国产| 亚洲丶国产丶欧美一区二区三区| 亚洲激情成人在线| 中文日韩在线| 欧美呦呦网站| 欧美成年视频| 欧美亚男人的天堂| 国产一区二区三区观看| 亚洲成色精品| 99精品视频一区二区三区| 亚洲欧美www| 亚洲盗摄视频| 一区二区三区精品| 亚洲欧美综合| 久久久久综合| 欧美日韩国产在线播放网站| 国产精品久久中文| 激情成人av| 99精品国产在热久久| 午夜国产精品视频免费体验区| 久久精品视频播放| 亚洲天堂av在线免费观看| 久久av二区| 欧美金8天国| 国产日韩成人精品| 亚洲精品极品| 欧美一区二区三区视频在线观看 | 亚洲午夜视频在线观看| 欧美在线观看视频在线| 99成人在线| 久久久999精品| 欧美日韩精品在线播放| 国产亚洲一区在线播放| 亚洲精品国产视频| 欧美在线一级va免费观看| 一本到12不卡视频在线dvd| 久久av二区| 欧美日韩一区二区欧美激情 | 久久精品中文| 国产精品igao视频网网址不卡日韩| 国内精品久久久久伊人av| 99精品久久久| 亚洲国产精品一区二区三区| 亚洲欧美bt| 欧美电影在线免费观看网站| 国产欧美一区二区三区在线看蜜臀| 亚洲日本激情| 久久精品亚洲精品| 午夜亚洲福利| 欧美日韩一区三区四区| 雨宫琴音一区二区在线| 亚洲一级片在线观看| 99视频在线精品国自产拍免费观看 | 中日韩男男gay无套 | 久久久久久久久蜜桃| 欧美先锋影音| 亚洲欧洲综合另类在线| 亚洲国产成人av| 久久精品人人做人人爽| 国产精品护士白丝一区av| 亚洲精品国产无天堂网2021| 亚洲国产综合在线| 久久蜜桃香蕉精品一区二区三区| 国产精品久久综合| 一区二区三区**美女毛片| aa级大片欧美三级| 欧美国产视频日韩| 亚洲电影免费| 亚洲高清视频一区| 久久久久久网站| 国产亚洲福利| 午夜欧美不卡精品aaaaa| 篠田优中文在线播放第一区| 国产精品久久久久久久久借妻| 亚洲三级免费观看| 亚洲另类黄色| 欧美激情亚洲| 亚洲激情视频在线| 亚洲三级毛片| 欧美国产日韩一区| 亚洲黄色一区| 日韩午夜黄色| 欧美区二区三区| 亚洲理伦电影| 在线中文字幕不卡| 欧美色大人视频| 夜夜精品视频| 亚洲欧美日韩国产中文| 国产精品福利在线观看| 亚洲一区二区三区四区中文 | 亚洲一区综合| 国产精品高潮视频| 亚洲综合色婷婷| 久久精品国产清高在天天线| 国产欧美日韩一区二区三区在线观看 | 亚洲影视综合| 久久精品国产精品亚洲精品| 国产综合色产| 亚洲精品国产精品乱码不99按摩| 欧美激情五月| 一本色道久久综合亚洲精品不| 亚洲午夜小视频| 国产精品一区二区三区免费观看| 香港成人在线视频| 老司机午夜免费精品视频| 亚洲国产精品嫩草影院| 亚洲深爱激情| 国产精品永久免费在线| 久久er精品视频| 欧美国产日本在线| 一区二区不卡在线视频 午夜欧美不卡'| 亚洲专区在线| 国产日韩欧美一区在线| 亚洲国产精品久久| 欧美日韩成人一区二区| 亚洲视频一二区| 久久久精品日韩欧美| 亚洲国产成人久久综合| 中文久久精品| 国产日韩在线亚洲字幕中文| 亚洲国产乱码最新视频| 欧美日韩美女在线观看| 亚洲一区二区三区四区五区黄| 久久久精品2019中文字幕神马| 在线免费不卡视频| 亚洲一区日韩在线| 国产视频欧美视频| 亚洲老司机av| 国产女人精品视频| 亚洲三级免费| 国产精品普通话对白| 亚洲激情国产| 国产精品久久久久久久久久尿 | 免费观看国产成人| 中文在线一区| 久久久免费av| 99国产麻豆精品| 久久久午夜精品| 一本到12不卡视频在线dvd| 欧美综合二区| 亚洲美女91| 久久全球大尺度高清视频| 日韩亚洲一区二区| 久久免费国产精品1| 日韩一级不卡| 久久网站免费| 亚洲一区免费网站| 欧美激情五月| 欧美影院午夜播放| 欧美特黄一级| 亚洲经典在线| 国产日韩精品久久| 中文高清一区| …久久精品99久久香蕉国产| 先锋影音国产一区| 亚洲精品久久久久久下一站| 久久久精品视频成人| 一区二区欧美在线观看| 欧美 日韩 国产精品免费观看| 亚洲欧美美女| 国产精品www994| 亚洲精品视频一区二区三区| 国产日韩欧美一区在线| 亚洲视频一起| 91久久国产综合久久蜜月精品 | 99re在线精品| 一区二区三区在线免费视频| 亚洲欧美日韩直播| 日韩天天综合| 欧美激情精品久久久| 久久国产一区二区| 国产精品午夜视频| 亚洲一区二区三区高清不卡|