機(jī)電之家資源網(wǎng)
單片機(jī)首頁(yè)|單片機(jī)基礎(chǔ)|單片機(jī)應(yīng)用|單片機(jī)開(kāi)發(fā)|單片機(jī)文案|軟件資料下載|音響制作|電路圖下載 |嵌入式開(kāi)發(fā)
培訓(xùn)信息
贊助商
ARM的三種中斷調(diào)試方法的探討
ARM的三種中斷調(diào)試方法的探討
 更新時(shí)間:2009-6-4 10:14:23  點(diǎn)擊數(shù):1
【字體: 字體顏色

摘  要:以典型ARM芯片S3C4510B為對(duì)象,結(jié)合應(yīng)用環(huán)境,介紹其技術(shù)特點(diǎn)和開(kāi)發(fā)流程,重點(diǎn)闡述有關(guān)應(yīng)用程序的中斷調(diào)試中動(dòng)態(tài)處理方法及其3種運(yùn)行方式,即程序在SDRAM中運(yùn)行、程序在FLASH中運(yùn)行、程序從FLASH中調(diào)到SDRAM中運(yùn)行的中斷調(diào)試方法。
關(guān)鍵詞:ARM  S3C4510B  中斷  動(dòng)態(tài)  3種運(yùn)行方式

1 概述
sung公司的S3C4510B是基于以太網(wǎng)應(yīng)用系統(tǒng)的高性?xún)r(jià)比16/32位RISC微控制器,內(nèi)含一個(gè)由ARM公司設(shè)計(jì)的16/32位ARM7TDMI RISC處理器核,ARM7TDMI為低功耗、高性能的16/32核,是目前應(yīng)用廣泛的一款A(yù)RM芯片。作者通過(guò)對(duì)這款典型芯片在網(wǎng)絡(luò)通訊應(yīng)用項(xiàng)目的開(kāi)發(fā),掌握了ARM的技術(shù)特點(diǎn)和開(kāi)發(fā)流程,并且在中斷調(diào)試方面獲得了一些高級(jí)技巧。
2 硬件特點(diǎn)
S3C4510B的主要特性描述如下:
    支持ROM/SRAM、FLASH、DRAM和外部I/O以8/16/32位的方式操作;
    100M/10Mbps IEEE802.3標(biāo)準(zhǔn)兼容、提供MII和7線(xiàn)制10Mbps接口Ethernet控制器;
    2個(gè)10Mbps HDLC (High-Level Data Link Control) 高層數(shù)據(jù)鏈路協(xié)議通道; 
    2個(gè)可工作于DMA方式或中斷方式的UART模塊,支持紅外發(fā)送和接收;
    IIC接口(主控模式);
    2個(gè)可編程32位定時(shí)器;18個(gè)可編程I/O口;2個(gè)DMA通道;
    21個(gè)中斷源,包括4個(gè)外部中斷源;
    外部時(shí)鐘可由片內(nèi)PLL倍頻;工作頻率最高為50MHz。發(fā)板800
3 調(diào)試環(huán)境
開(kāi)發(fā)環(huán)境包括Embest IDE集成開(kāi)發(fā)環(huán)境,Embest 仿真器,基于ARM(S3C4510B)的電路板。
參照嵌入式軟件的開(kāi)發(fā)流程,如圖1所示。在整個(gè)流程中,用戶(hù)首先需要建立工程并對(duì)工程做初步的配置,包括配置處理器和配置調(diào)試設(shè)備。編輯工程文件,包括自己編寫(xiě)的匯編和C語(yǔ)言源程序,還有工程編譯時(shí)需要編寫(xiě)的鏈接腳本文件,調(diào)試過(guò)程中需要編寫(xiě)存儲(chǔ)區(qū)映像文件和命令腳本文件,以及上電復(fù)位時(shí)的程序運(yùn)行入口的啟動(dòng)程序文件。 
 
圖1 開(kāi)發(fā)流程
對(duì)后四種文件的理解很重要,其作用解釋如下。
(1)鏈接腳本文件:在程序編譯時(shí)起作用。該文件描述代碼鏈接定位的有關(guān)信息,包括代碼段,數(shù)據(jù)段,地址段等,鏈接器必須使用該文件對(duì)整個(gè)系統(tǒng)的代碼做正確的定位。在SDRAM中調(diào)試程序、在FLASH中調(diào)試或固化后運(yùn)行的鏈接腳本文件應(yīng)加以區(qū)分。(在IDE開(kāi)發(fā)環(huán)境中使用擴(kuò)展名*.ld)
(2)命令腳本文件:在SDRAM中調(diào)試程序時(shí)起作用。在集成環(huán)境與目標(biāo)連接時(shí)、軟件調(diào)試過(guò)程中以及目標(biāo)板復(fù)位后,有時(shí)需要集成環(huán)境自動(dòng)完成一些特定的操作,比如復(fù)位目標(biāo)板、清除看門(mén)狗、屏蔽中斷寄存器、存儲(chǔ)區(qū)映射等。這些操作可以通過(guò)執(zhí)行一組命令序列來(lái)完成,保存一組命令序列的文本文件稱(chēng)為命令腳本文件(在IDE開(kāi)發(fā)環(huán)境中使用擴(kuò)展名*.cs)。
(3)存儲(chǔ)區(qū)映像文件:在SDRAM中調(diào)試程序時(shí)起作用。在軟件調(diào)試過(guò)程中訪問(wèn)非法存儲(chǔ)區(qū)在部分處理器和目標(biāo)板上會(huì)產(chǎn)生異常,如果異常沒(méi)有處理,則會(huì)導(dǎo)致軟件調(diào)試過(guò)程無(wú)法繼續(xù),為了防止以上問(wèn)題并調(diào)整仿真器訪問(wèn)速度以達(dá)到最合適的水平,提供這樣一種用于描述各個(gè)存儲(chǔ)區(qū)性質(zhì)的文件叫存儲(chǔ)區(qū)映像文件(在IDE開(kāi)發(fā)環(huán)境中使用擴(kuò)展名*.map)。
在程序的調(diào)試過(guò)程中可以選擇使用存儲(chǔ)區(qū)映像文件*.map和命令腳本文件*. cs配合程序的調(diào)試。
(4)啟動(dòng)文件:它主要是完成一些和硬件相關(guān)的初始化的工作,為應(yīng)用程序做準(zhǔn)備。一般,啟動(dòng)代碼的第一步是設(shè)置中斷和異常向量;第二步是完成系統(tǒng)啟動(dòng)所必須的寄存器配置;第三步設(shè)置看門(mén)狗及用戶(hù)設(shè)計(jì)的部分外圍電路;第四步是配置系統(tǒng)所使用的存儲(chǔ)區(qū)分配地址空間;第五步是變量初始化;第六步是為處理器的每個(gè)工作模式設(shè)置棧指針;最后一步是進(jìn)入高級(jí)語(yǔ)言入口函數(shù)(Main函數(shù))。4 中斷程序設(shè)計(jì)
S3C4510B支持21個(gè)中斷源,其中包括4個(gè)外部中斷源,基于優(yōu)先級(jí)的中斷處理,可以識(shí)別兩種類(lèi)型的中斷:正常中斷請(qǐng)求(IRQ)和快速中斷請(qǐng)求(FIQ)。
S3C4510B的中斷處理模式是一種典型的中斷處理方法。當(dāng)系統(tǒng)產(chǎn)生中斷的時(shí)候,系統(tǒng)將中斷懸掛寄存器(Interrupt Pending Register)中對(duì)應(yīng)中斷的標(biāo)志位置位,然后跳轉(zhuǎn)到位于0x18處的IRQ或0x1C處的FIQ中斷處理函數(shù)中,該中斷函數(shù)通過(guò)讀取中斷懸掛寄存器來(lái)判斷中斷源,并根據(jù)優(yōu)先級(jí)關(guān)系再跳轉(zhuǎn)到對(duì)應(yīng)中斷源的處理代碼內(nèi)。
對(duì)此,一般采取的中斷處理方法是在0x18處的IRQ或0x1C處的FIQ中斷處理函數(shù)中進(jìn)行獲取中斷源、清除中斷掛起標(biāo)志、進(jìn)入用戶(hù)中斷函數(shù)的相關(guān)程序。顯然,在用戶(hù)程序復(fù)雜,中斷源較多的情況下,采用此法必須進(jìn)行中斷源的判斷和散轉(zhuǎn)處理,這樣會(huì)影響中斷處理的響應(yīng)時(shí)間和程序性能。
在我們的應(yīng)用開(kāi)發(fā)過(guò)程中,在中斷調(diào)試方面采用了類(lèi)似矢量中斷動(dòng)態(tài)處理方式,讓中斷對(duì)應(yīng)的確定地址代碼調(diào)轉(zhuǎn)到RAM的固定地址處,定義一個(gè)函數(shù)指針指向該固定地址,就可以隨時(shí)通過(guò)替換RAM固定地址處的代碼,實(shí)現(xiàn)動(dòng)態(tài)改變中斷處理函數(shù)。
具體方法是:
(1)將中斷源函數(shù)指針定義在RAM中相對(duì)的固定地址,建立中斷矢量表;
void SetInterrupt (U32 vector, void (*handler)())
{
      InterruptHandlers[vector] = handler;
}
(2)在程序中,調(diào)用具體某中斷源的中斷處理函數(shù);
如:  SetInterrupt(IIC_INT,IICWriteIsr); 
/* 聲明IIC中斷處理函數(shù),其中IIC_INT為 IIC中斷源序號(hào),IICWriteIsr為 IIC的寫(xiě)中斷處理函數(shù) */
(3)在0x18處的IRQ或0x1C處的FIQ中斷入口函數(shù)中,獲取中斷源、清除中斷掛起標(biāo)志、通過(guò)已定義的中斷源函數(shù)指針進(jìn)入用戶(hù)具體某中斷處理程序。 
void ISR_IrqHandler(void)
{
    IntOffSet = (unsigned int)INTOFFSET;
    Clear_PendingBit(IntOffSet>>2) ;
(*InterruptHandlers[IntOffSet>>2])();
// 調(diào)用具體某中斷處理程序
}
采用動(dòng)態(tài)的中斷處理方法,在中斷源較多的情況下,中斷響應(yīng)時(shí)間和程序性能得到優(yōu)化。另外,在調(diào)試方面,此處理方法具有便于跟蹤調(diào)試的優(yōu)點(diǎn),并且根據(jù)需要,可以方便變換中斷處理函數(shù)。


5 中斷調(diào)試
歡迎訪問(wèn)無(wú)由電子開(kāi)發(fā)網(wǎng)技術(shù)文章 在線(xiàn)閱讀 在線(xiàn)商城
軟件調(diào)試可以在SDRAM中或FLASH中進(jìn)行。在SDRAM中,讀寫(xiě)方便,訪問(wèn)速度快。一般軟件調(diào)試應(yīng)在RAM中完成,但當(dāng)RAM空間小于FLASH程序空間,程序只能在FLASH運(yùn)行和調(diào)試時(shí),或者用戶(hù)希望了解程序在FLASH中實(shí)際運(yùn)行情況時(shí),就可以在FLASH中進(jìn)行程序調(diào)試。
進(jìn)行中斷調(diào)試時(shí),應(yīng)注意中斷入口位于SDRAM中或FLASH中0x18或0x1c地址,鏈接腳本文件必須使整個(gè)系統(tǒng)的代碼正確定位于0x0起始處,但SDRAM或FLASH對(duì)應(yīng)的鏈接腳本文件及工程配置注意區(qū)別。
(1)程序在SDRAM中運(yùn)行
在SDRAM中調(diào)試,使用SDRAM對(duì)應(yīng)的鏈接腳本文件。調(diào)試過(guò)程需要以下幾步:編譯、鏈接工程;連接仿真器和電路板;下載程序(在IDE開(kāi)發(fā)環(huán)境中使用擴(kuò)展名*.elf);調(diào)試。
下載程序前必須啟動(dòng)命令腳本文件完成前述的一些特定的操作,命令腳本文件的啟動(dòng)在連接仿真器時(shí)自動(dòng)進(jìn)行,其中存儲(chǔ)區(qū)映射應(yīng)與程序在SDRAM中運(yùn)行時(shí)相同,保證整個(gè)系統(tǒng)的代碼正確定位于0x0起始處。下載程序的起始地址也為0x0,下載成功后便可進(jìn)行調(diào)試工作。
(2)程序在FLASH中運(yùn)行
在FLASH中調(diào)試,使用FLASH對(duì)應(yīng)的鏈接腳本文件。調(diào)試過(guò)程需要以下幾步:編譯、鏈接工程;連接仿真器和電路板;程序格式轉(zhuǎn)換(*.elf轉(zhuǎn)換為*.bin);固化*.bin程序;調(diào)試。
連接仿真器后不需要下載程序,存儲(chǔ)區(qū)映射由本身工程中啟動(dòng)文件運(yùn)行完成,不需要命令腳本文件。在本環(huán)境調(diào)試過(guò)程中,可以設(shè)置兩個(gè)硬件斷點(diǎn)。
(3)程序從FLASH中調(diào)到SDRAM中運(yùn)行
在某些應(yīng)用場(chǎng)合,強(qiáng)調(diào)程序運(yùn)行速度的情況下,希望程序在SDRAM中運(yùn)行,這樣就需要將FLASH中存儲(chǔ)的程序,在系統(tǒng)上電后搬運(yùn)到SDRAM某空間
位置,然后自動(dòng)運(yùn)行。這種所謂的Bootloader技術(shù),在DSP系統(tǒng)中常被采用。
調(diào)試過(guò)程分兩步:
(1)首先將用戶(hù)程序在SDRAM中調(diào)試通過(guò),然后將*.bin文件固化到FLASH某一非0扇區(qū)地址空間;
(2)將自己編寫(xiě)的Bootloader搬運(yùn)程序調(diào)試通過(guò)并將Bootloader.bin文件固化到FLASH的 0扇區(qū)地址空間,搬運(yùn)程序在系統(tǒng)上電后,將(1)中FLASH某一非0扇區(qū)地址空間存儲(chǔ)的程序,搬運(yùn)到在SDRAM調(diào)試中同樣的空間位置,實(shí)現(xiàn)程序在SDRAM中運(yùn)行的目的。
另外注意,因?yàn)橛脩?hù)實(shí)際的程序中斷入口必須位于FLASH的0x18或0x1c地址,所以Bootloader搬運(yùn)程序還應(yīng)具有中斷入口的跳轉(zhuǎn)功能,即把PC指針由此轉(zhuǎn)向處于SDRAM空間的中斷程序入口表,就是整個(gè)用戶(hù)程序被搬運(yùn)到SDRAM的那一位置。 
如:LDR    PC,    =HandleIRQ
// HandleIRQ位于SDRAM空間中斷程序入口表
在本項(xiàng)目開(kāi)發(fā)過(guò)程中,由于系統(tǒng)實(shí)時(shí)性要求高,定時(shí)器中斷達(dá)到微秒級(jí),程序在FLASH中運(yùn)行時(shí),速度不能達(dá)到系統(tǒng)要求,故采用把程序從FLASH中調(diào)到SDRAM中運(yùn)行的方式,問(wèn)題得到解決。


6 結(jié)束語(yǔ)
上述有關(guān)中斷動(dòng)態(tài)處理方法及其3種運(yùn)行方式,是基于S3C4510B系統(tǒng)調(diào)試的一點(diǎn)小結(jié),在ARM技術(shù)的實(shí)際應(yīng)用中具有典型性和代表性,讀者可根據(jù)自己的應(yīng)用場(chǎng)合及應(yīng)用目的參考指正。

參考文獻(xiàn)
1、ARM Limited. ARM7TDMI(Rev4) Technical Reference Manual
2、李駒光. ARM應(yīng)用系統(tǒng)開(kāi)發(fā)詳解──基于S3C4510B的系統(tǒng)設(shè)計(jì)[M].北京:清華大學(xué)出版社,2003
3、馬忠梅. ARM嵌入式處理器結(jié)構(gòu)與應(yīng)用基礎(chǔ)[M].北京:北京航空航天大學(xué)出版社,2003

<!--插入廣告JS代碼-->
  • 上一篇: 使用免費(fèi)的SDCC C編譯器開(kāi)發(fā)DS89C420/430/440/450系列微控制器固件
  • 下一篇: SSD1906顯示控制器與AT91RM9200的接口技術(shù)
  • 發(fā)表評(píng)論   告訴好友   打印此文  收藏此頁(yè)  關(guān)閉窗口  返回頂部
    熱點(diǎn)文章
     
    推薦文章
     
    相關(guān)文章
    網(wǎng)友評(píng)論:(只顯示最新5條。)
    關(guān)于我們 | 聯(lián)系我們 | 廣告合作 | 付款方式 | 使用幫助 | 機(jī)電之家 | 會(huì)員助手 | 免費(fèi)鏈接

    點(diǎn)擊這里給我發(fā)消息66821730(技術(shù)支持)點(diǎn)擊這里給我發(fā)消息66821730(廣告投放) 點(diǎn)擊這里給我發(fā)消息41031197(編輯) 點(diǎn)擊這里給我發(fā)消息58733127(審核)
    本站提供的機(jī)電設(shè)備,機(jī)電供求等信息由機(jī)電企業(yè)自行提供,該企業(yè)負(fù)責(zé)信息內(nèi)容的真實(shí)性、準(zhǔn)確性和合法性。
    機(jī)電之家對(duì)此不承擔(dān)任何保證責(zé)任,有侵犯您利益的地方請(qǐng)聯(lián)系機(jī)電之家,機(jī)電之家將及時(shí)作出處理。
    Copyright 2007 機(jī)電之家 Inc All Rights Reserved.機(jī)電之家-由機(jī)電一體化網(wǎng)更名-聲明
    電話(huà):0571-87774297 傳真:0571-87774298
    杭州濱興科技有限公司提供技術(shù)支持

    主辦:杭州市高新區(qū)(濱江)機(jī)電一體化學(xué)會(huì)
    中國(guó)行業(yè)電子商務(wù)100強(qiáng)網(wǎng)站

    網(wǎng)站經(jīng)營(yíng)許可證:浙B2-20080178-1