0 引言
隨著嵌入式系統(tǒng)開發(fā)的普及和深入,在更加復(fù)雜的應(yīng)用中傳統(tǒng)軟件開發(fā)手段難以滿足需求,嵌入式操作系統(tǒng)在開發(fā)中扮演著越來越重要的角色,已經(jīng)被廣泛應(yīng)用于手機、移動計算機設(shè)備、網(wǎng)絡(luò)設(shè)備和工控仿真等領(lǐng)域。嵌入式操作系統(tǒng)μC/OS-II源碼是公開的,而且它是可移植、可固化、可裁減及可剝奪型的多任務(wù)實時內(nèi)核,可用于各類8位、16位和32位單片機和DSP,目前得到廣泛應(yīng)用。本文給出一種數(shù)字微波設(shè)備監(jiān)控系統(tǒng)的設(shè)計,該系統(tǒng)引入μC/OS-II之后,系統(tǒng)的開發(fā)效率得到提高,整個系統(tǒng)的健壯性得到增強,文中對軟件設(shè)計應(yīng)用中遇到的關(guān)鍵問題作了深入討論并給出了相應(yīng)的解決方案。
1 數(shù)字微波設(shè)備監(jiān)控系統(tǒng)的設(shè)計
微波通信是一種利用微波傳輸信息的通信手段,數(shù)字微波采用數(shù)字信號處理技術(shù),利用微波信道傳輸數(shù)字信號,以下給出一種數(shù)字微波通信系統(tǒng)中監(jiān)控系統(tǒng)的設(shè)計[1]。由兩個端站組成一條微波鏈路,每個端站含一個室內(nèi)單元IDU(In-Door Unit)、一個室外單元ODU(Out-Door Unit)、連接室內(nèi)單元和室外單元的同軸電纜、以及微波天線。本文主要討論IDU監(jiān)控部分CPU相關(guān)內(nèi)容的軟硬件設(shè)計。
1.1 微波監(jiān)控IDU部分硬件設(shè)計
IDU組成框圖如圖1所示,主要由業(yè)務(wù)接口、輔助業(yè)務(wù)、復(fù)分接、微波幀分復(fù)接、中頻調(diào)制解調(diào)、中頻分合路器、電源、CPU及相關(guān)接口組成。
μC/OS-II在數(shù)字微波監(jiān)控系統(tǒng)中的應(yīng)用" src="http://files.chinaaet.com/images/20110812/2f46bc7c-6007-414b-a155-31ce42776952.jpg" />
主業(yè)務(wù)數(shù)據(jù)通過業(yè)務(wù)接口電路復(fù)接后,與公務(wù)、輔助數(shù)據(jù)信號等一起進入微波幀復(fù)接模塊,復(fù)接成微波幀信號,由調(diào)制模塊完成調(diào)制,通過中頻分合路器送往ODU。從ODU送來的中頻信號經(jīng)過中頻分合路器送往解調(diào)模塊解調(diào)出數(shù)據(jù),送到微波幀分接電路,分接出主業(yè)務(wù)、公務(wù)以及輔助數(shù)據(jù)信息,通過主業(yè)務(wù)接口電路分接出各支路主業(yè)務(wù)數(shù)據(jù)。CPU對所傳輸?shù)臉I(yè)務(wù)數(shù)據(jù)進行監(jiān)視和控制,監(jiān)視所傳數(shù)據(jù)的狀態(tài)、性能等信息,可設(shè)置所傳數(shù)據(jù)的各種參數(shù),通過輔助業(yè)務(wù)接口可提取和插入各種控制信息。
CPU采用PHILIPS公司的32位ARM芯片LPC2214,該芯片接口豐富,硬件設(shè)計時CPU相關(guān)接口完成功能如下:輸入接口提供按鍵設(shè)置掃描電路,輸出接口通過液晶、告警燈及蜂鳴器輸出信息,通過I2C接口CPU可實現(xiàn)對串行E2PROM、時鐘芯片的存取,CPU本身提供SPI接口,通過該接口實現(xiàn)本端與遠端控制信息的交換。串行接口提供一種監(jiān)控手段,可實現(xiàn)CPU與PC機的通信,完成狀態(tài)讀取和各種命令的設(shè)置,以太網(wǎng)接口通過擴展以太網(wǎng)接口芯片實現(xiàn),通過以太網(wǎng)接口建立與網(wǎng)管中心的通信,可實現(xiàn)網(wǎng)絡(luò)化的管理。OOK(On/Off—Keying)調(diào)制解調(diào)電路完成IDU與ODU之間的通信,通過該電路,IDU可對ODU進行設(shè)置發(fā)功率、收發(fā)頻率、監(jiān)視ODU的工作狀態(tài)等。
1.2 軟件結(jié)構(gòu)
軟件總體分為應(yīng)用程序和μC/OS-II兩部分,應(yīng)用程序是用戶代碼部分,采用C語言編寫,完成對整個系統(tǒng)的監(jiān)控;μC/OS-II為一種嵌入式多任務(wù)實時操作系統(tǒng),其大部分程序使用C語言編寫,還有一小部分和處理器密切相關(guān)的代碼使用匯編語言編寫,μC/OS-II包括了三部分,即μC/OS-II核心代碼、配置代碼和移植代碼。
其中,核心代碼:包括10個C程序文件和一個頭文件,主要實現(xiàn)了系統(tǒng)調(diào)度、任務(wù)管理、內(nèi)存管理、信號量、消息郵箱和消息隊列等系統(tǒng)功能,而這些功能的實現(xiàn)與處理器類型無關(guān)。
配置代碼:包括2個頭文件,用于裁剪和配置μC/OS-II,這部分代碼根據(jù)用戶的實際需求來配置μC/OS-II系統(tǒng)。
移植代碼:這部分主要包括1個匯編文件、1個C程序文件和一個頭文件,這部分根據(jù)具體的處理器移植μC/OS-II系統(tǒng)的需要修改,它和處理器關(guān)系密切。
2 μC/OS-II在微波監(jiān)控系統(tǒng)中的應(yīng)用
2.1 應(yīng)用程序中任務(wù)的設(shè)計與劃分
根據(jù)實際的需要,應(yīng)用軟件劃分為7個任務(wù):液晶顯示、按鍵接收和告警、時間標(biāo)志處理、遠端信息處理、數(shù)據(jù)處理、串口任務(wù)處理,如圖2所示。
圖2 應(yīng)用程序中任務(wù)的劃分
(1)Task_LCD_OP:主要是處理菜單的顯示,根據(jù)不同的菜單顯示設(shè)備的相關(guān)信息,并且完成將設(shè)置數(shù)據(jù)保存到公共變量中。
(2)Task_KEY:主要完成外部按鍵信號的掃描,按照不同的按鍵轉(zhuǎn)換為不同的編碼,并把其值保存到公共變量中。
(3)Task_TIME_FLG:實現(xiàn)設(shè)置時間標(biāo)志,以使其它任務(wù)完成定時任務(wù),因為有許多的定時任務(wù),所以設(shè)立了一個單獨的任務(wù)來設(shè)置或取消時間標(biāo)志。
(4)Task_SPI_OP:通過SPI接口完成遠端信息交換處理以及數(shù)據(jù)鏈路各接口環(huán)回等設(shè)置。
(5)Task_DATA_OP:主要完成網(wǎng)絡(luò)數(shù)據(jù)管理、AD轉(zhuǎn)換、公務(wù)的控制,控制微波接口、時鐘芯片的設(shè)置和讀取,完成誤碼率的計算以及對串行E2PEOM存儲芯片數(shù)據(jù)的存取。
(6)Task_COMM1:主要是完成出串口與其它設(shè)備間通信數(shù)據(jù)的收發(fā)。
(7)Task_ODUCOMM0:主要是IDU和ODU設(shè)備的通信。
2.2 任務(wù)的創(chuàng)建
經(jīng)過分析和設(shè)計之后,就可以使用μC/OS- II所提供的函數(shù)創(chuàng)建任務(wù),這里給出了如何創(chuàng)建液晶顯示任務(wù)的實例,其它任務(wù)的創(chuàng)建與之類似,其過程如下:
OSTaskCreate (Task_LCD_OP,(void *)0, &LCDopreate[TaskStkLengh - 1],8);
Task_LCD_OP是要創(chuàng)建的任務(wù);(void *)0是傳遞給任務(wù)的參數(shù),因為這里所創(chuàng)建的任務(wù)沒有參數(shù),所以其值為0;&LCDopreate[TaskStkLengh - 1]是分配給任務(wù)的堆棧,這在程序中是事先定義好的,最后一個數(shù)字8是分配給該任務(wù)的優(yōu)先級。
2.4 任務(wù)優(yōu)先級的劃分
為了使整個系統(tǒng)的實時性能夠得到滿足,所以要以任務(wù)的緊迫性、關(guān)鍵性、頻繁性和中斷的重要性等為依據(jù),對不同的任務(wù)安排不同優(yōu)先級別。在系統(tǒng)優(yōu)先級的分配上,μC/OS-II系統(tǒng)級保留了0和1,用戶程序任務(wù)優(yōu)先級從2開始,最低優(yōu)先級定義為12。
在該監(jiān)控系統(tǒng)中,任務(wù)不同,對實時性要求也不同,通過定時任務(wù)來控制。定時任務(wù)劃分為20ms到5s多個時間級別,在同一個任務(wù)中可以再定時地處理一些事務(wù)。其中,單獨設(shè)置了一個任務(wù)Task_TIME_FLG來處理這些時間等級的劃分和管理,由于它的運行涉及到其它任務(wù)的時間標(biāo)志,是一個關(guān)鍵任務(wù),所以必須將其運行優(yōu)先級設(shè)置為用戶程序的最高級別。系統(tǒng)中除了對設(shè)備進行設(shè)置外,其余時間主要通過串行接口進行信息交互,也是較為重要和緊迫的,這一工作由串口1來承擔(dān),所以在設(shè)置Task_COMM1的優(yōu)先級次之;其次是Task_ODUCOMM0;Task_DATA_OP數(shù)據(jù)操作任務(wù)對實時性要求不高,級別隨之降低;Task_SPI_OP任務(wù)因其數(shù)據(jù)量小,故不是緊迫任務(wù);Task_KEY按鍵任務(wù)、Task_LCD_OP液晶顯示是實現(xiàn)人機交互的,所以實時性要求也比較低。
從以上分析可以把任務(wù)的優(yōu)先級進行如下分配:Task_TIME_FLG為2,Task_COMM1為3,Task_ODUCOMM0為4,Task_DATA_OP為5,Task_SPI_OP為6,Task_KEY為7,Task_LCD_OP為8。
2.5 任務(wù)的調(diào)度
μC/OS-II調(diào)度的依據(jù)是任務(wù)就緒隊列表,系統(tǒng)從處于就緒隊列的任務(wù)中選擇一個優(yōu)先級最高的來運行,它可以管理多達64個任務(wù)。對于多任務(wù)的管理,μC/OS- II 是通過調(diào)度器完成。其中任務(wù)級的調(diào)度是由函數(shù)OSSched()完成, 而中斷級的調(diào)度是由函數(shù)OSIntExiT()完成。
本系統(tǒng)的任務(wù)中,Task_TIME_FLG時間標(biāo)志處理任務(wù)優(yōu)先級最高,運行也最頻繁,它和其它任務(wù)切換是屬于普通的任務(wù)切換,而Task_COMM1和Task_ODUCOMM0的任務(wù)切換是屬于中斷級的切換,只有在發(fā)生中斷時才切換,正常運行時和普通任務(wù)的切換方式一樣。其余任務(wù)的切換都作為普通切換方式處理。在任務(wù)切換過程中如果當(dāng)前任務(wù)需要延時判斷,為保證其它任務(wù)的正常運行,可通過調(diào)用函數(shù)OSTimeDly(2)掛起當(dāng)前任務(wù),其中鍵顯部分有三級菜單,每一級菜單又有許多選項,為了提高按鍵掃描的實時性,在進入每一級菜單后必須調(diào)用該函數(shù)掛起當(dāng)前任務(wù),并掃描有無按鍵,如有則執(zhí)行對應(yīng)處理程序,沒有按鍵則把自己掛起,直到有按鍵方可退出。μC/OS-II如此處理,程序不會死等,按鍵和菜單顯示配合很協(xié)調(diào),只要有按鍵就能得到及時處理。
2.6 中斷的設(shè)置與使用
在ARM7體系的CPU中,最多可以有32個中斷源。對每個具體的中斷源,可以將其定義為快速FIQ中斷,使其具有最高的優(yōu)先級;也可以定義為向量IRQ中斷,使其具有中等優(yōu)先級,但向量IRQ的總數(shù)不能超過16個。μC/OS-II本身使用一個定時中斷源作為系統(tǒng)節(jié)拍中斷。
μC/OS-II響應(yīng)中斷的過程:當(dāng)系統(tǒng)接收到中斷請求后,并且CPU處于中斷開放狀態(tài),系統(tǒng)就會終止當(dāng)前運行的任務(wù),按照中斷向量的指向運行中斷服務(wù)子程序;當(dāng)中斷運行結(jié)束后,系統(tǒng)就會返回到被中止的任務(wù)繼續(xù)運行,或者轉(zhuǎn)向運行另一個更高優(yōu)先級的就緒任務(wù)。
本系統(tǒng)中使用了兩個定時中斷源、兩個串口中斷源、一個I2C中斷源。μC/OS-II中斷的設(shè)置和初始化由target.c中的TargetInit函數(shù)完成,通過該函數(shù)實現(xiàn)了串口、I2C和定時中斷的初始化設(shè)置。其中VICInit實現(xiàn)過程如下,將中斷服務(wù)子程序的地址寫到相應(yīng)的中斷向量寄存器(VICVectAddrx),并從相應(yīng)的中斷向量控制寄存器(VICVectCntlx)選中相應(yīng)的中斷,將其啟用。當(dāng)CPU接收到中斷請求就能找到對應(yīng)中斷服務(wù)程序的地址,并轉(zhuǎn)到中斷服務(wù)程序去運行。
2.7 堆棧的設(shè)置與使用
堆棧是依據(jù)“后進先出(LIFO)”原則組織的連續(xù)存儲空間。為滿足任務(wù)切換、響應(yīng)中斷以及存儲任務(wù)私有數(shù)據(jù)的需要,每個任務(wù)都配有自己的堆棧。
由于LPC2214的片內(nèi)Flash是256KB,片內(nèi)RAM是16KB,根據(jù)需要CPU沒有擴展外部閃存,故要求代碼精練,RAM分配一定要合理。尤其是在液晶顯示任務(wù)中,由于顯示的菜單項目較多,因此任務(wù)之間切換增加了RAM的需求。如果每個任務(wù)堆棧開辟過小,任務(wù)切換時就會出現(xiàn)私有數(shù)據(jù)丟失,堆棧溢出直至程序運行出錯;反之堆棧設(shè)置過大,就會使內(nèi)存RAM空間緊張,因此設(shè)置堆棧空間必須適中。本系統(tǒng)中開始設(shè)置顯示任務(wù)堆棧大小為64個字,調(diào)試運行中發(fā)現(xiàn)進入多級菜單時會出現(xiàn)程序死鎖的現(xiàn)象,擴大對應(yīng)任務(wù)堆??臻g問題就得到解決。
3 軟件的調(diào)試環(huán)境與下載
該系統(tǒng)需要建立ADS1.2集成仿真環(huán)境,使用了廣州周立功單片機發(fā)展有限公司提供的專用工程模板。如果硬件沒有擴展外部存儲器,就使用LPC2100的工程模板;否則使用LPC2200的工程模板。在調(diào)試過程中選用DebugInFLASH模式燒寫調(diào)試;軟硬件調(diào)試完成,可選用RelInFlash模式燒寫,后一種燒寫方式會加密芯片,使之無法二次燒寫;如果加密之后需要重新燒寫芯片,就必須使用ISP進行解密之后方可燒寫,調(diào)試程序時一定要注意這點。
4 結(jié)束語
μC/OS-II應(yīng)用于數(shù)字微波監(jiān)控系統(tǒng)軟件開發(fā)之后,系統(tǒng)的軟件結(jié)構(gòu)更加簡潔實用,系統(tǒng)的實時性和穩(wěn)定性得到提高,設(shè)備在實際應(yīng)用中表現(xiàn)穩(wěn)定可靠,并取得一定的經(jīng)濟效益,μC/OS-II在嵌入式系統(tǒng)中具有廣泛的應(yīng)用推廣價值。