基于閃爍存儲器的TMS320VC5409 DSP并行引導裝載方法
上電復位后,TMS320VC5409檢測其MP/MC引腳,如果MP/MC=0,DSP從0xFF80h處開(kāi)始執行片內引導裝載程序。進(jìn)入引導程序后,如有INT2請求中斷,則進(jìn)入HPI 引導方式;如有INT3請求中斷,則進(jìn)入EEPROM串行口引導方式;否則就進(jìn)入并行引導方式。其詳細引導過(guò)程如圖3所示。
片內并行引導方式前半部件是I/O空間并行引導方式,我們不采用此方式,程序繼續運行直到從數據空間0xFFFFh地址讀入一個(gè)地址數據,此數據為用戶(hù)自舉表的入口地址。這時(shí)片內引導程序就開(kāi)始執行FLASH中的用戶(hù)自舉表,若自舉表的第一個(gè)字是0x10AA,則表示是16位并行引導模式。
4 FLASH中自舉表(Boottable)的存儲格式
為了實(shí)現DSP加電自舉,FLASH的數據必須按照自舉表的格式“燒寫(xiě)”。自舉表的作用是:DSP運行此表時(shí),首先根據自舉表中前部分用戶(hù)起始地址把后面的用戶(hù)程序代碼加載到DSP片內程序空間中相應的用戶(hù)地址區域(由于FLASH與DSP時(shí)間不匹配,要設置好SWWR和BSCR寄存器),然后根據自舉表中的程序入口址,在程序空間相應的地址開(kāi)始運行程序。表2為16位并行自舉的代碼結構(自舉表在空間允許的情況下可以放幾個(gè)程序代碼段,為便于說(shuō)明,在此只說(shuō)明一個(gè)程序代碼段的情況)。
表2 并行自舉表的代碼結構
10AA(并行尋址格式) |
SWWSR寄存器的初始值 |
BSCR寄存器的初始值 |
用戶(hù)程序入口的XPC |
用戶(hù)程序入口的地址PC |
用戶(hù)程序的長(cháng)度 |
用戶(hù)程序起始地址XPC |
用戶(hù)程序起始地址PC |
用戶(hù)程序代碼… |
0000(表示自舉表結束) |
下面結合一個(gè)實(shí)例,說(shuō)明利用hex500命令生成二進(jìn)制數據自舉表的方法。
(1)所編寫(xiě)的一個(gè)用戶(hù)程序名為myblink.C,在編譯鏈接成功后生成的輸出文件名為myblink.out;程序空間的開(kāi)始地址為0x1400h,程序執行的入口地址為0x144Fh。利用hex500工具,生成文件名為myblink.hex的二進(jìn)制數據,hex500命令后添加如下條件:
mybilink.out ;要轉換的.out文件
-a ;生成ASCII碼的形式
-e 0x144Fh ;程序空間中程序運行的開(kāi)始
地址
-boot ;轉換成自舉表的形式
-bootorg PARALLEL ;并行格式
-byte ;按字節分配地址
-memwidth 16 ;系統存儲器字寬度為16位
-romwidth 16 ;ROM物理寬度為16位
-swwsr 0x7FFFh ;SWWSR設置軟件等待周期
-bscr 0xF800h ;BSCR設置段開(kāi)關(guān)控制寄存器值0xF800
-o myblink.hex ;輸出的二進(jìn)制數據文件名
(2)生成的進(jìn)制數據文件myblink.hex的數據為:
0x10AA 0x7FFF 0xF800 0x0000 0x144F 0x00D1 0x0000 0x1400 …(用戶(hù)程序代碼)… 0x0000;
前8個(gè)數據解釋分別為:
0x10AAh:16位并行尋址格式;
0x7FFFh:SWWSR初始值為0x7FFFh,因為FLASH的運行速度比DSP慢,等待7個(gè)周期;
0xF8000h:BSCR初始值為0xF800h;
0x0000h:自舉表程序入口的XPC=0;
0x144Fh:自舉表程序入口的地址=0x144Fh;
0x00D1h:自舉表程序的長(cháng)度=0xD1h;
0x0000h:自舉表起始地址XPC=0;
0x1400h:自舉表的起始地址=0x1400h。
(3)編寫(xiě)一個(gè)數據轉換程序,把二進(jìn)制數據文件myblink.hex轉換為數組頭文件myblink.h。在CCS環(huán)境下,FLASH的“燒寫(xiě)”主程序包含此頭文件,編譯鏈接后通過(guò)仿真器下載到DSP中,運行DSP,用戶(hù)程序就被“燒入”FLASH中了。
實(shí)際應用是:在數據空間地址0xFFFFh(也就是FLASH的空間0xFFFFh)中“燒寫(xiě)”數據0x9000h(FLASH中存放的自舉表起始地址),在FLASH的地址0x9000h開(kāi)始“燒入”用戶(hù)自舉表數據即myblink.h中的數組數據。
DSP 運行情況是:依據第3節所述的引導裝載過(guò)程,經(jīng)過(guò)一系列的設置,使DSP尋址到數據空間地址0xFFFFh,得到自舉表的起始地址0x9000h,PC指針指向0x9000h,執行自舉表的數據,根據自舉表寫(xiě)入信息,把后面的程序裝載入程序空間起始地址0x1400h(XPC=0)(這時(shí)通過(guò)仿真器查看程序空間0x1400h開(kāi)始的數據,與仿真器下載的myblink.out文件數據是一致的)。然后,DSP的PC指針指向程序入口地址0x144Fh (XPC=0)開(kāi)始執行用戶(hù)程序,從而完成了DSP利用FLASH實(shí)現16位并行引導裝載的過(guò)程。
評論