- 相關(guān)推薦
組件機(jī)制與操作系統(tǒng)的實(shí)現(xiàn)
摘要 本文介紹了一個(gè)操作系統(tǒng)開(kāi)發(fā)平臺(tái)-OSKit,它提供了一套用于架構(gòu)操作系統(tǒng)內(nèi)核的庫(kù)函數(shù)和一些組件。它的設(shè)計(jì)目標(biāo)是降低進(jìn)入操作系統(tǒng)研究與開(kāi)發(fā)領(lǐng)域的門檻。OSKit在設(shè)計(jì)時(shí)借用了COM的思想,把操作系統(tǒng)的各個(gè)部分設(shè)計(jì)成盡量獨(dú)立的組件,使開(kāi)發(fā)者可以很方便地使用或替換這些組件來(lái)構(gòu)造自己的操作系統(tǒng)。
關(guān)鍵字 組件 重用 操作系統(tǒng) OSKit
1 引言
當(dāng)前,操作系統(tǒng)的功能不斷擴(kuò)展,操作系統(tǒng)的類型呈現(xiàn)出多樣化的趨勢(shì)。一個(gè)小規(guī)模的開(kāi)發(fā)小組已經(jīng)不可能完全從頭開(kāi)始實(shí)現(xiàn)一個(gè)實(shí)用的操作系統(tǒng),而一般情況下,研究人員只對(duì)操作系統(tǒng)的一些特定領(lǐng)域感興趣,而對(duì)于另外一些元素,如啟動(dòng)加載代碼、核心啟動(dòng)代碼、設(shè)備驅(qū)動(dòng)程序和內(nèi)存分配代碼等往往不感興趣,但是一個(gè)可運(yùn)行的原型系統(tǒng)又必須包含這些內(nèi)容。編寫這些基礎(chǔ)結(jié)構(gòu)延緩了操作系統(tǒng)研究項(xiàng)目的進(jìn)度,同時(shí)也增加了進(jìn)行操作系統(tǒng)研究的代價(jià)。為了解決這一問(wèn)題,猶他大學(xué)的FLUX研究小組開(kāi)發(fā)了OSKit,它提供了一個(gè)框架和一組模塊化的、具有簡(jiǎn)單接口的庫(kù)以及一組清晰的、可重用的OS組件。OSKit可以用來(lái)構(gòu)建操作系統(tǒng)內(nèi)核、外層服務(wù)和其他核心OS功能模塊。OSKit提供了各種功能模塊,諸如簡(jiǎn)單自舉,一個(gè)可用于內(nèi)核的最小化POSIX環(huán)境、與物理內(nèi)存和其約束一致的內(nèi)存管理、廣泛的調(diào)試支持,以及高層子系統(tǒng)如協(xié)議棧和文件系統(tǒng)。開(kāi)發(fā)者可以根據(jù)自己的研究興趣或所要考慮的性能來(lái)使用這些模塊,或用他們自己的模塊來(lái)替代標(biāo)準(zhǔn)的OSKit模塊。
OSKit公開(kāi)了它內(nèi)部的實(shí)現(xiàn)細(xì)節(jié),允許用戶從成熟的操作系統(tǒng)中不加修改地提取代碼,然后通過(guò)一小部分經(jīng)過(guò)仔細(xì)設(shè)計(jì)的粘接代碼將它們合并到一起,隔離它們的依賴性,并輸出良好定義的接口。OSKit使用這一技術(shù)整合了許多穩(wěn)定而成熟的源代碼,包括設(shè)備驅(qū)動(dòng)、文件系統(tǒng)、網(wǎng)絡(luò)協(xié)議等等。實(shí)踐表明,使用組件軟件架構(gòu)和重用技術(shù)會(huì)給操作系統(tǒng)實(shí)現(xiàn)領(lǐng)域帶來(lái)大的影響。
2 組件技術(shù)簡(jiǎn)介
組件技術(shù)是一種較新的軟件開(kāi)發(fā)技術(shù)。到目前為止,還難以確定組件技術(shù)的明確定義。比如,對(duì)組件技術(shù)的常見(jiàn)說(shuō)法有以下這些:“二進(jìn)制軟件單元”、“任意場(chǎng)合可部署的軟件”、“特別適合第三方開(kāi)發(fā)”和“規(guī)范定義的接口”等等。大致上可以這樣理解:所謂組件,其實(shí)就是一種可部署軟件的代碼包,其中包括某些可執(zhí)行模塊。組件單獨(dú)開(kāi)發(fā)并作為軟件單元使用,它具有明確的接口,軟件就是通過(guò)這些接口調(diào)用組件所能提供的服務(wù),多種組件可以聯(lián)合起來(lái)構(gòu)成更大型的組件乃至直接建立整個(gè)系統(tǒng)。組件的實(shí)現(xiàn)必須支持一種或者多種其用戶所希望獲得的接口。實(shí)現(xiàn)組件并不一定需要采用面向?qū)ο笳Z(yǔ)言。為了構(gòu)造新應(yīng)用程序,軟件開(kāi)發(fā)人員找出適當(dāng)?shù)慕M件,將這些組件加入到正在開(kāi)發(fā)中的應(yīng)用程序,同時(shí)對(duì)應(yīng)用程序進(jìn)行測(cè)試并保證應(yīng)用程序的組裝工作按照預(yù)定的規(guī)劃正常進(jìn)行。采用組件技術(shù)能降低開(kāi)發(fā)、測(cè)試和維護(hù)成本,提高可靠性和穩(wěn)定性。
3 Oskit組件綜述
OSKIT的組件庫(kù)提供了一般情況下更高層的功能,它通常只對(duì)外開(kāi)放一些相關(guān)的公用調(diào)用接口。目標(biāo)系統(tǒng)通過(guò)OSKit的面向?qū)ο蟮腃OM接口來(lái)與這些組件進(jìn)行交互。以下幾節(jié)概述了OSKit所提供的組件。
3. 1 引導(dǎo)程序
大多數(shù)操作系統(tǒng)多有自身的啟動(dòng)加載機(jī)制,彼此互不兼容。這種加載機(jī)制的多樣性并不是由于每個(gè)OS所要求的自舉服務(wù)不同而引起,而是由于構(gòu)建啟動(dòng)加載器的特定方式造成的。因?yàn)閺牟僮飨到y(tǒng)研究的立場(chǎng)來(lái)看,啟動(dòng)加載器是一個(gè)令人不敢興趣的領(lǐng)域,因此OS開(kāi)發(fā)者通常進(jìn)行一個(gè)最小化、快捷的設(shè)計(jì)。由于設(shè)計(jì)理念和要求的輕微差別,每個(gè)啟動(dòng)加載器都不適用于下一個(gè)OS。為了解決這個(gè)問(wèn)題,OSKit直接支持多啟動(dòng)標(biāo)準(zhǔn),這一標(biāo)準(zhǔn)是由幾個(gè)OS項(xiàng)目的成員共同設(shè)計(jì)的,它的目的是提供一個(gè)簡(jiǎn)單而通用的啟動(dòng)加載器與OS內(nèi)核間的接口,從而允許一個(gè)啟動(dòng)加載器加載任何兼容的OS。
在進(jìn)行操作系統(tǒng)研究時(shí),多啟動(dòng)標(biāo)準(zhǔn)非常有用,這其中的主要原因是啟動(dòng)加載器在加載內(nèi)核自身的同時(shí)還具有加載附加文件或者啟動(dòng)模塊的能力。這里的一個(gè)啟動(dòng)模塊只是一個(gè)普通文件,啟動(dòng)加載器不以任何方式解釋它,而僅僅把它隨同內(nèi)核映像一起加載到保留物理內(nèi)存塊中。在啟動(dòng)內(nèi)核時(shí),啟動(dòng)加載器提供給內(nèi)核以下內(nèi)容:物理地址的列表、所有已加載的啟動(dòng)模塊的大小,以及與每個(gè)模塊相聯(lián)系的由用戶定義的字符串。這些啟動(dòng)模塊和與它們相聯(lián)系的用戶定義的字符串由內(nèi)核解釋。這樣做的目的是為了通過(guò)提供內(nèi)核啟動(dòng)時(shí)需要的數(shù)據(jù),諸如初始化程序、設(shè)備驅(qū)動(dòng)和文件系統(tǒng)服務(wù)器,來(lái)減輕內(nèi)核啟動(dòng)的負(fù)擔(dān)。
3.2核心支持庫(kù)
OSKit核心支持庫(kù)的主要用途是讓客戶OS更容易訪問(wèn)硬件設(shè)施。它包含了一個(gè)較大的實(shí)用函數(shù)和符號(hào)定義的集合,該集合對(duì)于管理模式代碼是非常具體的。與此相對(duì)應(yīng),OSKit的大多數(shù)其他庫(kù)在用戶模式代碼中通常很有用。和OSKit的其余部分所不同的是,多數(shù)核心支持代碼必須是針對(duì)特定系統(tǒng)結(jié)構(gòu)的,而這些特定機(jī)器的細(xì)節(jié)對(duì)客戶OS也是有用的。例如,在x86機(jī)器上,核心支持庫(kù)包含一些函數(shù),用來(lái)創(chuàng)建和操縱x86頁(yè)表和段寄存器。其他OSKit組件通常提供建立在這些低層機(jī)制上的與體系結(jié)構(gòu)無(wú)關(guān)的設(shè)施,但是為了提供最大的靈活性,與特定結(jié)構(gòu)相關(guān)的接口始終可以被訪問(wèn)。
OSKit核心支持庫(kù)在x86體系結(jié)構(gòu)上尤為重要,因?yàn)樵擉w系結(jié)構(gòu)的OS級(jí)編程環(huán)境特別復(fù)雜和模糊。核心支持庫(kù)仔細(xì)地設(shè)置了一個(gè)基本的32位執(zhí)行環(huán)境(為了與MS-DOS兼容,x86處理器通常以16位模式開(kāi)始),初始化段和頁(yè)轉(zhuǎn)換表,安裝一個(gè)中斷向量表,并提供缺省的陷阱和中斷處理程序。當(dāng)然,客戶OS能夠修改或重載這些行為。然而,在缺省情況下,核心支持庫(kù)自動(dòng)地做所有必要的工作,以便使處理器進(jìn)入一個(gè)方便的執(zhí)行環(huán)境,此時(shí)中斷、陷阱、調(diào)試以及其他標(biāo)準(zhǔn)設(shè)施已經(jīng)如預(yù)期的那樣開(kāi)始工作。該庫(kù)在缺省情況下自動(dòng)地定位所有隨內(nèi)核加載的啟動(dòng)模塊,并保留它們所在的物理內(nèi)存。接下來(lái),應(yīng)用程序可以很容易使用它們?蛻鬙S只需以標(biāo)準(zhǔn)C語(yǔ)言風(fēng)格提供一個(gè)main()函數(shù)。一切都設(shè)置好以后,內(nèi)核支持庫(kù)將用所有參數(shù)和由啟動(dòng)加載器傳遞過(guò)來(lái)的環(huán)境變量來(lái)調(diào)用它。
3.3內(nèi)存管理庫(kù)
如同在一個(gè)標(biāo)準(zhǔn)C語(yǔ)言庫(kù)中實(shí)現(xiàn)的malloc()一樣,內(nèi)存管理代碼典型地用于用戶空間。通常并不適用于內(nèi)核。設(shè)備驅(qū)動(dòng)常常需要分配特定類型的內(nèi)存,并伴隨具體的調(diào)整屬性。例如,對(duì)于內(nèi)建的DMA控制器只能訪問(wèn)最初的16M物理內(nèi)存。為解決這些內(nèi)存管理問(wèn)題,OSKit包含了兩個(gè)簡(jiǎn)單而靈活的內(nèi)存管理庫(kù):(1)基于隊(duì)列的內(nèi)存管理器(或稱LMM
【組件機(jī)制與操作系統(tǒng)的實(shí)現(xiàn)】相關(guān)文章:
基于COM技術(shù)的公式計(jì)算組件的開(kāi)發(fā)與實(shí)現(xiàn)11-23
TinyOS消息通訊機(jī)制以及TOSBase無(wú)線-串口通訊組件分析03-07
試論思想道德建設(shè)的實(shí)現(xiàn)機(jī)制03-07
在Windows系統(tǒng)中用VC 實(shí)現(xiàn)鉤子機(jī)制03-18
基于μC/OS-II操作系統(tǒng)的任務(wù)調(diào)度機(jī)制03-04
基于Vxworks實(shí)時(shí)操作系統(tǒng)的串口通信程序設(shè)計(jì)與實(shí)現(xiàn)03-18
硬件密碼組件與軟件密碼組件的比較研究03-18