資料介紹
引言
一個(gè)完整的嵌入式系統(tǒng)必須要有一個(gè)合適的存儲(chǔ)器存放用戶代碼。Flash是一種非易失性存儲(chǔ)器,而且具有電可擦寫(xiě)、容量大、價(jià)格便宜等特點(diǎn),通??捎糜谠?a target='_blank' class='arckwlink_none'>DSP系統(tǒng)中存放用戶代碼。
Flash在正常使用前要進(jìn)行編程,即將用戶代碼寫(xiě)入Flash。在系統(tǒng)編程方法不需要其它編程設(shè)備和編程電源,只借助于仿真器,可直接通過(guò)DSP燒寫(xiě)程序?qū)lash進(jìn)行編程。本文所使用的編程方法就屬于在系統(tǒng)編程。
本文首先介紹常見(jiàn)的Flash編程方法,然后詳細(xì)介紹本文方法的原理,以及DSP系統(tǒng)上電加載原理,最后給出整個(gè)實(shí)現(xiàn)過(guò)程并分析了Flash編程時(shí)需要注意的一些問(wèn)題。


圖1 系統(tǒng)上電的工作步驟 圖2 程序流程
Flash編程方法
常見(jiàn)的Flash編程方式
Flash在正常使用前必須寫(xiě)入用戶程序,傳統(tǒng)上有3種編程方法:由供應(yīng)商出貨前把程序代碼寫(xiě)入Flash、編程器編程和在系統(tǒng)編程。
第1種方法不能滿足用戶更改代碼的需求,所以在開(kāi)發(fā)階段不宜采用。當(dāng)使用編程器編程時(shí),要求Flash固定在PCB板前必須把用戶程序?qū)懭肫瑑?nèi)。因此,現(xiàn)在一般都優(yōu)先考慮在系統(tǒng)編程方法,首先應(yīng)確定所選的DSP是否直持在系統(tǒng)編程?,F(xiàn)行的在系統(tǒng)編程的方法一般是先把待加載程序(用戶程序)的.out文件(COFF格式)轉(zhuǎn)成HEX格式,然后去掉HEX格式文件的文件頭,再通過(guò)燒寫(xiě)程序?qū)懙紽lash里去。也可以不進(jìn)行COFF格式到HEX格式的轉(zhuǎn)換這一步,把COFF文件作為源文件,去除文件頭信息后將其寫(xiě)入Flash。
本文方法的編程原理
本文的實(shí)現(xiàn)方法比較簡(jiǎn)單,首先把用戶程序映射到系統(tǒng)RAM,再把用戶程序作為數(shù)據(jù)直接從RAM搬入Flash中。
首先在CCS上完成用戶程序,生成可執(zhí)行的.out文件,將該文件設(shè)為文件1進(jìn)行加載;然后加載燒寫(xiě)程序的.out文件,將其設(shè)為文件2;最后運(yùn)行文件2,通過(guò)它把文件1燒入Flash。
操作步驟非常簡(jiǎn)單,這里要說(shuō)明幾點(diǎn)。首先,2個(gè).out文件各自獨(dú)立,文件2加載后,文件1成為數(shù)據(jù),CCS在運(yùn)行時(shí),運(yùn)行的是最新加載的程序,也即文件2。其次,文件2與文件1映射到RAM中的物理空間各自獨(dú)立,也就是文件2不能映射到文件1已映射的地方,如果發(fā)生重疊,文件2的內(nèi)容就會(huì)覆蓋原先文件1映射到該地址空間的內(nèi)容,寫(xiě)入Flash的內(nèi)容就會(huì)發(fā)生錯(cuò)誤。再次,用戶程序里包括了二次加載程序,以在自舉時(shí)把用戶程序從Flash還原到RAM中。
總線周期
命令1 2 3 4 5 6
序列地址 數(shù)據(jù)地址 數(shù)據(jù)地址 數(shù)據(jù)地址 數(shù)據(jù)地址 數(shù)據(jù)地址 數(shù)據(jù)
軟件復(fù)位XXXF0
芯片擦除XXXAAXXX55XXX80XXXAAXXX55XXX10
扇區(qū)擦除XXXAAXXX55XXX80XXXAAXXX55SA30
字節(jié)寫(xiě)XXXAAXXX55XXXA0PAPD
表1 Am29LV033C內(nèi)存指令表
二次加載和Bootloader
要保證用戶程序的正確運(yùn)行,僅把程序?qū)懭隖lash是不夠的,必須保證上電后,程序能夠從Flash中正確恢復(fù)到RAM。系統(tǒng)上電工作步驟如圖1所示。
DSP首先自檢,得到程序的加載模式。在C6000中主要有2種模式,一種是主機(jī)加載模式,也即DSP從0x0000 0000開(kāi)始執(zhí)行程序;另一種是ROM加載模式,該模式又有8位、16位、32位幾種,不同的DSP略有不同,這里選用8位ROM模式。工作時(shí),DSP先從地址0x9000 0000開(kāi)始,把0x9000 0000~0x9000 0400這1K(在C62xx中是64K)的數(shù)據(jù)搬到0x0000 0000~0x0000 0400,然后再?gòu)?x0000 0000開(kāi)始執(zhí)行程序。這一次加載由DSP自行完成,但是1K的程序作為用戶程序顯然不夠,因此,這1K的程序要做成加載器,也就是手工寫(xiě)的Bootloader,利用它把用戶程序從Flash搬入RAM。加載器搬運(yùn)用戶程序又是一次加載,因此把這個(gè)過(guò)程統(tǒng)稱為二次加載。
Bootloader要完成兩項(xiàng)功能,第一,把其它程序搬到指定的地址;第二,跳轉(zhuǎn)到用戶程序入口,這里要先修改ISP,再跳轉(zhuǎn)到復(fù)位中斷,因此在Bootloader的最后總是一條跳轉(zhuǎn)指令。由于Bootloader在Flash中的位置是0x9000 0000~0x9000 0400,而B(niǎo)ootloader又是放在用戶程序里的,因此,為了方便燒寫(xiě)程序把Bootloader寫(xiě)到該位置,這里在用戶程序的.cmd文件中把bootloader定位在程序段的起始位置。
一個(gè)完整的嵌入式系統(tǒng)必須要有一個(gè)合適的存儲(chǔ)器存放用戶代碼。Flash是一種非易失性存儲(chǔ)器,而且具有電可擦寫(xiě)、容量大、價(jià)格便宜等特點(diǎn),通??捎糜谠?a target='_blank' class='arckwlink_none'>DSP系統(tǒng)中存放用戶代碼。
Flash在正常使用前要進(jìn)行編程,即將用戶代碼寫(xiě)入Flash。在系統(tǒng)編程方法不需要其它編程設(shè)備和編程電源,只借助于仿真器,可直接通過(guò)DSP燒寫(xiě)程序?qū)lash進(jìn)行編程。本文所使用的編程方法就屬于在系統(tǒng)編程。
本文首先介紹常見(jiàn)的Flash編程方法,然后詳細(xì)介紹本文方法的原理,以及DSP系統(tǒng)上電加載原理,最后給出整個(gè)實(shí)現(xiàn)過(guò)程并分析了Flash編程時(shí)需要注意的一些問(wèn)題。


圖1 系統(tǒng)上電的工作步驟 圖2 程序流程
Flash編程方法
常見(jiàn)的Flash編程方式
Flash在正常使用前必須寫(xiě)入用戶程序,傳統(tǒng)上有3種編程方法:由供應(yīng)商出貨前把程序代碼寫(xiě)入Flash、編程器編程和在系統(tǒng)編程。
第1種方法不能滿足用戶更改代碼的需求,所以在開(kāi)發(fā)階段不宜采用。當(dāng)使用編程器編程時(shí),要求Flash固定在PCB板前必須把用戶程序?qū)懭肫瑑?nèi)。因此,現(xiàn)在一般都優(yōu)先考慮在系統(tǒng)編程方法,首先應(yīng)確定所選的DSP是否直持在系統(tǒng)編程?,F(xiàn)行的在系統(tǒng)編程的方法一般是先把待加載程序(用戶程序)的.out文件(COFF格式)轉(zhuǎn)成HEX格式,然后去掉HEX格式文件的文件頭,再通過(guò)燒寫(xiě)程序?qū)懙紽lash里去。也可以不進(jìn)行COFF格式到HEX格式的轉(zhuǎn)換這一步,把COFF文件作為源文件,去除文件頭信息后將其寫(xiě)入Flash。
本文方法的編程原理
本文的實(shí)現(xiàn)方法比較簡(jiǎn)單,首先把用戶程序映射到系統(tǒng)RAM,再把用戶程序作為數(shù)據(jù)直接從RAM搬入Flash中。
首先在CCS上完成用戶程序,生成可執(zhí)行的.out文件,將該文件設(shè)為文件1進(jìn)行加載;然后加載燒寫(xiě)程序的.out文件,將其設(shè)為文件2;最后運(yùn)行文件2,通過(guò)它把文件1燒入Flash。
操作步驟非常簡(jiǎn)單,這里要說(shuō)明幾點(diǎn)。首先,2個(gè).out文件各自獨(dú)立,文件2加載后,文件1成為數(shù)據(jù),CCS在運(yùn)行時(shí),運(yùn)行的是最新加載的程序,也即文件2。其次,文件2與文件1映射到RAM中的物理空間各自獨(dú)立,也就是文件2不能映射到文件1已映射的地方,如果發(fā)生重疊,文件2的內(nèi)容就會(huì)覆蓋原先文件1映射到該地址空間的內(nèi)容,寫(xiě)入Flash的內(nèi)容就會(huì)發(fā)生錯(cuò)誤。再次,用戶程序里包括了二次加載程序,以在自舉時(shí)把用戶程序從Flash還原到RAM中。
總線周期
命令1 2 3 4 5 6
序列地址 數(shù)據(jù)地址 數(shù)據(jù)地址 數(shù)據(jù)地址 數(shù)據(jù)地址 數(shù)據(jù)地址 數(shù)據(jù)
軟件復(fù)位XXXF0
芯片擦除XXXAAXXX55XXX80XXXAAXXX55XXX10
扇區(qū)擦除XXXAAXXX55XXX80XXXAAXXX55SA30
字節(jié)寫(xiě)XXXAAXXX55XXXA0PAPD
表1 Am29LV033C內(nèi)存指令表
二次加載和Bootloader
要保證用戶程序的正確運(yùn)行,僅把程序?qū)懭隖lash是不夠的,必須保證上電后,程序能夠從Flash中正確恢復(fù)到RAM。系統(tǒng)上電工作步驟如圖1所示。
DSP首先自檢,得到程序的加載模式。在C6000中主要有2種模式,一種是主機(jī)加載模式,也即DSP從0x0000 0000開(kāi)始執(zhí)行程序;另一種是ROM加載模式,該模式又有8位、16位、32位幾種,不同的DSP略有不同,這里選用8位ROM模式。工作時(shí),DSP先從地址0x9000 0000開(kāi)始,把0x9000 0000~0x9000 0400這1K(在C62xx中是64K)的數(shù)據(jù)搬到0x0000 0000~0x0000 0400,然后再?gòu)?x0000 0000開(kāi)始執(zhí)行程序。這一次加載由DSP自行完成,但是1K的程序作為用戶程序顯然不夠,因此,這1K的程序要做成加載器,也就是手工寫(xiě)的Bootloader,利用它把用戶程序從Flash搬入RAM。加載器搬運(yùn)用戶程序又是一次加載,因此把這個(gè)過(guò)程統(tǒng)稱為二次加載。
Bootloader要完成兩項(xiàng)功能,第一,把其它程序搬到指定的地址;第二,跳轉(zhuǎn)到用戶程序入口,這里要先修改ISP,再跳轉(zhuǎn)到復(fù)位中斷,因此在Bootloader的最后總是一條跳轉(zhuǎn)指令。由于Bootloader在Flash中的位置是0x9000 0000~0x9000 0400,而B(niǎo)ootloader又是放在用戶程序里的,因此,為了方便燒寫(xiě)程序把Bootloader寫(xiě)到該位置,這里在用戶程序的.cmd文件中把bootloader定位在程序段的起始位置。
下載該資料的人也在下載
下載該資料的人還在閱讀
更多 >
- TMS320DM642 EVM OSD FPGA用戶指南
- TMS320DM642 EVM子卡規(guī)格1.0版
- TMS320DM642硬件設(shè)計(jì)人員資源指南
- TMS320DM642至TMS320DM6437遷移指南
- 從TMS320DM642/3/1/0遷移到TMS320DM648/7器件
- 從TMS320DM642遷移至TMS320DM648/DM6437
- 如何從進(jìn)行TMS320DM642到TMS320DM6467的遷移 12次下載
- TMS320DM642中文資料 10次下載
- TMS320DM642中文手冊(cè) 28次下載
- 基于TMS320DM642的嵌入式Web服務(wù)器設(shè)計(jì) 15次下載
- TMS320DM642-500,pdf(Video/Imag
- 基于TMS320DM642的視頻采集卡設(shè)計(jì)
- TMS320DM642 E開(kāi)發(fā)板技術(shù)參考手冊(cè)
- 基于TI TMS320DM642平臺(tái)的H.324可視電話設(shè)計(jì)
- TMS320DM642 pdf datasheet
- 基于TMS320DM642和EPM240芯片實(shí)現(xiàn)圖像采集與處理系統(tǒng)的設(shè)計(jì) 3672次閱讀
- 基于TMS320DM643芯片和TCP/IP NDK網(wǎng)絡(luò)開(kāi)發(fā)包實(shí)現(xiàn)電視采集系統(tǒng)的設(shè)計(jì) 2752次閱讀
- 基于CY7C68033和TMS320DM6437芯片實(shí)現(xiàn)高速圖像采集處理系統(tǒng)的設(shè)計(jì) 2537次閱讀
- 基于DSP芯片TMS320DM642實(shí)現(xiàn)剖面聲納系統(tǒng)的設(shè)計(jì) 2964次閱讀
- 基于TMS320C6203 DSP芯片實(shí)現(xiàn)G.729ab聲碼器的應(yīng)用方案 3114次閱讀
- 基于TMS320DM642 DSP芯片實(shí)現(xiàn)IMlab6421視頻服務(wù)器的設(shè)計(jì) 2341次閱讀
- 基于TMS320DM642多媒體芯片實(shí)現(xiàn)視頻監(jiān)控系統(tǒng)的應(yīng)用方案 3432次閱讀
- TMS320C6748和TMS320C6747芯片對(duì)比 1.7w次閱讀
- dsp tms320c6000基本作用的認(rèn)識(shí) 9889次閱讀
- 以FPGA和TMS320DM642為核心的實(shí)時(shí)圖像采集和處理系統(tǒng)設(shè)計(jì)詳解 2863次閱讀
- TMS320f28335控制AD7656的硬件電路設(shè)計(jì) 1.1w次閱讀
- 基于DSP的嵌入式數(shù)字?jǐn)z像夜間能見(jiàn)度測(cè)量系統(tǒng) 3575次閱讀
- DM642上5/3提升小波的優(yōu)化 1467次閱讀
- 基于TMS320DM642的Flash編程 1442次閱讀
- 基于TMS320C642電子穩(wěn)像的實(shí)現(xiàn) 1711次閱讀
下載排行
本周
- 1電子電路原理第七版PDF電子教材免費(fèi)下載
- 0.00 MB | 1489次下載 | 免費(fèi)
- 2單片機(jī)典型實(shí)例介紹
- 18.19 MB | 91次下載 | 1 積分
- 3S7-200PLC編程實(shí)例詳細(xì)資料
- 1.17 MB | 27次下載 | 1 積分
- 4筆記本電腦主板的元件識(shí)別和講解說(shuō)明
- 4.28 MB | 18次下載 | 4 積分
- 5開(kāi)關(guān)電源原理及各功能電路詳解
- 0.38 MB | 9次下載 | 免費(fèi)
- 6基于AT89C2051/4051單片機(jī)編程器的實(shí)驗(yàn)
- 0.11 MB | 4次下載 | 免費(fèi)
- 7基于單片機(jī)和 SG3525的程控開(kāi)關(guān)電源設(shè)計(jì)
- 0.23 MB | 3次下載 | 免費(fèi)
- 8基于單片機(jī)的紅外風(fēng)扇遙控
- 0.23 MB | 3次下載 | 免費(fèi)
本月
- 1OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234313次下載 | 免費(fèi)
- 2PADS 9.0 2009最新版 -下載
- 0.00 MB | 66304次下載 | 免費(fèi)
- 3protel99下載protel99軟件下載(中文版)
- 0.00 MB | 51209次下載 | 免費(fèi)
- 4LabView 8.0 專業(yè)版下載 (3CD完整版)
- 0.00 MB | 51043次下載 | 免費(fèi)
- 5555集成電路應(yīng)用800例(新編版)
- 0.00 MB | 33562次下載 | 免費(fèi)
- 6接口電路圖大全
- 未知 | 30319次下載 | 免費(fèi)
- 7Multisim 10下載Multisim 10 中文版
- 0.00 MB | 28588次下載 | 免費(fèi)
- 8開(kāi)關(guān)電源設(shè)計(jì)實(shí)例指南
- 未知 | 21539次下載 | 免費(fèi)
總榜
- 1matlab軟件下載入口
- 未知 | 935053次下載 | 免費(fèi)
- 2protel99se軟件下載(可英文版轉(zhuǎn)中文版)
- 78.1 MB | 537791次下載 | 免費(fèi)
- 3MATLAB 7.1 下載 (含軟件介紹)
- 未知 | 420026次下載 | 免費(fèi)
- 4OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234313次下載 | 免費(fèi)
- 5Altium DXP2002下載入口
- 未知 | 233045次下載 | 免費(fèi)
- 6電路仿真軟件multisim 10.0免費(fèi)下載
- 340992 | 191183次下載 | 免費(fèi)
- 7十天學(xué)會(huì)AVR單片機(jī)與C語(yǔ)言視頻教程 下載
- 158M | 183277次下載 | 免費(fèi)
- 8proe5.0野火版下載(中文版免費(fèi)下載)
- 未知 | 138039次下載 | 免費(fèi)
評(píng)論