基于UC/OS-II的嵌入式構(gòu)件系統(tǒng)設(shè)計(jì)
近些年來(lái),隨著嵌入式產(chǎn)品需求的不斷增加,嵌入式軟件正變得越來(lái)越復(fù)雜,而產(chǎn)品的開(kāi)發(fā)周期也越來(lái)越短。嵌入式軟件開(kāi)發(fā)迫切需要更高效的軟件重用手段。
隨著軟件復(fù)用研究成為熱點(diǎn),其核心技術(shù)——構(gòu)件化軟件開(kāi)發(fā)方法(CBD)引起了軟件工程領(lǐng)域的高度關(guān)注,并且在工程應(yīng)用領(lǐng)域獲得了極大的成功。這種開(kāi)發(fā)方法已在辦公應(yīng)用、電子商務(wù)、因特網(wǎng)及分布式網(wǎng)絡(luò)應(yīng)用中廣泛使用;但在嵌入式領(lǐng)域,構(gòu)件技術(shù)仍處于起步階段,目前沒(méi)有一個(gè)統(tǒng)一通用的構(gòu)件規(guī)范。盡管如此,由于基于構(gòu)件的軟件設(shè)計(jì)方法能夠極好地滿(mǎn)足嵌入式軟件幾乎所有的特性(如定制、裁剪、動(dòng)態(tài)演變等),有效縮短產(chǎn)品開(kāi)發(fā)周期,這種設(shè)計(jì)方法無(wú)疑將給嵌入式系統(tǒng)的開(kāi)發(fā)帶來(lái)巨大的好處。
本文嘗試將構(gòu)件化軟件設(shè)計(jì)思想引入嵌入式軟件設(shè)計(jì)中,提出了一種適用于嵌入式軟件的基于構(gòu)件的軟件體系結(jié)構(gòu),并且在常用輸入設(shè)備鍵盤(pán)的應(yīng)用實(shí)踐中,驗(yàn)證了此體系結(jié)構(gòu)的可行性。
1 嵌入式構(gòu)件技術(shù)
1.1 構(gòu) 件
構(gòu)件可以視為一個(gè)通過(guò)接口對(duì)外界提供服務(wù)或向外界請(qǐng)求服務(wù)的黑盒,多個(gè)構(gòu)件可以組成一個(gè)更高層次的構(gòu)件,構(gòu)件比對(duì)象提供了更高的設(shè)計(jì)抽象。構(gòu)件是二進(jìn)制可替換的,這個(gè)特點(diǎn)使它們與“類(lèi)”有著顯著的不同。當(dāng)創(chuàng)建了一個(gè)構(gòu)件的修訂版本時(shí),它可以替代同一構(gòu)件的原先版本,而不必重新編譯其他構(gòu)件。通常,只要一個(gè)構(gòu)件滿(mǎn)足相同的接口,就可替換另一個(gè)構(gòu)件,而不必對(duì)其他構(gòu)件做任何修改。因此,構(gòu)件能夠很好地解決更新、維護(hù)、分布和復(fù)用等諸多問(wèn)題。
構(gòu)件具備以下幾個(gè)基本特征:可復(fù)用性、可封裝性、組裝性、可定制性、自治性、粗粒度、集成特征、接口連接機(jī)制。目前,構(gòu)建模型大致可分為2類(lèi):在面向?qū)ο蟮某绦蛟O(shè)計(jì)中,構(gòu)件即對(duì)象,例如JavaBean;在軟件體系結(jié)構(gòu)中,構(gòu)件即結(jié)構(gòu)單元,例如結(jié)構(gòu)描述語(yǔ)言ADL。這些構(gòu)件模型適合更高層的應(yīng)用軟件,但不適合在嵌入式軟件開(kāi)發(fā)中占主導(dǎo)地位的底層系統(tǒng)軟件的開(kāi)發(fā)。
1.2 嵌入式構(gòu)件
1.2.1 嵌入式構(gòu)件模型
嵌入式構(gòu)件為實(shí)現(xiàn)一定嵌入式系統(tǒng)功能的一組封裝的、規(guī)范的、可重用的、具有嵌入特性的軟件單元,是組成嵌入式系統(tǒng)的功能單位。它是被標(biāo)準(zhǔn)化的、具有重用性、支持QoS的、能夠提供實(shí)時(shí)應(yīng)用的軟件資源。
這里,從嵌入式構(gòu)件的定義出發(fā),將參考文獻(xiàn)中通用軟件構(gòu)件模型作適當(dāng)?shù)臄U(kuò)展,使其成為適用于嵌入式系統(tǒng)的基本構(gòu)件模型。
每個(gè)嵌入式構(gòu)件由4部分構(gòu)成:構(gòu)件體、屬性、接口、依賴(lài)關(guān)系。圖1為基本構(gòu)件的示意圖。構(gòu)件體實(shí)現(xiàn)構(gòu)件的基本功能,即對(duì)外提供的服務(wù);屬性描述了構(gòu)件的基本信息;接口將構(gòu)件與外界連接,在得到自己需要的服務(wù)后,為外界提供服務(wù),每一種接口對(duì)應(yīng)一個(gè)不同的服務(wù);依賴(lài)關(guān)系標(biāo)識(shí)構(gòu)件間的所有關(guān)系,用于實(shí)現(xiàn)構(gòu)件間的拼接。
- FPGA
- DSP
- MCU
- 示波器
- 步進(jìn)電機(jī)
- Zigbee
- LabVIEW
- Arduino
- RFID
- NFC
- STM32
- Protel
- GPS
- MSP430
- Multisim
- 濾波器
- CAN總線
- 開(kāi)關(guān)電源
- 單片機(jī)
- PCB
- USB
- ARM
- CPLD
- 連接器
- MEMS
- CMOS
- MIPS
- EMC
- EDA
- ROM
- 陀螺儀
- VHDL
- 比較器
- Verilog
- 穩(wěn)壓電源
- RAM
- AVR
- 傳感器
- 可控硅
- IGBT
- 嵌入式開(kāi)發(fā)
- 逆變器
- Quartus
- RS-232
- Cyclone
- 電位器
- 電機(jī)控制
- 藍(lán)牙
- PLC
- PWM
- 汽車(chē)電子
- 轉(zhuǎn)換器
- 電源管理
- 信號(hào)放大器
屬性是描述構(gòu)件某個(gè)方面特征的元數(shù)據(jù)。屬性定義了構(gòu)件查找的方法,可以根據(jù)任意一條屬性記錄快速找到符合條件的構(gòu)件。由于嵌入式構(gòu)件的特殊性,可以將嵌入式軟件構(gòu)件的屬性分為3 種:描述屬性、約束屬性和服務(wù)質(zhì)量(QoS)屬性。
(1)描述屬性
描述屬性指的是一般構(gòu)件都具有的公共屬性。常見(jiàn)的描述屬性有以下幾種。
名稱(chēng):構(gòu)件以名稱(chēng)作為標(biāo)識(shí)。
標(biāo)識(shí):每個(gè)構(gòu)件都對(duì)應(yīng)唯一的ID號(hào),區(qū)別于其他構(gòu)件。
類(lèi)型:將構(gòu)件歸類(lèi),便于檢索與管理。
版本號(hào):用于構(gòu)件的更新。
編程語(yǔ)言:表示構(gòu)件的實(shí)現(xiàn)語(yǔ)言。
構(gòu)件描述信息:簡(jiǎn)述構(gòu)件功能。
表示形式:一個(gè)構(gòu)件可以是源代碼、動(dòng)態(tài)鏈接庫(kù)、靜態(tài)鏈接庫(kù),以及文檔、圖表等形式。
(2)約束屬性
約束屬性描述構(gòu)件所依賴(lài)的環(huán)境。約束屬性可分為2類(lèi):描述絕大多數(shù)構(gòu)件都具有的公有約束屬性和描述單獨(dú)構(gòu)件特殊需求的專(zhuān)有約束屬性。公有約束屬性包括 CPU類(lèi)型、操作系統(tǒng)、依賴(lài)的類(lèi)庫(kù)等。專(zhuān)有約束屬性包括特殊硬件需求、時(shí)間約束和內(nèi)存需求等。
(3)QoS屬性
QoS屬性是嵌入式軟件構(gòu)件最重要的要素。為了選取合適的構(gòu)件來(lái)開(kāi)發(fā)嵌入式系統(tǒng),必須考慮構(gòu)件的QoS屬性,以評(píng)估它所提供的性能指標(biāo)。常見(jiàn)的QoS屬性包括平均執(zhí)行時(shí)間、最差執(zhí)行時(shí)間、最優(yōu)執(zhí)行時(shí)間、內(nèi)存消耗、功耗、健壯性、可靠性和安全性等。
2 嵌入式軟件構(gòu)件設(shè)計(jì)
2.1 μC/OS—II嵌入式實(shí)時(shí)操作系統(tǒng)
μC/0S—II是一個(gè)可移植、占先式、實(shí)時(shí)的多任務(wù)內(nèi)核,以任務(wù)為基本處理單位,能同時(shí)管理高達(dá)63個(gè)任務(wù)。它實(shí)時(shí)性強(qiáng),可靠性高,對(duì)處理器以及 ROM、RAM資源的要求不高;另外,它的代碼大部分用ANSI C語(yǔ)言編寫(xiě),只有少部分微處理器專(zhuān)用的代碼用匯編語(yǔ)言編寫(xiě),有利于程序的移植。
2.2 基于構(gòu)件的嵌入式軟件體系結(jié)構(gòu)
一個(gè)構(gòu)件系統(tǒng)的體系結(jié)構(gòu)由一系列定義的構(gòu)件框架和針對(duì)該框架設(shè)計(jì)的構(gòu)件間的相互作用關(guān)系組成。體系結(jié)構(gòu)是所要實(shí)現(xiàn)系統(tǒng)的整體規(guī)劃,它為構(gòu)件的組裝提供基礎(chǔ)框架和接口規(guī)范。
目前,嵌入式構(gòu)件技術(shù)研究的核心之一是構(gòu)件模型和軟件體系結(jié)構(gòu)(軟件構(gòu)架)這兩個(gè)相互關(guān)聯(lián)的問(wèn)題。不同的構(gòu)件只能在相應(yīng)的軟件構(gòu)架中使用,因此基于構(gòu)件的應(yīng)用軟件設(shè)計(jì)也可認(rèn)為是基于體系結(jié)構(gòu)(構(gòu)架)的軟件設(shè)計(jì),也稱(chēng)之為基于“構(gòu)件一構(gòu)架”的應(yīng)用軟件設(shè)計(jì)。
根據(jù)上述的嵌入式基本構(gòu)件模型,本文提出了一適用于嵌入式系統(tǒng)的軟件體系結(jié)構(gòu)。其中,定義“構(gòu)件系統(tǒng)”為一特定應(yīng)用,實(shí)現(xiàn)某一具體功能。例如,鍵盤(pán)為一構(gòu)件系統(tǒng),顯示器也為一構(gòu)件系統(tǒng)。另外,定義“構(gòu)件子系統(tǒng)”。它類(lèi)似于UML中的包概念,代表元素的邏輯分組,將具體的應(yīng)用從實(shí)際問(wèn)題中抽象出來(lái),同時(shí)對(duì)各個(gè)關(guān)注區(qū)域進(jìn)行相對(duì)分離,這樣做可以獨(dú)立地分析各個(gè)關(guān)注點(diǎn),從而可以更好地分析系統(tǒng)的結(jié)構(gòu)。一個(gè)構(gòu)件子系統(tǒng)可以包含一個(gè)構(gòu)件或者是多個(gè)構(gòu)件的集合。
我們把構(gòu)件系統(tǒng)構(gòu)造成抽象層次中的不同部分,最抽象(最接近應(yīng)用領(lǐng)域)的位于“頂部”,最具體(最接近硬件)的位于“底部”。這樣,可以將構(gòu)件系統(tǒng)從結(jié)構(gòu)上構(gòu)造為6個(gè)獨(dú)立的層次:應(yīng)用層、用戶(hù)接口層、通信層、OS層、硬件抽象層和配置描述層。
每個(gè)層次為一個(gè)構(gòu)件子系統(tǒng),每個(gè)構(gòu)件子系統(tǒng)內(nèi)包含有一個(gè)或多個(gè)構(gòu)件。通過(guò)構(gòu)件間的依賴(lài)關(guān)系來(lái)定位和拼接構(gòu)件,組裝構(gòu)件子系統(tǒng),最終生成所需要的構(gòu)件系統(tǒng)。其中,配置描述層記錄構(gòu)件系統(tǒng)屬性、結(jié)構(gòu)說(shuō)明、相關(guān)參數(shù)設(shè)置與系統(tǒng)類(lèi)型定義,以及構(gòu)件系統(tǒng)中各構(gòu)件的依賴(lài)關(guān)系。配置描述層作用于其他各個(gè)層次,記錄了構(gòu)件系統(tǒng)所需的一切信息,使得構(gòu)件系統(tǒng)的移植更為方便,同時(shí)也易于構(gòu)件的查詢(xún)、檢索、維護(hù)及出入庫(kù)管理。 linux操作系統(tǒng)文章專(zhuān)題:linux操作系統(tǒng)詳解(linux不再難懂)
評(píng)論