時(shí)間:2008-09-01 10:54:00來(lái)源:ronggang
圖2 MPC860的中斷處理流程[/align]
4 中斷處理應(yīng)用編程
實(shí)際中斷處理應(yīng)用編程主要包括兩部分工作:一是編寫中斷初始化程序,進(jìn)行初始化和中斷連接;二是編寫中斷服務(wù)程序完成中斷服務(wù)功能。
4.1 編寫中斷初始化程序
中斷初始化程序的首要工作是初始化中斷寄存器,包括打開SIU中斷屏蔽寄存器(SIMASK,SIU Interrupt Mask)對(duì)應(yīng)的屏蔽位,使能外部中斷。如果是SIU的外部中斷,應(yīng)該初始化SIU中斷邊沿/電平寄存器(SIEL,SIU Interrupt Edge/Level Register),以設(shè)定中斷是下降沿觸發(fā)還是低電平觸發(fā)。如果使用了CPM中斷,還應(yīng)該初始化CPM中斷配置寄存器(CICR,CPM Interrupt Configuration Register)和CPM中斷屏蔽寄存器(CIMR,CPM Interrupt Mask Register),以設(shè)定CPM在SIU中斷控制器中的中斷優(yōu)先級(jí),以及其內(nèi)部的最高優(yōu)先級(jí)中斷源。對(duì)于子塊可屏蔽中斷源,還應(yīng)該打開對(duì)應(yīng)的事件屏蔽寄存器。
中斷初始化程序還必須把SIU中斷服務(wù)程序放到正確的位置。在VxWorks環(huán)境下調(diào)用intConnect()函數(shù)即將中斷服務(wù)程序與外部中斷源連接起來(lái)。
4.2 編寫中斷服務(wù)程序
由于中斷服務(wù)程序不是在規(guī)則的任務(wù)上下文中運(yùn)行(它沒有任務(wù)控制塊,中斷處理程序共享一個(gè)堆棧等),中斷服務(wù)程序必須遵守一個(gè)基本約束:它必須不能調(diào)用可能直接或間接導(dǎo)致阻塞的函數(shù)。例如,ISR不能獲取信號(hào)量,但可以釋放信號(hào)量;ISR不能直接或間接調(diào)用內(nèi)存操作函數(shù)malloc()和free();ISR不能通過(guò)VxWorks驅(qū)動(dòng)來(lái)執(zhí)行I/O操作,但VxWorks的管道驅(qū)動(dòng)程序是一個(gè)例外;ISR也不能使用printf()進(jìn)行打印,VxWorks專門為ISR打印信息設(shè)計(jì)了一個(gè)記錄功能,允許向系統(tǒng)輸出平臺(tái)打印文本信息。具體能被中斷服務(wù)程序調(diào)用的函數(shù)請(qǐng)參見參考文獻(xiàn)[5]。
由于中斷服務(wù)通常涉及到任務(wù)級(jí)代碼,并且中斷服務(wù)程序受到種種限制,VxWorks支持在中斷級(jí)運(yùn)行的中斷服務(wù)程序直接與一般任務(wù)進(jìn)行通信。其通信機(jī)制有共享數(shù)據(jù)結(jié)構(gòu)、信號(hào)量、消息隊(duì)列、管道、信號(hào)等。其中,信號(hào)量是VxWorks提高中斷服務(wù)程序與任務(wù)的合作性能的最好機(jī)制。理想情況下,一個(gè)中斷服務(wù)程序僅僅調(diào)用semGive()函數(shù)釋放一個(gè)信號(hào)量,發(fā)起一個(gè)任務(wù)來(lái)完成必要的處理[6]。
5 中斷處理應(yīng)用實(shí)例
下面給出VxWorks下MPC860的中斷處理的應(yīng)用實(shí)例。我們?cè)谀稠?xiàng)目開發(fā)中利用中斷通知MPC860讀取外圍器件FIFO的數(shù)據(jù)。相關(guān)的硬件連接如圖3所示。
[align=center]
圖3 中斷處理應(yīng)用實(shí)例的硬件連接[/align]
其中,F(xiàn)IFO采用IDT公司的IDT72V3650芯片,F(xiàn)PGA采用ALTERA公司APEX20K系列的EP20K1500E器件。FIFO芯片提供了五個(gè)空滿狀態(tài)標(biāo)志位,可根據(jù)不同的實(shí)際需求方便的通過(guò)FPGA編程向MPC860的IRQ2和IRQ1分別發(fā)送開始讀信號(hào)和停止讀信號(hào),從而在時(shí)鐘的驅(qū)動(dòng)下讀取FIFO數(shù)據(jù)。
中斷應(yīng)用程序的主要實(shí)現(xiàn)函數(shù)的代碼及注釋如下:
/***初始化,中斷連接***/
void tRdFifoInit(void)
?。?
*SIEL(RegBase)|=0x28000000; /*設(shè)置外部中斷源IRQ1、IRQ2下降沿觸發(fā)*/
startSem=semBCreate(SEM_Q_FIFO,SEM_EMPTY);
/*?jiǎng)?chuàng)建二進(jìn)制信號(hào)量,以便實(shí)現(xiàn)中斷與任務(wù)的通信*/
intConnect(IV_IRQ1,(VOIDFUNCPTR)stopRdISR,NULL);
intConnect(IV_IRQ2,(VOIDFUNCPTR)startRdISR,NULL);
/*分別將外部中斷源與中斷服務(wù)程序相連接*/
intEnable(IVEC_TO_INUM(IV_IRQ1)); intEnable(IVEC_TO_INUM(IV_IRQ2));
/*分別使能外部中斷*/
?。?
/***開始讀FIFO中斷服務(wù)程序***/
void startRdISR(void)
?。?
semGive(startSem);
/*釋放信號(hào)量*/
RdFlag=1;
/*設(shè)置讀FIFO數(shù)據(jù)標(biāo)志*/
?。猄IPEND(RegBase)=0x08000000;
/*清除外部中斷源IRQ2的狀態(tài)位*/
?。?
/***停止讀FIFO中斷服務(wù)程序***/
void stopRdISR(void)
?。?
RdFlag=0;
/*禁止讀FIFO數(shù)據(jù)標(biāo)志*/
?。猄IPEND(RegBase)=0x20000000;
/*清除外部中斷源IRQ1的狀態(tài)位*/
}
/***按照中斷通知讀取FIFO數(shù)據(jù)***/
void tRdFifo(void)
?。?
while(1)
{
semTake(startSem,WAIT_FOREVER);
/*獲取信號(hào)量*/
while(RdFlag)
?。?
…/*讀取FIFO數(shù)據(jù)*/
?。?
?。?
?。?
6 結(jié)束語(yǔ)
嵌入式實(shí)時(shí)操作系統(tǒng)VxWorks提供的中斷處理機(jī)制中斷延遲小、用戶編程方便,被廣泛應(yīng)用于實(shí)際工程中。MPC860的中斷體系結(jié)構(gòu)是理解如PowerPC系列芯片等雙處理器體系結(jié)構(gòu)的中斷處理機(jī)制的難點(diǎn)。本文在詳細(xì)分析兩者中斷處理機(jī)制的基礎(chǔ)上介紹了具體的開發(fā)實(shí)例。該實(shí)例已在TornadoⅡ 2.0.2版本上調(diào)試通過(guò),并成功應(yīng)用于某型網(wǎng)絡(luò)設(shè)備開發(fā)中。
參考文獻(xiàn)
[1] 陳智育,溫彥軍,陳琪. VxWorks程序開發(fā)實(shí)踐[M]. 北京:人民郵電出版社,2004.
[2] 羅國(guó)慶. VxWorks與嵌入式軟件開發(fā)[M]. 北京:機(jī)械工業(yè)出版社,2003.
[3] Wind River. VxWorks Reference Manual: Libraries[OL].
[4] Motorola. MPC860 PowerQuicc Family User’s Manual[Z]. Motorola, 2003.
[5] Wind River. VxWorks Programmer’s Guide 5.5[OL].
[6] 孔祥營(yíng),柏桂枝. 嵌入式實(shí)時(shí)操作系統(tǒng)VxWorks及其開發(fā)環(huán)境Tornado[M]. 北京中國(guó)電力出版社,2002.
標(biāo)簽:
傳動(dòng)網(wǎng)版權(quán)與免責(zé)聲明:凡本網(wǎng)注明[來(lái)源:傳動(dòng)網(wǎng)]的所有文字、圖片、音視和視頻文件,版權(quán)均為傳動(dòng)網(wǎng)(www.surachana.com)獨(dú)家所有。如需轉(zhuǎn)載請(qǐng)與0755-82949061聯(lián)系。任何媒體、網(wǎng)站或個(gè)人轉(zhuǎn)載使用時(shí)須注明來(lái)源“傳動(dòng)網(wǎng)”,違反者本網(wǎng)將追究其法律責(zé)任。
本網(wǎng)轉(zhuǎn)載并注明其他來(lái)源的稿件,均來(lái)自互聯(lián)網(wǎng)或業(yè)內(nèi)投稿人士,版權(quán)屬于原版權(quán)人。轉(zhuǎn)載請(qǐng)保留稿件來(lái)源及作者,禁止擅自篡改,違者自負(fù)版權(quán)法律責(zé)任。
產(chǎn)品新聞
更多>2025-10-31
勇梅機(jī)械液壓閘門給煤機(jī)的優(yōu)點(diǎn)
2025-10-22
2025-10-17
2025-10-11
「一體機(jī)性價(jià)比王者」NK290M普及型數(shù)控...
2025-10-09
耐磨管道機(jī)器人檢測(cè)電纜CCTV,水下管道...
2025-09-23
推薦專題
更多>