<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>

新聞中心

EEPW首頁(yè) > 嵌入式系統 > 設計應用 > 嵌入式Linux系統中內核抽象的動(dòng)態(tài)擴展技術(shù)簡(jiǎn)介

嵌入式Linux系統中內核抽象的動(dòng)態(tài)擴展技術(shù)簡(jiǎn)介

作者: 時(shí)間:2012-08-16 來(lái)源:網(wǎng)絡(luò ) 收藏

由于其工作環(huán)境、位置分布、與應用的結合方式等方面的原因,在的升級、修改方面存在著(zhù)相當的困難,且費用高。目前大多數系統只能在一定程度上進(jìn)行靜態(tài),這意味著(zhù)修改某些屬性值后要重新編譯,對普通用戶(hù)而言難以實(shí)現。通信的發(fā)展使得操作系統的成為可能,可以在遠程控制的基礎上增加嵌入式系統的靈活性,延長(cháng)嵌入式系統的壽命;同時(shí),由于嵌入式的應用日益廣泛,研究嵌入式具有重要意義。

擴展是指系統在運行狀態(tài)下實(shí)現系統的升級和維護。動(dòng)態(tài)擴展目前被廣泛應用在軟件系統開(kāi)發(fā)的各個(gè)領(lǐng)域。組件、可擴展的數據庫系統、主動(dòng)網(wǎng)等多種都是動(dòng)態(tài)擴展在各個(gè)領(lǐng)域的具體體現。在嵌入式操作系統領(lǐng)域,動(dòng)態(tài)擴展技術(shù)研究的主要目標是實(shí)現內核的擴展。實(shí)現操作系統內核的動(dòng)態(tài)擴展能夠提高系統的靈活性、適應性,使系統能夠根據應用的需求,提供特定的服務(wù)。然而,由于嵌入式系統硬件資源有限,這對研究嵌入式系統核心的動(dòng)態(tài)擴展性是一個(gè)極大的挑戰。

本文主要討論嵌入式Linux系統中內核的動(dòng)態(tài)擴展技術(shù)。

1、幾種主要的內核動(dòng)態(tài)擴展技術(shù)的分析

當前應用于操作系統中的動(dòng)態(tài)擴展技術(shù)主要有四種:微內核技術(shù)、可擴展內核技術(shù)、解釋器技術(shù)/JOS技術(shù)和內核下載技術(shù)/LKM技術(shù)[1,2]。 這三種技術(shù)已經(jīng)在桌面操作系統的不同環(huán)境中得到了充分的應用。嵌入式操作系統及其使用環(huán)境具有桌面操作系統所不同的特征,它在性能、地址空間、所需存儲空間和底層訪(fǎng)問(wèn)頻率等方面的特征,使得我們在擴展技術(shù)的選擇上需要加以權衡。

(1) 微內核技術(shù)

在微內核操作系統中,內核中包括了一些基本內核功能(如創(chuàng )建和刪除任務(wù)、任務(wù)調度、內存管理和中斷處理等),部分操作系統抽象和關(guān)鍵服務(wù)(如文件系統、網(wǎng)絡(luò )協(xié)議棧等),都是在用戶(hù)空間運行的。這大大減小了內核的體積,同時(shí)也極大地方便了整個(gè)系統的升級、維護和移植。系統通過(guò)核心到用戶(hù)層向上調用服務(wù)的方法來(lái)為應用程序提供服務(wù)。由于服務(wù)存在于用戶(hù)層,用戶(hù)可通過(guò)修改服務(wù)來(lái)獲得不同的行為,因而也稱(chēng)為用戶(hù)層擴展技術(shù)。由于所有的應用程序都要利用操作系統提供的API或系統調用,完成內存管理、進(jìn)程管理、I/O、設備管理等,因此通過(guò)在用戶(hù)空間監視并截獲某個(gè)進(jìn)程的系統調用,然后將擴展功能代碼插入系統調用中,就可以擴展Linux操作系統功能。

與內核空間功能擴展相比,在用戶(hù)空間擴展安全性更強,對Linux操作系統和應用程序更加透明。用戶(hù)層擴展技術(shù)的缺點(diǎn)在于,將服務(wù)提升到用戶(hù)層使程序運行過(guò)程中核心態(tài)和用戶(hù)態(tài)之間的切換和自陷次數增加,導致系統負載增加,系統性能下降。另外,微內核與傳統的嵌入式Linux內核在結構上是完全不同的。在嵌入式Linux中,如果采用該技術(shù)來(lái)增加系統的動(dòng)態(tài)擴展性能,需要對內核結構重新設計。

(2) 可擴展內核技術(shù)

可擴展內核技術(shù)允許用戶(hù)應用程序向內核植入(inject)代碼以擴展其功能。由于被植入的代碼是在核心態(tài)運行,從而避免了微內核技術(shù)中的系統性能下降的問(wèn)題。被植入的代碼是在核心態(tài)運行,需要有一個(gè)實(shí)時(shí)檢查機制來(lái)驗證代碼的安全性,保證被植入代碼不會(huì )導致系統的崩潰。程步奇等人使用軟件故障孤立技術(shù)來(lái)實(shí)現擴展模塊的故障孤立,保證系統不受到擴展模塊的破壞。 Bershad等人也使用軟件故障孤立技術(shù)來(lái)限制被植入代碼可訪(fǎng)問(wèn)的內存地址范圍。代碼安全性檢查無(wú)疑增加了系統的負擔,問(wèn)題產(chǎn)生的根本原因是那些被植入的擴展性代碼對核心來(lái)說(shuō)是不可信任的。為了減輕系統的負擔,就需要假設被植入的代碼是安全的、可信任的。

(3) 解釋器技術(shù)/JOS技術(shù)

與文獻中提到的JOS(Java Operating System)技術(shù)相同,該技術(shù)允許開(kāi)發(fā)者用Java語(yǔ)言編寫(xiě)系統模塊,例如TCP/IP協(xié)議?;蛭募到y。將這些模塊編譯成類(lèi)(class)文件,并在系統運行時(shí)由JVM(Java Virtual Machine)動(dòng)態(tài)地加載。Liao等人在1996年提出,將JVM插入到微內核中,從而可以讓用戶(hù)編寫(xiě)Java程序,以擴展內核功能。

解釋器技術(shù)是以解釋的方式來(lái)執行程序代碼的,比較適合于交互式系統;與編譯器相比,解釋器/JVM在移植時(shí)相對簡(jiǎn)單;解釋器通過(guò)采用中間代碼表示的方法,當代碼長(cháng)度小于500 KB的時(shí)候,可執行的中間代碼通常比編譯產(chǎn)生的二進(jìn)制代碼小,這一點(diǎn)很適合于存儲空間非常有限的嵌入式系統;最后,Java代碼容易維護和編寫(xiě),可移植性好,可實(shí)現代碼重用。采用解釋器技術(shù)的缺點(diǎn)是,中間可執行代碼的執行速度慢。在嵌入式Linux系統中,內核很大一部分由應用所共享,甚至應用程序本身就是內核的一個(gè)線(xiàn)程,執行頻率高,采用解釋器技術(shù)會(huì )大大降低系統的效率。有些Java平臺采用即時(shí)(Just in time)編譯技術(shù)來(lái)改進(jìn)代碼的執行速度。該技術(shù)是利用空間來(lái)?yè)Q取時(shí)間,因此很難在硬件資源非常有限的嵌入式系統上實(shí)現。此外,由于Java語(yǔ)言的類(lèi)庫很大,在一定程度上也阻礙了其在資源有限的嵌入式系統中的發(fā)展。

(4) 內核加載技術(shù)/LKM技術(shù)

許多桌面操作系統,例如Linux,提供LKM(Loadable Kernel Module)來(lái)動(dòng)態(tài)擴展它們的內核。當模塊(Module)安裝到內核后就作為核心的一部分,不進(jìn)行實(shí)時(shí)安全檢測,全速運行。在嵌入式Linux系統中,LKM的主要問(wèn)題是:存儲模塊需要占用額外空間以及被加載模塊的安全性。模塊的安全問(wèn)題可以通過(guò)軟件保護技術(shù)來(lái)解決。

Oikawa等人在1996年提出一種與LKM類(lèi)似的動(dòng)態(tài)核心模塊(DKMs)技術(shù)。與LKM一樣,DKMs以文件的形式存儲并能在系統運行過(guò)程中動(dòng)態(tài)地加載和卸載。DKMs由一個(gè)用戶(hù)層的DKM服務(wù)器來(lái)管理,并非由內核來(lái)管理。當核心需要某模塊時(shí),由DKM服務(wù)器負責把相應的DKM加載;當核心的內存資源緊缺時(shí),由DKM服務(wù)器負責卸載一個(gè)沒(méi)有被使用的DKM。缺點(diǎn)是所有的DKM是存儲在本地系統上的,占用了大量寶貴的存儲空間。

與Oikawa的方法不同,Chang DaWei 等人于2003年提出了OperatingSystemPortal framework(OSP)的方法。該方法是將核心模塊存儲在一個(gè)資源充足的遠程服務(wù)器上,并由服務(wù)器端工具OS Portal來(lái)管理所存儲的模塊,同時(shí)也負責處理客戶(hù)端(嵌入式系統內核)發(fā)出的請求,按照請求動(dòng)態(tài)的選擇并連接模塊,然后通過(guò)網(wǎng)絡(luò )傳到客戶(hù)端。由于模塊的管理和連接都在服務(wù)器端,所以對客戶(hù)端來(lái)說(shuō)可以節省大量的資源空間。OS Portal的結構如圖1所示。

本文引用地址:http://dyxdggzs.com/article/148582.htm

OS Portal的結構 www.elecfans.com



圖1 OS Portal的結構圖

linux操作系統文章專(zhuān)題:linux操作系統詳解(linux不再難懂)

上一頁(yè) 1 2 下一頁(yè)

評論


相關(guān)推薦

技術(shù)專(zhuān)區

關(guān)閉
国产精品自在自线亚洲|国产精品无圣光一区二区|国产日产欧洲无码视频|久久久一本精品99久久K精品66|欧美人与动牲交片免费播放
<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>