摘 要: 隨著計算機和微電子技術(shù)的飛速發(fā)展,嵌入式系統(tǒng)(Embedded System)作為計算機應(yīng)用的一個重要領(lǐng)域,已深入到社會的方方面面。本文討論了嵌入式系統(tǒng)軟件的設(shè)計與實現(xiàn),旨在創(chuàng)建一個完整的嵌入式控制系統(tǒng)軟件平臺。該平臺將嵌入式實時操作系統(tǒng)、嵌入式組態(tài)軟件、軟PLC等有機地結(jié)合起來,為嵌入式控制系統(tǒng)提供一個完整的運行環(huán)境。
關(guān)鍵字: 軟件平臺, 嵌入式, 控制系統(tǒng)
1 引言
近年來,嵌入式系統(tǒng)在工業(yè)控制領(lǐng)域的應(yīng)用越來越廣泛。隨著嵌入式控制系統(tǒng)的發(fā)展,嵌入式控制系統(tǒng)將在一定程度上取代現(xiàn)有的工業(yè)PC控制系統(tǒng),在微型TDCS(集散控制系統(tǒng))、現(xiàn)場總線系統(tǒng)、PLC控制系統(tǒng)、智能化儀表等領(lǐng)域得到廣泛的應(yīng)用。由于其相對于大型的TDCS系統(tǒng)來說具有較強的成本優(yōu)勢和靈活性,其應(yīng)用領(lǐng)域正在進一步擴大。本文建立了一套完整的嵌入式控制系統(tǒng)軟件平臺,該平臺建構(gòu)于嵌入式硬件系統(tǒng)之上,包括嵌入式實時操作系統(tǒng)、軟PLC系統(tǒng)、嵌入式組態(tài)軟件等。
平臺包括運行環(huán)境和開發(fā)環(huán)境兩部分。使用開發(fā)環(huán)境,用戶可以方便組態(tài)和二次開發(fā),而將開發(fā)重點集中到具體的控制系統(tǒng)應(yīng)用上,而諸如系統(tǒng)的軟件架構(gòu)設(shè)計、實時性保證、通用的控制系統(tǒng)軟件如網(wǎng)絡(luò)通信、控制算法等復(fù)雜而繁瑣的軟件工作,則交由平臺完成。
2平臺的總體框架
嵌入式控制系統(tǒng)平臺是以嵌入式實時操作系統(tǒng)為核心,包括硬件平臺、硬件驅(qū)動、圖形庫運行環(huán)境、實時數(shù)據(jù)庫管理與通信、人機界面、軟PLC、網(wǎng)絡(luò)通信、用戶應(yīng)用程序等。
嵌入式控制系統(tǒng)平臺總體框架如圖1所示。
[align=center]
圖1嵌入式控制系統(tǒng)軟件平臺總體框架[/align]
由圖1可知,嵌入式控制系統(tǒng)軟件平臺主要包括以下部分:
?。?) 嵌入式硬件平臺 (2) 嵌入式實時操作系統(tǒng) (3) 硬件驅(qū)動程序
(4) 圖形庫與運行環(huán)境 (5) 實時數(shù)據(jù)庫管理與通信 (6) 人機界面
?。?) 軟PLC (8) 網(wǎng)絡(luò)通信 (9) 用戶應(yīng)用程序
3 嵌入式控制系統(tǒng)軟件平臺主要模塊的實現(xiàn)
嵌入式控制系統(tǒng)軟件平臺是個非常復(fù)雜的系統(tǒng),從總體框架圖可以看出平臺包括實時操作系統(tǒng)、實時數(shù)據(jù)庫管理與通信、圖形庫與運行環(huán)境、人機界面等許多模塊,本章著重介紹嵌入式實時操作系統(tǒng)、實時數(shù)據(jù)庫管理與通信等模塊的實現(xiàn)。
3.1嵌入式Linux實時操作系統(tǒng)
Linux是一種能運行于多種平臺、功能強大、源代碼公開、免費的操作系統(tǒng),基于Linux開發(fā)一個開放的、標準的、高效廉價的實時操作系統(tǒng)是完全可行的。本文介紹的嵌入式控制系統(tǒng)軟件平臺就采用嵌入式Linux實時操作系統(tǒng),使用雙內(nèi)核RTAI解決方案。RTAI的實現(xiàn)方案類似于RT-Linux,是雙內(nèi)核系統(tǒng),即利用Linux內(nèi)核,同時增加一個實時內(nèi)核,兩個內(nèi)核共同工作。RTAI利用Linux提供的內(nèi)核模塊機制完成實時任務(wù),提供實時服務(wù)。模塊是內(nèi)核的一部分,但是沒有被編譯到內(nèi)核里去。模塊被編譯成一組目標文件,根據(jù)需要,這些文件能夠被插入到正在運行的內(nèi)核中,也可以從正在運行的內(nèi)核中移去。RTAI實現(xiàn)的主要模塊有RTAI核心模塊、RTAI調(diào)度器模塊、RTAI先進先出模塊、RTAI共享內(nèi)存模塊和LXRT模塊等。
3.1.1基于RTAI的Linux實時操作系統(tǒng)的實現(xiàn)
我們實現(xiàn)基于RTAI的Linux實時操作系統(tǒng)的過程是:在標準Linux的基礎(chǔ)上,打上RTAI的實時補丁包,根據(jù)特定硬件條件和運行環(huán)境的要求進行適當(dāng)?shù)呐渲?再對內(nèi)核進行裁剪后編譯成一個支持實時性的內(nèi)核。
3.1.2基于RTAI-Linux的應(yīng)用程序開發(fā)
在編寫基于RTAI-Linux的應(yīng)用程序時,根據(jù)實時系統(tǒng)的具體要求,將應(yīng)用程序分為實時任務(wù)和非實時任務(wù)。實時任務(wù)是實時模塊,作為Linux核心可加載模塊運行在核心態(tài)。一般地,定義init_module()函數(shù),它在執(zhí)行insmod命令裝載模塊時被調(diào)用,在該函數(shù)中一般是作一些初試化工作,并且啟動實時任務(wù)。同樣的,還需要定義cleanup_module()函數(shù),它在執(zhí)行rmmod卸載模塊時被調(diào)用,在該函數(shù)中一般是做一些資源釋放工作。實時任務(wù)的設(shè)計應(yīng)該盡可能簡單,僅包含那些有強實時要求的處理模塊,如實時數(shù)據(jù)采集、外部設(shè)備控制等。
非實時任務(wù)是普通的Linux進程,它在用戶態(tài)運行,運行那些對實時要求不高的任務(wù),如數(shù)據(jù)處理、圖形顯示等。
實時任務(wù)(RTAI核心態(tài))并不能直接調(diào)用系統(tǒng)調(diào)用,它必須通過特定的方法和非實時任務(wù)(Linux進程)進行通信。它們可以通過共享內(nèi)存和FIFO等方法通信。
基于RTAI應(yīng)用程序的結(jié)構(gòu)圖如圖2所示。
[align=center]
圖2 RTAI應(yīng)用程序結(jié)構(gòu)圖[/align]
3.2實時數(shù)據(jù)庫管理與通信
本系統(tǒng)的實時數(shù)據(jù)庫管理著全局I/O數(shù)據(jù)。通過硬件驅(qū)動程序,將數(shù)據(jù)采集,并放入到實時數(shù)據(jù)庫中,同時,上層軟件從實時數(shù)據(jù)庫中獲得數(shù)據(jù)。
3.2.1數(shù)據(jù)結(jié)構(gòu)設(shè)計
實時數(shù)據(jù)庫與其他一般數(shù)據(jù)庫一樣,包含一組對象及其結(jié)構(gòu),由于目前對實時數(shù)據(jù)庫還沒有提出統(tǒng)一的數(shù)據(jù)模型,所以不同廠家開發(fā)的數(shù)據(jù)庫的數(shù)據(jù)結(jié)構(gòu)都有很大差別。本系統(tǒng)的實時數(shù)據(jù)庫,一個基本的數(shù)據(jù)對象為“數(shù)據(jù)”,一個數(shù)據(jù)包含若干信息,如數(shù)據(jù)名稱、數(shù)據(jù)類型、數(shù)據(jù)位置、數(shù)據(jù)長度等。
考慮到數(shù)據(jù)的存取效率,程序運行一開始,我們將在內(nèi)存區(qū)開辟一段緩沖區(qū),緩沖區(qū)中只存放數(shù)據(jù),如果緩沖區(qū)大小不夠,即緩沖區(qū)的數(shù)據(jù)較多,可以自動擴展緩沖區(qū)大小。實時數(shù)據(jù)存放在緩沖區(qū)時,我們采取這種思想:如果不是bit型數(shù)據(jù),由于數(shù)據(jù)長度都是字節(jié)的整數(shù)倍,存入緩沖區(qū)中以字節(jié)來進行存儲,該數(shù)據(jù)的長度length是以字節(jié)來計算。如果是bit型數(shù)據(jù),存入緩沖區(qū)中,該數(shù)據(jù)的長度length是以位來計算,接著再存儲一個實時數(shù)據(jù),若為非bit型數(shù)據(jù),則從下一個字節(jié)開始存放,即原來的bit型數(shù)據(jù)占用一個字節(jié),若為bit型數(shù)據(jù),根據(jù)此數(shù)據(jù)的長度來判斷其存放位置,這里又分兩種情況,如果這兩個bit型數(shù)據(jù)的長度沒有超過8位,則緊接著前一個bit型數(shù)據(jù)后存儲這個bit型數(shù)據(jù),如果兩個bit型數(shù)據(jù)的長度超過8位,則從下一個字節(jié)開始存放,即原來的bit型數(shù)據(jù)占用一個字節(jié)。
3.2.2數(shù)據(jù)存取設(shè)計
為了存取方便,我們將所有的實時數(shù)據(jù)組成一個鏈表,鏈表的節(jié)點類型為上述的rtdb_data_t結(jié)構(gòu)。當(dāng)向?qū)崟r緩沖區(qū)中加入一條數(shù)據(jù)時,就自動會計算出數(shù)據(jù)存儲位置、長度等信息,并在實時數(shù)據(jù)庫鏈表中加上一個節(jié)點。這樣,取實時數(shù)據(jù)就非常靈活和方便,如果知道實時數(shù)據(jù)的名稱,則可以遍歷鏈表得到數(shù)據(jù),如果知道數(shù)據(jù)的存儲位置和長度,則可以利用實時數(shù)據(jù)庫提供的接口直接從緩沖區(qū)中獲得數(shù)據(jù),而不必遍歷鏈表,因為遍歷鏈表需要花費一些時間,這在實時性要求較高的本系統(tǒng)中不太適合,所以本系統(tǒng)常常采用后一種方法存取數(shù)據(jù)。實時數(shù)據(jù)庫鏈表結(jié)構(gòu)如圖3所示。
[align=center]
圖3實時數(shù)據(jù)庫鏈表結(jié)構(gòu)[/align]
3.3人機界面軟件
人機界面模塊是本系統(tǒng)重要的部分,它提供用戶與底層控制的交互平臺。
3.3.1人機界面數(shù)據(jù)庫
人機界面數(shù)據(jù)是指與界面相關(guān)的數(shù)據(jù),包括全局I/O數(shù)據(jù)和內(nèi)存數(shù)據(jù)。I/O數(shù)據(jù)指的是需要系統(tǒng)和其它應(yīng)用程序(包括I/O服務(wù)程序)交換數(shù)據(jù)的變量,與實時數(shù)據(jù)庫中的全局I/O數(shù)據(jù)相似。內(nèi)存變量是只在系統(tǒng)內(nèi)需要的變量,比如計算過程的中間變量。為了存取方便,我們使用鏈表來組織人機界面數(shù)據(jù),形成兩個鏈表:I/O數(shù)據(jù)鏈和內(nèi)存數(shù)據(jù)鏈。人機界面數(shù)據(jù)庫也是依據(jù)XML配置文件hmidb.xml來填充的,XML配置文件來自于開發(fā)環(huán)境。
3.2.2界面圖元
圖元是構(gòu)成畫面的基本元素,包括基本圖元,如線條、矩形、橢圓等,以及組合圖元,如油罐、閥門等,它們是由基本圖元組合而成。本系統(tǒng)提供了大量的圖元,這些圖元的繪制將調(diào)用特定系統(tǒng)下的平臺函數(shù),如Linux系統(tǒng)和Windows CE系統(tǒng),即對于用戶來說,不管使用哪個系統(tǒng),這一層是相同的。
描述人機界面需要一個XML配置文件,如hmiwidget.xml,這個配置文件是用戶在開發(fā)環(huán)境中設(shè)計界面時生成的。系統(tǒng)還支持圖元的變化,即動態(tài)屬性,以及事件響應(yīng)。因此人機界面圖元還有動態(tài)屬性和事件屬性,解析配置文件hmiwidget.xml時,會分析這些屬性,并將其鏈起來。
在系統(tǒng)初始化時,MiniGUI分為兩種情況:服務(wù)器(Server)和客戶端(Client)。這主要取決于全局變量mgServer的值,如果為TRUE,表示為服務(wù)端,如果為FALSE,表示為客戶端。我們將MiniGUI應(yīng)用程序名改為mginit,則該應(yīng)用程序為服務(wù)端,如果MiniGUI應(yīng)用程序名作為客戶端運行,則必須先運行MiniGUI提供的服務(wù)端程序mginit。
[align=center]
圖4 MiniGUI應(yīng)用程序流程[/align]
本文作者創(chuàng)新點:
本文討論的嵌入式控制系統(tǒng)軟件平臺是一個復(fù)雜、龐大的系統(tǒng),而且每個組成部分其內(nèi)部結(jié)構(gòu)和實現(xiàn)也非常復(fù)雜。我在此課題中做了很多研究,提出了系統(tǒng)設(shè)計的框架,如今已經(jīng)實現(xiàn)部分為: 嵌入式Linux實時操作系統(tǒng)、實時數(shù)據(jù)庫管理與通信、圖形庫與運行環(huán)境等,取得了優(yōu)秀的成果。
參考文獻:
[1] 朱文凱,王衛(wèi)華,丁漢等.基于嵌入式PC的開放式PLC[J].機械與電子,2003(3):3-7
[2]李嘉.嵌入式遠程監(jiān)控系統(tǒng)的開發(fā)[J].自動化儀表,2002,4 23(4):5-7
[3]須文波,張星燁,歐愛輝.基于RTAI-Linux的實時操作系統(tǒng)的分析與研究[J].山東電子,2003(2):21-23
[4] 陳瑋,周瑞祥,黎卓韜. 分布式制造資源集成系統(tǒng)軟件平臺研究[J]. 微計算機信息, 2006, 5-1: 309-311
作者簡介:
何會民 (1967.3-), 男,漢族, 河北永年人,副教授,主要從事計算機體系結(jié)構(gòu)與嵌入式的教學(xué)與研究。