《電子技術應用》
您所在的位置:首頁 > 嵌入式技術 > 設計應用 > TMS320VC5410 DSP的DSP/BIOS擴展尋址的實現
TMS320VC5410 DSP的DSP/BIOS擴展尋址的實現
唐 冰 周 勇 駱云志
摘要: TMS320VC5410的程序空間通常被限制在64K地址空間內,當應用程序超出64K時,則需增加目標系統存儲區和附加邏輯,實現對系統的擴展。介紹了如何配置及使用DSP/BIOS接口來實現擴展尋址功能,分析了API函數調用和中斷觸發過程,并以DSP并行自舉引導方式實現程序的脫離仿真運行。
Abstract:
Key words :

    摘  要: TMS320VC5410的程序空間通常被限制在64K地址空間內,當應用程序超出64K時,則需增加目標系統存儲區和附加邏輯,實現對系統的擴展。介紹了如何配置及使用DSP/BIOS" title="DSP/BIOS">DSP/BIOS接口來實現擴展尋址功能,分析了API函數調用和中斷觸發過程,并以DSP并行自舉" title="自舉">自舉引導方式實現程序的脫離仿真運行。 

    關鍵詞: DSP/BIOS  擴展尋址  API  并行自舉引導

 

1 DSP/BIOS 接口

    DSP/BIOS接口提供了基本的運行服務,如應用程序實時分析功能、時鐘周期函數、I/O模塊、優先級的任務調度等。DSP/BIOS接口提供支持匯編語言和C語言的API接口函數,這些API函數絕大部分都是用匯編語言實現的,因此匯編語言可以直接調用API,而C語言調用API則要通過DSP/BIOS的C封裝器。應用程序通過調用API函數來使用DSP/BIOS接口,如軟件中斷、背景線程和中斷服務程序" title="中斷服務程序">中斷服務程序等都可以調用DSP/BIOS的函數。當DSP/BIOS要調用用戶的C語言函數時,則要通過函數鏈接器,如圖1所示。 

 

 

2 擴展程序空間

    TMS320VC5410的16位地址空間被劃分為兩塊,低地址塊定義為公共區(或未映射區),高地址塊定義為映射區(或擴展區)。這兩塊的地址由目標系統的外部寄存器和存儲區決定。值得注意的是,TMS320VC5410的數據區沒有擴展存儲區。 

    用戶可以在映射區上定義多個物理存儲區,它們覆蓋整個映射區,但彼此間不重疊。當使用存儲區的擴展頁時,內部16位地址空間被擴展為32位的地址進行尋址,高16位代表擴展頁的數目,低16位代表局部的16位地址。如使用擴展程序映射存儲器(XPC)存放擴展頁碼,則XPC存放在數據空間地址為0x1E的位置,它的值要與.CMD鏈接文件中定義的擴展頁碼保持一致。圖2所示的是一個擴展3頁的程序區結構圖。公共區的范圍是0x0000~0x7FFF;映射區的范圍是0x8000~0xFFFF;映射區為第一頁,XPC要為0才能訪問該區;映射地址空間存放兩個擴展頁,擴展程序映射寄存器限定了映射地址,使得每個擴展頁的每個單元具有唯一的地址。當訪問擴展頁時,映射區將被覆蓋。 

 

 

    TMS320VC5410的DSP/BIOS不僅支持64K程序頁內的“近”訪問模式,而且支持擴展程序的“遠”訪問模式,只需設置DSP/BIOS的屬性即可實現擴展程序的“遠”訪問。要注意的是,匯編語言寫的API只能在PAGE0頁調用,而C語言寫的API可以在任何頁面調用。 

3 中 斷

    當中斷產生時,DSP的內部結構機制只能保存低16位頁內的局部地址,而擴展尋址時程序地址需要23位,這就意味著調用和返回時將超出64K(16位地址)的范圍,因此必須考慮怎樣保存和恢復擴展地址。解決的方法是用中斷服務程序(ISR)保存XPC的值,確保能正確計算中斷向量,為此中斷向量表" title="向量表">向量表必須放在公共區或映射區的64K程序頁面上。當DSP/BIOS在公共區上時,ISR可以放在任何位置;如果不在公共區上,則ISR必須放在PAGE0上。 

    當OVLY=0時,為了能保證中斷正確執行,必須在每一個頁面上都要有中斷向量表的拷貝。當OVLY=1時,只需在公共頁面上(如0x7F80)作一份中斷向量表的拷貝就可以了。 

4 程序實例

    下面通過一個簡單的例子介紹DSP/BIOS如何實現程序地址的擴展。本例中有三個軟中斷:時鐘中斷PRD_POST_SWI,每100ms觸發SWI_PAGE1(或SWI_PAGE2)一次;SWI_PAGE1,完成置XF高;SWI_PAGE2,完成置XF低。三個軟中斷執行的函數分別放在程序空間的不同頁面上,即PRD_Post_SWI放在公共頁面上(XPC=0),Page1Func和Page2Func分別放在擴展程序頁面1和2上(XPC為1和2)。 

    #include “testfarcfg.h” 

    #pragma CODE_SECTION(Page1Func,“.FarPage1”) 

    #pragma CODE_SECTION(Page2Func,“.FarPage2”) 

    int pagenumber; 

    void main(void)         {pagenumber=0;} 

    void Page2Func (void)   {asm(“rsbx xf”);pagenumber=0;} 

    void Page1Func (void)   {asm(“ssbx xf”);pagenumber=1;} 

    void PRD_Post_SWI(void) 

    { if(pagenumber)  SWI_post(&SWI_PAGE2); 

    else   SWI_post(&SWI_PAGE1); 

    } 

5 DSP/BIOS的配置 

    如要把DSP/BIOS的程序映射到擴展程序空間,需要對其進行配置,步驟如下: 

    (1)建立一個新配置文件。啟動仿真軟件(Code Composer Studio),建立testfar.pjt工程,通過File中的New ——DSP/BIOS Config創建配置文件,選用sd54.cdb(54X EVM)配置。 

    (2)添加軟件中斷。右鍵打開軟件中斷管理器(Software Interrupt Manager),選擇Insert SWI,創建SWI_PAGE1,屬性配置為:function:_Page1Func;priority:2。用同樣的方法創建function為_Page2Func的SWI_PAGE2。右鍵打開定時器功能管理器(Periodic Function Manager),選擇Insert PRD,創建PRD_POST_SWI,屬性配置為:period(ticks):50,function:_ PRD_Post_SWI,mode:continuous。 

    (3)設置OVLY位為1。打開System中的Global Settings的屬性頁,在PMST(6~0)項中填入使第5位為1的值,如MP=1,填入0x60。 

    (4)指定“遠”調用模式。在Global Settings屬性頁面的Function Call Model選項中選擇far,使全局變量Callmodel設置為far。 

    (5)在公共區中重新分配中斷向量表。雙擊System中的MEM,右鍵打開VECT 的屬性頁,在base項中填入新的基地址,如0x7F80。 

    (6)配置擴展程序地址段。對于54X EVM評估板,已經有了兩個擴展程序段EPROG0和EPROG1(如果沒有的話,則需添加這兩個段,選擇Insert MEM,添加兩個擴展程序段,重命名為EPROG0和EPROG1)。EPROG0屬性為base:0x8000,len:0x4000,勾去create a heap in this memory選項,space:code;EPROG1與EPROG0的屬性不同之處為base:0x18000。加入一個新的擴展程序段EPROG2,屬性為base:0x28000,len:0x4000,space:code。 

    (7)將目標代碼鏈接到擴展程序段。pragma偽指令告訴編譯器的預處理器如何處理函數,語法為#pragma CODE_SECTION(Page1Func,“.FarPage1”),在名為“.FarPage1”的段中分配Page1Func的程序空間。這樣,目標代碼Page1Func就被鏈接到.FarPage1段的區域。 

    (8)創建一個新的鏈接命令文件(testfar.cmd)。其主要功能是把testfarcfg.cmd鏈接進去,并且告訴鏈接器把不同目標函數放在不同的擴展頁面上。如: 

    -ltestfarcfg.cmd 

    SECTIONS 

    { .FarPage1:{} > EPROG1 PAGE 0 

      .FarPage2:{} > EPROG2 PAGE 0 

    } 

    (9)保存配置文件為testfar.cdb,然后將testfar.cdb,testfar.cmd、testfar.c文件加入工程中。 

    (10)配置編譯器和匯編器支持遠模式代碼。打開菜單Project中的Build Options窗體,選擇Compiler屬性頁,點擊Category中的Advanced選項,勾選Use Far Calls (-mf)(C548 and higher)。此選項指定產生遠調用代碼模式。 

    (11)在調試器內描述并激活擴展尋址功能。仿真器的調試軟件需要激活擴展尋址功能才能支持長指令的執行和擴展存儲區的讀/寫,方便地對使用擴展尋址的程序進行調試。所以使用通用擴展函數GEL_XMDef()來定義映射寄存器(如XPC)和映射擴展空間的首地址。如當OVLY=1時,擴展程序區從0x8000開始,7位XPC放置在數據空間的0x1E單元中,并把下面兩條語句加入到C5410.gel文件的C5410_Init()函數中。 

    GEL_XMDef(0,0x1e,1,0x8000,0x7f);  

    //0:映射程序空間;0x1e:XPC的地址;1:XPC 在數據空間中; 

    //0x8000:映射首地址;0x7f:XPC的大小,128頁; 

    GEL_XMOn(); //使能擴展地址映射 

6 DSP/BIOS函數調用和中斷觸發過程

6.1 DSP/BIOS函數調用過程

    DSP/BIOS API 調用過程如圖3中的實線所示。具體過程如下: 

 

 

    (1)產生PRD_F_swi,短調用C語言封裝器的PRD_F_swi (),XPC=0。 

    (2)C語言封裝器觸發PRD_POST_SWI時鐘軟中斷,然后檢測SWI_PAGE1,產生執行DSP/BIOS調度表的分支。 

    (3)DSP/BIOS調度表保存當前PRD_POST_SWI上下文信息,調用函數鏈接器以觸發SWI_PAGE1。 

    (4)函數鏈接器遠調用SWI_PAGE1,執行相應的函數(Page1Func),XPC=1。 

    (5)SWI_PAGE1執行結束,遠返回函數鏈接器。 

    (6)函數鏈接器又返回到DSP/BIOS調度表。 

    (7)DSP/BIO調度表恢復PRD_POST_SWI信息,返回到C語言封裝器。 

    (8)執行上述(1)和(2),第(3)步觸發SWI_PAGE2,函數鏈接器遠調用SWI_PAGE2,執行函數(Page2Func),XPC=2。 

    (9)SWI_PAGE2執行結束,遠返回函數鏈接器,然后順序執行上述的第(6)和(7)。 

6.2 中斷觸發過程

    中斷觸發過程如圖3中的虛線所示。 

    (1)PRD_F_swi發生,CPU把當前的16位PC指針壓入堆棧,在中斷向量表中取指令。 

    (2)中斷向量程序把當前的XPC壓入堆棧,產生一個配置中斷服務程序的分支指令,執行中斷服務程序,XPC=0。 

    (3)中斷服務程序調用HWI_enter,觸發PRD_POST_SWI軟中斷,接著調用HWI_exit,HWI_exit檢測到SWI_PAGE1準備好,開始調用DSP/BIOS調度表。 

    (4)DSP/BIOS調度表保存當前的上下文信息,調用函數鏈接器以觸發SWI_PAGE1。 

    (5)函數鏈接器遠調用SWI_PAGE1,執行相應的函數,此時XPC=1。SWI_PAGE1執行完,遠返回調用函數鏈接器,再到DSP/BIOS調度表,調度表恢復上下文信息,把程序指針交給PRD_POST_SWI軟中斷。PRD_POST_SWI結束。 

    (6)執行上述(1)、(2)步后,第(3)步檢測到SWI_PAGE2準備好,第(4)步觸發SWI_PAGE2,第(5)步函數鏈接器遠調用SWI_PAGE2,XPC=2,順序執行下去,直到PRD_POST_SWI結束。 

7 并行自舉引導" title="自舉引導">自舉引導的實現

    TMS320VC5410上電復位后,檢查到DSP處于MC(微計算機)工作方式,從片內ROM的0FF80h起執行程序。0FF80h地址存放的是中斷向量表,它實為一條分支轉移指令(BD 0F800h),使程序跳轉至0F800h執行自舉引導程序(Bootlooader)。并行自舉引導是DSP自舉引導常用的一種方式,Bootlooader首先從地址為0FFFFh的I/O口讀取自舉表首地址的內容,如果此內容不符合8位或16位的引導方式,就從地址為0FFFFh的數據存儲器讀取,進行8位或16位并行自舉引導。若要完成自舉引導功能,必須建立正確的自舉表。 

    自舉表的內容不僅包括欲加載的各段代碼,而且包括各段代碼的長度、各代碼段存放的目標地址、程序入口地址等信息。自舉表可由hex500格式轉換器自動生成。hex500是一個通用程序,它將公共目標文件格式—COFF文件轉換成各種FLASH(或EPROM)的編程格式。因此,在使用hex500工具之前,首先把testfar.pjt進行編譯、鏈接,生成COFF格式的testfar.out文件,然后再通過設置適當的選項生成用戶所要求的自舉表,如轉換文件的格式、外部數據存儲器的字寬等選項。把testfar.out轉換為testfar.hex文件后,再使用C語言編寫一個轉換程序,將hex文件轉換為DSP燒寫FLASH程序能識別的文件格式。根據文件信息就可以完成自舉表的內容,如表1所示。最后使用FLASH的擦除、讀寫等操作指令把表1的內容燒入FLASH中。DSP上電復位,便可完成并行自舉引導。 

 

 

    整個引導過程為:上電復位后,判斷MP/MC=0處于微計算機工作方式,從片內ROM的0FF80h處執行中斷向量表的分支轉移指令(BD 0F800h),使程序跳轉至0F800h處執行自舉引導程序。自舉引導程序完成初始化后讀取數據空間的0FFFFh地址的內容,找到自舉表首地址8000h,從8000h處開始讀取內容,首先是16位自舉標記(10AA),然后分別是寄存器SWWSR及BSCR的內容、程序入口地址、代碼段長度、存放代碼段的目標地址等信息,根據這些信息把FLASH中的8008H~A594H的程序搬運到片內RAM中,然后把Page1Func和Page2Func的代碼搬運到0x180000和0x28000處,最后跳轉至片內RAM的26FDH,即PC為26FDH,XPC為0,開始執程序。這樣即完成程序的并行自舉過程。 

    使用DSP/BIOS可以很好地實現擴展尋址功能,把程序燒寫入FLASH后,復位DSP使其處于MC工作方式,便可使用示波器測試XF引腳,觀察程序運行正確與否。 

參考文獻

1 張雄偉,陳 亮,徐光輝. DSP集成開發與應用實例.北京: 電子工業出版社,2002.6 

2 Interrupt Handling Using Extended Addressing of the TMS320C54x Family. Application Report SPRA492,1998.11 

3 TMS320VC5410 Bootloader. SPRA609A   Copyright (c). TI,April 2000 

此內容為AET網站原創,未經授權禁止轉載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
国产精品久久毛片a| 精品二区视频| 久久久久久久一区二区三区| 亚洲性图久久| 99精品黄色片免费大全| 亚洲人成网在线播放| 久久大逼视频| 欧美一区二区三区四区高清| 亚洲综合国产| 亚洲综合日韩在线| 亚洲一区在线看| 亚洲免费一区二区| 亚洲欧美视频| 亚洲男人第一网站| 午夜精品一区二区三区在线视 | 国产精品卡一卡二| 国产精品电影网站| 国产精品大全| 国产精品视频九色porn| 国产精品久久网| 国产欧美精品在线| 国产无遮挡一区二区三区毛片日本| 国产日韩一区欧美| 国产午夜精品久久久| 国产亚洲欧美一级| 好吊成人免视频| 亚洲第一久久影院| 日韩午夜激情电影| 亚洲一区二区综合| 午夜一区不卡| 亚洲国产成人tv| 亚洲精选91| 亚洲午夜久久久| 亚洲午夜精品网| 欧美在线一级va免费观看| 久久精品主播| 麻豆国产精品va在线观看不卡| 男人的天堂亚洲在线| 欧美国产日本在线| 欧美三级日韩三级国产三级| 国产精品一二一区| 黄色成人av| 亚洲欧洲日产国码二区| 在线一区日本视频| 午夜精品99久久免费| 亚洲动漫精品| 在线亚洲+欧美+日本专区| 欧美一区二区免费观在线| 久热国产精品视频| 欧美日韩福利| 国产婷婷色一区二区三区| 亚洲国产精品www| 亚洲无限av看| 亚洲国产日韩欧美在线图片| 在线一区观看| 久久久久久穴| 欧美日韩国产区| 国产嫩草一区二区三区在线观看| 在线免费观看日本欧美| 夜夜嗨av一区二区三区四区| 欧美一区三区二区在线观看| 99re视频这里只有精品| 欧美在线黄色| 欧美精品一区二区久久婷婷| 国产乱码精品一区二区三区av| 一区二区亚洲欧洲国产日韩| 99精品99| 亚洲国产精品久久久久秋霞影院| 亚洲一区二区在线| 久久琪琪电影院| 欧美性开放视频| ●精品国产综合乱码久久久久| 夜夜嗨一区二区| 亚洲福利国产精品| 亚洲欧美在线视频观看| 欧美aⅴ一区二区三区视频| 国产精品美女久久久久av超清 | 一本色道久久综合狠狠躁的推荐| 午夜视频一区在线观看| 日韩视频中午一区| 久久精品在线| 国产精品久久久久久av下载红粉| 在线播放国产一区中文字幕剧情欧美| 一区二区三区福利| 91久久久久久| 久久精品一本| 国产精品久久久久久久久久久久 | 欧美成年网站| 国产日韩精品在线播放| 99re6这里只有精品| 亚洲国产精品视频| 午夜久久影院| 欧美日韩一区二区三区在线看 | 亚洲高清视频一区| 欧美亚洲视频一区二区| 亚洲一区二区三区中文字幕| 欧美高清在线视频观看不卡| 国产在线视频不卡二| 亚洲一区二区三区色| 在线亚洲免费| 欧美岛国在线观看| 一区二区三区在线不卡| 午夜精品一区二区在线观看| 在线综合+亚洲+欧美中文字幕| 欧美va天堂| 在线看欧美日韩| 久久精品亚洲热| 久久久综合精品| 国产亚洲一区在线| 亚洲欧美另类中文字幕| 亚洲主播在线播放| 欧美无砖砖区免费| 日韩亚洲精品视频| 一区二区三区 在线观看视频| 欧美高清影院| 亚洲国产精品毛片| 亚洲经典一区| 麻豆国产精品一区二区三区| 欧美激情免费观看| 激情亚洲一区二区三区四区| 午夜亚洲视频| 久久精品国产亚洲精品| 国产一本一道久久香蕉| 校园春色综合网| 欧美一区二区三区在线观看视频| 国产精品久久久久毛片软件| 中文国产亚洲喷潮| 亚洲一二三区精品| 欧美体内she精视频在线观看| 亚洲免费久久| 亚洲香蕉网站| 国产精品美女在线| 午夜激情久久久| 久久青青草综合| 伊人精品成人久久综合软件| 亚洲福利视频在线| 欧美激情va永久在线播放| 亚洲人午夜精品| 亚洲婷婷综合久久一本伊一区| 国产精品高潮在线| 亚洲欧美大片| 久久一区二区三区国产精品| 在线观看一区欧美| 99精品视频免费观看| 国产精品福利在线| 欧美一区二区三区免费观看视频 | 狂野欧美激情性xxxx欧美| 伊伊综合在线| aa级大片欧美三级| 国产精品sss| 欧美一二三视频| 免费中文字幕日韩欧美| 亚洲欧洲一区二区天堂久久| 亚洲一区二区三区高清| 国产精品综合久久久| 亚洲第一久久影院| 欧美精品在线视频| 亚洲尤物视频在线| 久久婷婷av| 亚洲精品中文字幕女同| 午夜精品国产更新| 精品av久久707| 亚洲午夜在线| 国产在线观看精品一区二区三区| 亚洲精品裸体| 国产精品毛片| 亚洲电影在线播放| 欧美视频久久| 欧美在线短视频| 欧美精品在线网站| 午夜精品久久久久久久蜜桃app| 免费不卡视频| 亚洲尤物在线| 男女av一区三区二区色多| 正在播放欧美视频| 鲁大师影院一区二区三区| 亚洲人成绝费网站色www| 午夜伦理片一区| 亚洲高清中文字幕| 午夜精彩视频在线观看不卡| 亚洲第一在线视频| 午夜精彩国产免费不卡不顿大片| 伊人久久噜噜噜躁狠狠躁| 亚洲愉拍自拍另类高清精品| 一区视频在线| 亚洲欧美日韩在线一区| 在线不卡亚洲| 亚洲欧美在线视频观看| 亚洲观看高清完整版在线观看| 亚洲欧美日韩专区| 亚洲激情小视频| 久久久久久亚洲精品中文字幕| 亚洲精品视频免费在线观看| 久久久久**毛片大全| 夜夜嗨一区二区| 欧美国产一区视频在线观看| 欧美一区影院| 国产精品久久久久久久电影 | 欧美另类在线播放| 久久精品视频在线免费观看|