基于RTLinux的實時控制系統(tǒng)
基于RTLinux的實時控制系統(tǒng)
摘要:從技術(shù)背景、系統(tǒng)結(jié)構(gòu)、硬件和軟件設(shè)計等方面論述了基于RTLinux的閘門實時控制系統(tǒng)的組成、原理以及實現(xiàn)方法,并著重分析了軟件實現(xiàn)的關(guān)鍵問題。關(guān)鍵詞:RTLinux 實時控制 TCP/IP MYSQL數(shù)據(jù)庫
在水電站閘門控制系統(tǒng)中,設(shè)備地理位置分散、控制分散,基于常規(guī)繼電器的控制系統(tǒng)不能滿足電廠無人值班控制系統(tǒng)和全廠綜合自動化的要求,必須將智能控制和工業(yè)網(wǎng)絡(luò)相結(jié)合,實現(xiàn)實時控制的同時又能對設(shè)備進行智能管理和維護。目前比較常用的控制系統(tǒng)大多由PLC構(gòu)成,成本較高,缺乏客戶定制的靈活性。本文從系統(tǒng)功能實現(xiàn)和經(jīng)濟指標兩個方面考慮,半基于RTLinux的控制平臺、工業(yè)以太網(wǎng)和數(shù)據(jù)庫技術(shù)引入閘門控制系統(tǒng)。
1 RTLlinux、工業(yè)以太網(wǎng)和數(shù)據(jù)庫
RTLinux是由新墨西大學(xué)的Victor Yodaiken等人開發(fā)的,現(xiàn)在已有商業(yè)化的版本推出。在RTLinux面世之前,Linux在實時性方面作過一些嘗試。(www. 收集整理)在POSIX1.b中,規(guī)定了實時進程的一些標準,但由于Linux內(nèi)核的不可搶先性,真正的實時進程無法在標準的Linux環(huán)境下實現(xiàn)。RTLinux采用簡單而有效的方法解決了此問題而不用重寫Linux內(nèi)核代碼。RTLinux實現(xiàn)了一個高效的可搶先的實時調(diào)度核心,全面接管中斷,并把Linux作為此實時核心的一個優(yōu)先級最低的進程運行。當有實時任務(wù)需要處理時,RTLinux運行實時任務(wù);無實時任務(wù)時,RTLinux運行Linux的非實時進程。圖1是RTLinux的結(jié)構(gòu)圖。
為保證實時進程與非實時Linux進程部順序進行數(shù)據(jù)交換,RTLinux引入了RT-FIFO隊列。RT-FIFO被Linux視為字符設(shè)備,最多可達150個,分別命名為/der/rtf0、/dev/rtf1……/dev/rtf63。最大的RT-FIFO數(shù)量在系統(tǒng)內(nèi)核編譯時設(shè)定。圖2說明了RT-FIFO的工作原理。
RTLinux程序運行于兩個空間:用戶空間內(nèi)核態(tài)。RTLinux提供了應(yīng)用程序接口,借助這些API函數(shù)將實時處理部分編寫成內(nèi)核模塊,并裝載到RTLinux內(nèi)核中,運行于RTLinux的內(nèi)核態(tài)。非實時部分的應(yīng)用程序則在Linux下的用戶空間中執(zhí)行,這樣可以發(fā)揮Linux對網(wǎng)絡(luò)和數(shù)據(jù)庫的強大支持功能。
TCP/IP協(xié)議和以太網(wǎng)在Internet上的成功應(yīng)用吸引著越來越多控制程師。盡管以太網(wǎng)的時間不確定性給以太網(wǎng)應(yīng)用于工業(yè)控制現(xiàn)場的實時性帶來了很多爭論,但是實際應(yīng)用中,經(jīng)網(wǎng)絡(luò)傳輸?shù)臄?shù)據(jù)絕大多數(shù)用于系統(tǒng)管理和維護等方面,用于實時控制的數(shù)據(jù)傳輸很少,這也是基于管理集中、控制分散的系統(tǒng)設(shè)計策略考慮的。在較高的以太網(wǎng)傳輸速度下,現(xiàn)場智能處理單元的處理速度才是傳輸延遲的主要原因。本系統(tǒng)現(xiàn)場控制單元采用高速處理器,并采用RTLinux作為現(xiàn)場控制單元的控制平臺,直接用以太網(wǎng)傳輸數(shù)據(jù),系統(tǒng)的網(wǎng)絡(luò)層次減少,信號的傳輸實時性也得到提高。
目前,有許多數(shù)據(jù)庫開發(fā)商提供了Linux平臺上的數(shù)據(jù)庫軟件,例如Oracle、Sybase、Informix和MYSQL等都推出了Linux版本;赗TLinux的控制系統(tǒng)在實時控制領(lǐng)域有巨大的潛力。
2 系統(tǒng)組成
本系統(tǒng)分為現(xiàn)場和集中級,F(xiàn)場控制級由分散在現(xiàn)場的4個現(xiàn)場控制單元控制,分別完成閘門位置、油缸油壓和油路狀態(tài)等的采集,現(xiàn)場操作按鈕的監(jiān)視以及閘門提升和下降的控制等。集中級由集中監(jiān)控站、維護站組成,分別執(zhí)行監(jiān)視、智能維護及診斷等功能。打印機用于數(shù)據(jù)的硬備份、報表的輸出。系統(tǒng)結(jié)構(gòu)如圖3所示。
2.1 系統(tǒng)硬件構(gòu)成
在工業(yè)控制系統(tǒng)中通常采用PLC作為現(xiàn)場的控制核心。PLC的不足一方面在于其較高的價格,另一方面在于其難以實現(xiàn)非順序控制算法,以及缺乏對TCP/IP靈活的支持。本系統(tǒng)采用嵌入式PC作為控制單元的核心,開發(fā)人員可自行開發(fā)外圍接口板,根據(jù)系統(tǒng)需要靈活組態(tài),既經(jīng)濟又能使用高級語言開發(fā)控制程序。
現(xiàn)場控制閘門的LCU采用相同的硬件配置。CPU板采用研華公司的PCM-5864,CPU的Intel公司的Pentium MMX 166MHz,內(nèi)存為64MB,以太網(wǎng)接口為10MHz的RTL-8139A。CPU板通過PC104總線與采樣模塊和輸出模塊相連。此外該板上配有顯示、鍵盤和鼠標等標準接口,便于在線修改和檢查程序。硬盤選用容量為4.3GB的筆記本硬盤。16通道的A/D采樣模塊PCM-3718H完成模擬量的采集,分辨率為12位;16通道的數(shù)字I/O模塊PCM-3730用于開關(guān)量的采集、控制閘門的啟動和停止。為便于現(xiàn)場巡檢,LCU配有顯示中文信息的LCD模塊MGLS-240128,內(nèi)置T6963C控制器。系統(tǒng)采用了16端口的HUB。
為保證集中站可靠地工作,集中監(jiān)控站、集中維
護站采用工業(yè)PC,配有Intel公司的P處理器,256MB內(nèi)存和40GB的大硬盤,TCP/IP通信由3COM公司的10/100MbpsPCI網(wǎng)卡3C905C來完成。
2.2 系統(tǒng)軟件構(gòu)成
系統(tǒng)的軟件也分為兩部分。集中監(jiān)控站采用Windows2000操作系統(tǒng),并安裝有MYSQL-3.23.49 for Windows服務(wù)器軟件和監(jiān)控軟件;維護也采用Windows2000操作系統(tǒng)。此外裝有MYSQL的客戶端軟件包和維護及診斷軟件。監(jiān)控軟件和維護及診斷軟件均用Visual C++開發(fā)。
LCU的軟件包括實時Linux操作系統(tǒng)、數(shù)據(jù)庫客戶端軟件和控制程序。在LCU中,操作系統(tǒng)Redhat6.2經(jīng)升級和安裝RTLinux后被改造成實時Linux。升級后的核為Linux-2.2.18,RTLinux的版本號為RTLinux2.2 for Linux-2.2.18。數(shù)據(jù)庫的客戶端程序包為MYSQL-3.23.49RPM?刂瞥绦虬▽崟r控制程序和非實時程序兩部分。
3 系統(tǒng)設(shè)計的關(guān)鍵問題
現(xiàn)場單元中與實現(xiàn)控制部分和非實時控制部分程序相對應(yīng)的文件為gatectl_module.c和gatectl_app.c。二者由gcc編譯后生成目標文件gatectl_module.o和gatectl_app.o。前者為內(nèi)核模塊,嵌入到RTLinux核中,用于實時采集和實時控制輸出,運行于內(nèi)核態(tài)。后者為Linux應(yīng)用環(huán)境,運行于用戶空間,完成數(shù)據(jù)的預(yù)處理、訪問數(shù)據(jù)庫和人機接口等工作。
3.1 內(nèi)核模塊
內(nèi)核模塊程序按多線程模式編寫,RTLinux提供了與多線程編程相應(yīng)的API函數(shù)。
RTLinux2.2內(nèi)核中,完成實時任務(wù)的模塊主要包括以下兩個功能函數(shù):
Int init_module();
Void cleanup_module()。
前者在模塊第一次裝入核中時被調(diào)用,完成實時任務(wù)的參數(shù)(優(yōu)先級別、中斷周期等)的設(shè)置,進行任務(wù)的啟動和終止等操作。后者在模塊卸載時被調(diào)用,一般在調(diào)試或系統(tǒng)退出時使用。模塊中可啟動多個任務(wù),本系統(tǒng)在實時部分只設(shè)計一個實時任務(wù)即Task1。
啟動實時任務(wù)前必須進行初始化。init_module()中的初始化工作包括以下三部分:
·為保證內(nèi)核態(tài)的.實時進程與用戶空間的非實時進程間交換信息。須創(chuàng)建3個RTL-FIFO,具體為:rtf1用于實時進程與非實時進程間的數(shù)據(jù)交換,數(shù)據(jù)包括采集到的模擬量和數(shù)字量;rtf3用于非實時進程向?qū)崟r進程傳遞控制命令字,以啟動和終止實時任務(wù);rtf2用于保存經(jīng)ttf3傳遞的實時任務(wù)的控制命令字。創(chuàng)建工作由RTLinux提供的API函數(shù)rtf_create(n,buf)來完成。
·創(chuàng)建實時任務(wù)Task1對應(yīng)的線程,并設(shè)定其調(diào)度優(yōu)先級,由API函數(shù)pthread_create來完成。
·當非實時進程通過rtf3進行控制命令傳遞時,實時進程應(yīng)及時響應(yīng)。因此必須在實時程序中建立跟蹤rtf3變化的子程序,調(diào)用rtf_create_handler(3,&data_handler)來完成此功能。
內(nèi)核態(tài)的主體程序有兩種實現(xiàn)方式:中斷處理和周期實時線程方式。本系統(tǒng)采用周期性實時線,即周期性地執(zhí)行數(shù)據(jù)采集、輸出控制結(jié)果以及與處于用戶空間中的非實時進程交換數(shù)據(jù)。具體過程見圖4。
在編寫實時程序時,應(yīng)特別注意的是:實時任務(wù)運行在內(nèi)核水平,是為了提供對計算機硬件的直接訪問能力,為避免不確定的延遲,RTLinux給代碼和數(shù)據(jù)分配固定的內(nèi)存空間。實時任務(wù)不能使用Linux的系統(tǒng)調(diào)用及Linux中的程序與數(shù)據(jù)結(jié)構(gòu),否則難以保證數(shù)據(jù)的一致性。此外應(yīng)控制實時程序的執(zhí)行時間,編寫程序時應(yīng)注意包含與API函數(shù)對應(yīng)的頭文件。
內(nèi)核程序中與RT-FIFO相關(guān)的函數(shù)有:
rtf_create():創(chuàng)建RT-FIFO。
rtf_get():從RT-FIFO讀數(shù)據(jù)。
rtf_put():向RT-FIFO寫數(shù)據(jù)。
rtf_create_handler():建立響應(yīng)RT-FIFO變化的子程序。
內(nèi)核程序中與實時任務(wù)線程相關(guān)的函數(shù)有:
pthread_create():創(chuàng)建實時任務(wù)對應(yīng)的線程。
pthread_wait_np():將當前線程掛起,直至下一個周期線程。
pthread_makeperiodic_np():設(shè)置線程的屬性并啟動線程。
pthread_suspend_np():將本線程無限期掛起,即終止任務(wù)。
在調(diào)試階段,需要將有bug的模塊卸載。該項工作由cleanup_module()來完成。在卸載模塊時將rtf1、rf2和rtf3撤銷,并撤銷實時任務(wù)Task1。
3.2 應(yīng)用程序
Linux下應(yīng)用程序gatect1_app工作流程見圖4,其程序用Linux下的C語言開發(fā)。集中監(jiān)控站和維護站的程序在Windows下用Visual C++開發(fā)。其中有幾點要說明:
·RT-FIFO被Linux視為字符設(shè)備,因此可以通過調(diào)用open("/dev/rtf1",O_RDONLY)來獲得rtf1的指針,rtf2的rtf3類似。獲得指針后通過read和write函數(shù)實現(xiàn)對RT_FIFO的讀寫操作。
·程序中調(diào)用select函數(shù)檢查RT_FIFO是否忙,以避免讀RT_FIFO時出現(xiàn)阻塞現(xiàn)象。
·LCD顯示模塊MGLS-240128內(nèi)置智能控制器,只需將待顯示的數(shù)據(jù)送控制器的顯示緩沖區(qū)就能實現(xiàn)顯示功能,數(shù)據(jù)顯示不會占用系統(tǒng)過多的時間。
·系統(tǒng)數(shù)據(jù)傳輸和維護通過網(wǎng)絡(luò)數(shù)據(jù)庫來實現(xiàn)。數(shù)據(jù)庫采用客戶端/服務(wù)器模塊,將LCU、集中維護站設(shè)置為客戶端,將集中監(jiān)控站設(shè)置為服務(wù)器。本系統(tǒng)采用基于TCP/IP協(xié)議的MYSQL數(shù)據(jù)庫為實現(xiàn)數(shù)據(jù)管理。MYSQL是一個多用戶、多線程的SQL數(shù)據(jù)庫服務(wù)器,由客戶端/服務(wù)器結(jié)構(gòu)來實現(xiàn)。它由一個服務(wù)器守護程序mysqld和不同的客戶程序及庫組成,使用TCP/IP把多個客戶(LCU等)連接到一個服務(wù)器(集中監(jiān)控站)上。在運行前應(yīng)將主機名、IP地址等設(shè)備就緒,在LCU的應(yīng)用程序gatectl_app中應(yīng)包含MYSQL.h頭文件,其中有MYSQL的API函數(shù)的具體實現(xiàn)。在用戶空間,C語言程序通過這些API函數(shù)訪問遠程的數(shù)據(jù)庫服務(wù)器。
·數(shù)據(jù)的預(yù)處理:為防止被干擾的數(shù)據(jù)上傳到服務(wù)器,應(yīng)用程序?qū)?shù)據(jù)進行濾波,再對數(shù)據(jù)進行分類。經(jīng)過預(yù)處理后的數(shù)據(jù)才可以送數(shù)據(jù)緩沖區(qū),通過API函數(shù)向數(shù)據(jù)庫服務(wù)器上傳。
4 應(yīng)用效果
目前該系統(tǒng)正在試驗室運行。從連續(xù)運轉(zhuǎn)的情況看,控制實時性和可靠性均達到了設(shè)計要求,網(wǎng)絡(luò)和數(shù)據(jù)庫均運行正常,可見本設(shè)計思路是可行的。下一步將設(shè)放到工業(yè)現(xiàn)場進一步驗證。RTLinux實現(xiàn)實時控制功能并與Linux有機結(jié)合,這一設(shè)計思路既滿足了實時控制系統(tǒng)對響應(yīng)的快速性、時間的精確性和控制的可預(yù)測性的要求,又充分發(fā)揮了Linux對網(wǎng)絡(luò)和數(shù)據(jù)庫的支持功能。將RTLinux引入控制領(lǐng)域,拓寬了Linux的應(yīng)用范圍,必須加速工業(yè)控制的信息化。
版權(quán)聲明:本文內(nèi)容由互聯(lián)網(wǎng)用戶自發(fā)貢獻,該文觀點僅代表作者本人。本站僅提供信息存儲空間服務(wù),不擁有所有權(quán),不承擔相關(guān)法律責任。如發(fā)現(xiàn)本站有涉嫌抄襲侵權(quán)/違法違規(guī)的內(nèi)容, 請發(fā)送郵件至 yyfangchan@163.com (舉報時請帶上具體的網(wǎng)址) 舉報,一經(jīng)查實,本站將立刻刪除