国产毛片a精品毛-国产毛片黄片-国产毛片久久国产-国产毛片久久精品-青娱乐极品在线-青娱乐精品

MPC860的中斷處理技術研究

發(fā)布時間:2010-11-16 10:44    發(fā)布者:eetech
關鍵詞: MPC860 , 處理 , 中斷
MPC860是網絡通信設備中應用最廣的一款RISC嵌入式處理器。本文介紹MPC860的中斷體系結果及中斷發(fā)生后服務程序的處理流程;以SMC1的接收中斷為例,闡述在設計操作系統(tǒng)管理的條件下,中斷初始化程序和中斷服務程序的編寫。  

Motorola公司推出的MPC860 PowerQUICC是目前在通信領域應用得非常廣泛的一款嵌入式處理器,被譽為MC68360 PowerQUICC在網絡和數(shù)據(jù)通信領域的新一代產品。與MC68360相比,MPC860 PowerQUICC在各方面的性能,包括器件的適應性、外部擴展能力和芯片集成度等都得到了提高。  

MPC860PowerQUICC(簡稱MPC860)內部集成了兩個處理單元。一個處理單元是嵌入的PowerPC核(PowerPCCore)。它是主處理單元(CPU),包括Cache和內存管理單元;是一個RISC芯片,通常編譯后的程序指令都是由它執(zhí)行。另一個是通信處理模塊CPM(Communications Processor Module),內部也集成了一個RISC微處理器,對各種常用的通信模塊進行管理。通信處理模塊內部集成有4個串行通信控制器SCC(Serial Communication Controller)、2個串行管理控制器SMC(Serial Management Channels)、1個串行外圍接口電路SPI(Serial Peripheral Interface)和1個I2C(Inter-Integrtaed Circuit)接口。兩個處理單元之間的數(shù)據(jù)通常使用DMA方式傳送。由于CPM分擔了嵌入式PowerPC核的外圍工作任務,這種雙處理器體系結構極大減輕了CPU的工作負荷,而且功耗也要低于傳統(tǒng)體系結構的處理器。另外,在MPC860中還有一個系統(tǒng)接口單元SIU(System Interface Unit),主要功能是提供內外總線的接口及一些其它功能(如SIU中斷)的管理等。  

由于MPC860的體系與通用的X86體系結構有很大的不同,其中斷體系結構和處理機制也有自己的特點,使得它的中斷管理及中斷服務程序成為系統(tǒng)移植和應用中的難點。本文將對MPC860的中斷體系結構和中斷應用程序的編寫進行介紹。





1 MPC860中斷體系結構  

與MPC860的兩個處理單元相對應,對于CPM產生的中斷,也有兩級處理過程。整個MPC860的中斷體系結構如圖1所示。  

從圖1可以看出,MPC860的整個中斷體系結構有3個模塊:PowerPC核、SIU中斷控制器SIU IC(SIU Interrupt Controller)和CPM中斷控制器CPMIC(CPM Interrupt Controller)。  

PowerPC Core是指令執(zhí)行單元,使用異常(Exception)的目的就是要打斷它的正常執(zhí)行,使它轉入處理緊急事件的異常處理程序中執(zhí)行。對于每一類異常,異常發(fā)生后PowerPC跳轉執(zhí)行的位置是不同的。這些不同的位置組成了一個表——異常向量表。不同類型的異常在異常向量表中的偏移量不同。例如系統(tǒng)重啟異常在異常向量表中的偏移量是0x100,機器自檢異常的偏移量是0x200,而外部中斷在異常向量表中的偏移量是0x500等等。  

SIU中斷控制器負責管理8個外部中斷源(IRQ0~7)和8個內部中斷源(Leve10~7),結構如圖2的示。其中IRQ0一般用作不可屏蔽中斷,通過NMI向PowerPC內核請求中斷,其余15個通過IREQ請求中斷。對于8個內部中斷源,包括周期性的中斷時鐘(PIT)、實時時鐘(RTC)、PCMCIA以及CPM等,用戶可以通過對寄存器的操作,把它們設定為Leve10~7中的任何一級。這16個中斷源之間的優(yōu)先級SIU IC已經設定了。其中IRQ0的優(yōu)先級最高,Leve10其次,依此類推,Leve17的優(yōu)先級最低。





在SIU IC進行SIU中斷處理時,有幾個重要的寄存器與之相關的。它們是中斷懸掛寄存器SIPEND、中斷屏蔽寄存器SIMASK和中斷向量寄存器SIVEC。  

CPM中斷控制器是對SIU中斷控制器的下一級擴展。它管理通信處理模塊的各個中斷源,并向SIU IC申請中斷處理,其結構如圖3所示。CPIC接收12個外部中斷源和17個內部中斷源的中斷請求,經過屏蔽和判優(yōu)處理后,把中斷請求送往SIU中斷控制器。通過設置CPIC的配置寄存器,CPM在SIU IC中的優(yōu)先級可以是Leve10~7中的任何一級,并且所有的CPM中斷源都將以這個優(yōu)先級向SIU申請中斷。在CPM IC內部,它也為每個中斷源分配了一個中斷向量號,并且分配了不同的優(yōu)先級,還可以編程設定哪個中斷源為最高優(yōu)先級。  

在CPM的中斷源中,如果一個中斷源有多個子功能可以產生中斷請求,并且每一項子功能的中斷請求都可以屏蔽,那么這個中斷源稱為子塊可屏蔽中斷。例如,對串行管理通道SMI(Serial Management Channels),每一個SMC有一個事件寄存器SMCE和一個屏蔽寄存器SMCM,具體定義如圖4所示。用戶可以通過對SMCM進行編程,屏蔽掉某項子功能的中斷請求功能。假如用戶要使用中斷接收功能,就應該置位SMCM的RX位以打開接收中斷。在中斷服務程序中還要讀取SMCE,以判斷是哪個子功能產生的中斷。如果SMCE的RX位已被置位,就表明產生了接收中斷,應進入接收中斷處理函數(shù)。  

CPM IC中提供了一些可編程寄存器。通過對這些寄存器進行設置,可以設定CPM IC的工作方式。這些寄存器分別是CPM中斷配置寄存器CICR、CPM中斷屏蔽寄存器CIMR、CPM中斷向量寄存器CIVR、CPM中斷是掛寄存器CIPR和CPM中斷服務寄存器CISR。  

2 編寫MPC860中斷應用程序  

編寫MPC860中斷應用程序主要有兩個方面的內容:一個是中斷初始化程序,另一個是中斷服務程序。




中斷初始化程序首要的工作是初始化中斷寄存器,包括打開SIMASK對應的屏蔽位、使能外部中斷。如果要使用SIU的外部中斷,應該初始化SIEL寄存器,以設定中斷是低電平觸發(fā)還是低跳變觸發(fā)。如果使用了CPM中斷,還應該初始化CICR、CIMR寄存器,以設定CPM在SIU IC中的中斷優(yōu)先級,以及它自身內部的最高優(yōu)先級中斷源。對于子塊可屏蔽中斷源,還應該打開對應的事件屏蔽寄存器。只有在初始化這些寄存器后,中斷源產生的中斷才得到響應。  

對于外部中斷,PowerPC內核接收到中斷請求信號后,會轉入異常向量表中的外部中斷偏移地址處(0x500)執(zhí)行。這一段最大長度為256個字節(jié)的代碼,也可以說是SIU中斷的服務程序。在中斷初始化程序中,還必須把SIU中斷服務程序放到正確的位置。  

中斷服務程序是中斷產生后自動跳轉執(zhí)行的程序,它對中斷進行處理。對于其中比較復雜的CPM中斷,它有兩級處理程序,分別是SIU中斷服務程序和CPM中斷服務程序。中斷服務程序的處理流程如圖5所示。  

在SIU中斷服務程序中,要讀取產生SIU中斷有中斷向量號,根據(jù)中斷向量號判斷中斷源,然后跳轉到對各個中斷源處理的服務程序中執(zhí)行。如果讀到的中斷向量號對應的是CPM,要轉入CPM中斷服務程序中執(zhí)行。CPM又有29個中斷源,每個中斷源對應不同CPM中斷向量號。在CPM中斷服務程序中,也要讀取CPM中斷向量號,然后根據(jù)中斷向量號調用對應的中斷處理程序。這樣,所有的CPM中斷源,在進入中斷處理程序之前,都經過了SIU IC和CPM IC兩級處理。另外,由于MPC860是RISC處理器,它有許多通用寄存器,在中斷服務程序中應該把影響到的寄存器壓入到堆棧中,在退出中斷服務程序之前再恢復。




3 實例應用  

下面以CPM的SMC1用作串口,使用中斷接收數(shù)據(jù)為例,說明MPC860的中斷應用程序編寫過程。  

本程序的主函數(shù)是main()。它調用smc_init()進行smc初始化,然后循環(huán)等待接收數(shù)據(jù)。smc_init()是初始化函數(shù)。它設定smc1的工作方式,初始化接收描述字,然后初始化中斷寄存器,并且把SIU中斷服務程序拷貝到異常向量表的0x500處。Initbrn()是SIU中斷服務程序,也就是外部中斷產生后的入口程序。它讀取SIU的中斷向量號,如果是CPM中斷,就調用CPM中斷處理程序CPMHandler(),在這個程序中再讀取CPM中斷向量號,如果是CPM中斷,就調用CPM中斷處理程序CPMHandler(),在這個程序中再讀取CPM中斷向量號,處理SMC1發(fā)送過來的數(shù)據(jù)。  

另外,函數(shù)getimmr()的作用是用匯編指令得到芯片雙端口寄存器的基址,getmsr()的作用是讀取機器狀態(tài)字(MSR)的值,getevt()利用MSR的值得到的異常向量表的基址。整個程序代碼如下:  

#include "pc860.h" /*MPC860寄存器宏定義頭文件*/  
struct dprbase *pdpr; /*指向雙端口內存基址的地址*/  
void smc_init() /*初始化SMC函數(shù)*/  
{ void intbrn(); /*定義SIU中斷服務程序*/  
int *ptrs,*ptrd; /*SIU中斷服務程序搬移的源和目的地址*/  
char intlv1=4;/*CPM中斷級別*/  
pdpr=(struct dprbase *)(getimmr() %26;amp; 0xFFFF0000); /*得到內部雙端口寄存器的基址*/  
…… /*初始化SMC的寄存器和工作參數(shù),如工作模式,波特率等*/  
…… /*初始化串口數(shù)據(jù)收發(fā)緩沖區(qū)的描述字,注意要把接收緩沖區(qū)描述字RxBD的中斷位置為1*/  
ptrs=(int *)intbrn; /*需要搬移的SIU中斷服務程序源地址*/  
ptrd=(int *)(getevt()+0x500);/*目標地址*/  
do /*把SIU中斷服務程序搬移到外部中斷入口處*/  
*ptrd++=*ptrs;  
while(*ptrs++!=0x4c000064);/*0x4c000064是SIU中斷服務程序返回指令RFI指令的二進制代碼*/  
pdpr->CICR.IRL2=(unsigned)(intlv1);/*設定CPM的中斷級別為4*/  
pdpr->CICR.HP0_HP4=0x1F; /*設定PC15為最高優(yōu)先級中斷*/  
pdpr->CIMR.SMC1=1;/*打開CPM IC的SMC1中斷屏蔽位*/  
pdpr->SIMASK.ASTRUCT.LVM4=1;/*打開SIU IC的CPM中斷屏蔽位*/  
pdpr->CICR.IEN=1;/*使能CPM中斷*/  
pdpr->SMCE1=0xFF;/*清除SMC1的事件寄存器*/  
pimm->SMCM1=1;/*打開子模塊可屏蔽的接收中斷*/  
asm("mtspr 80,0");/*使能中斷*/  
…… /*使能SMC1的發(fā)送和接收功能*/  
}  
main() /*主函數(shù)*/  
{ smc_init() /*初始化SMC1*/  
while(1==1);/*等待接收*/  
}  
#pragma interrupt intbrn /*SIU中斷服務程序  
void intbrn()  
{void CPMHandler();/*定義CPM中斷服務程序*/  
asm("stwu r9,-4(r1");/*把GRR9壓入堆棧*/  
switch(pdpr->SIVEC.IC)/*讀取SIU的中斷向量號,轉入相應處理程序*/  
{case 0x24;/*為CPM對應的中斷向量號*/  
asm("mfspr r9,8");/*把LR壓入堆棧*/  
asm("mfspr r9,8");/*把LR壓入堆棧*/  
asm("mfspr r9,8");/*把LR壓入堆棧*/  
asm("stwu r9,-4(r1)");  
asm("bla CPMHandler")/*調用CPM中斷處理函數(shù)*/  
asm("lwz r9,0(r1)");/*把LR從堆棧中彈出*/  
asm("addi r1,r1,4");/*恢復堆棧指針*/  
asm("mtspr8,r9");  
break;  
default:;  
}  
asm("lwz r9,0(r1); /*把GPR9從堆棧中彈出/*  
asm("addi r1,r1,4");/*恢復堆棧指針*/  
}  
void CPMHandler() /*CPM中斷處理程序*/  
{unsigned v1;  
pdpr->CIVR.IACK=1;/*把CIVR的IACK位置為1,以讀取CIVR中的中斷向量號*/  
v1=pdpr->CIVR.VN;/*讀取中斷向量號*/  
switch(pimm->CIVR.VN)/*根據(jù)中斷向量號進行處理*/  
{case 4: /*SMC1的中斷向量*/  
…… /*SMC1中斷處理程序,對接收到的數(shù)據(jù)進行處理*/  
pimm->CISR=1<<(31-11);/*清除IN-SRVCE位*/  
break;  
default:;  
}  
}  
getimmr() /*得到雙端口寄存器的基址*/  
{ asm("mfspr3,638");  
}  
getevt() /*得到中斷入口的基址*/  
{ if((getmsr() %26;amp; 0x40)==0)/*如果MSR.IP等于0*/  
return(0); /*中斷入口在低位*/  
else  
return(0xFFF00000);/*中斷入口在高位*/  
}  
getmsr() /*得到機器狀態(tài)寄存器MSR的值*/  
{ asm(mfmsr 3; /*把MSR的值讀到r3中*/  
}




4 結論  

以上討論的中斷應用程序的編寫是在沒有操作系統(tǒng)的情況下進行的;如果有操作系統(tǒng),對中斷管理的初始化會在操作系統(tǒng)初始化時完成,用戶只需調用API函數(shù)安裝中斷服務程序即可。但即使這樣,理解上述的中斷處理過程,對編寫MPC860中斷服務程序也是有必要的。  
從以上討論可以看出,與MPC860帶有兩個處理器的體系結構相適應的,MPC860中斷機制采用了兩級中斷處理,其優(yōu)點是能最大限度地擴展外部中斷源的數(shù)量,并可以加快對CPM中斷的響應速度。編寫MPC860中斷處理程序的關鍵在兩個方面:一個是在初始化時應該設置好各個中斷寄存器,并且把SIU中斷服務程序放到正確的位置;另一個是在中斷服務程序的處理過程中,要根據(jù)讀得的SIU和CPM中斷向量號進行相應處理。
本文地址:http://m.qingdxww.cn/thread-39542-1-1.html     【打印本頁】

本站部分文章為轉載或網友發(fā)布,目的在于傳遞和分享信息,并不代表本網贊同其觀點和對其真實性負責;文章版權歸原作者及原出處所有,如涉及作品內容、版權和其它問題,我們將根據(jù)著作權人的要求,第一時間更正或刪除。
您需要登錄后才可以發(fā)表評論 登錄 | 立即注冊

廠商推薦

  • Microchip視頻專區(qū)
  • 使用SAM-IoT Wx v2開發(fā)板演示AWS IoT Core應用程序
  • 使用Harmony3加速TCP/IP應用的開發(fā)培訓教程
  • 集成高級模擬外設的PIC18F-Q71家族介紹培訓教程
  • 探索PIC16F13145 MCU系列——快速概覽
  • 貿澤電子(Mouser)專區(qū)

相關視頻

關于我們  -  服務條款  -  使用指南  -  站點地圖  -  友情鏈接  -  聯(lián)系我們
電子工程網 © 版權所有   京ICP備16069177號 | 京公網安備11010502021702
快速回復 返回頂部 返回列表
主站蜘蛛池模板: 四虎国产精品永久在线 | 午夜精品福利在线 | 99视频精品全部免费观看 | 99视频精品全部在线播放 | 亚洲欧美高清在线 | 久久精品免视着国产成人 | 欧美草逼网 | 亚洲一区欧美在线 | 午夜精品久久影院蜜桃 | 久久久久久免费精品视频 | 青青国产成人精品视频 | 办公室被老板调教bd | 国产理论在线 | 日韩三级一区二区三区 | 人体蜈蚣2彩色版 | α片免费 | 久久国内视频 | 日本色图在线 | 亚洲情a成黄在线观看动 | 五月天婷婷视频在线观看 | 青青青国产精品视频 | 99视频免费在线 | 精品乱人伦一区二区三区 | 99视频观看 | 男人天堂资源站 | 美女天天射 | 老司机久久精品视频 | 欧美一区二区三区在线 | 就色干综合| 综合久久久久久久 | 鬼骨场在线观看 | 国产毛片精品 | 久久久青青草 | 五月天中文在线 | 四虎影视在线 | 夜夜夜网站 | 日韩特级毛片免费观看视频 | 4hu影院永久在线播放 | 国产精品欧美一区二区三区不卡 | 四虎网址在线 | 亚洲黄视频 |