資料介紹
引言
一個完整的嵌入式系統必須要有一個合適的存儲器存放用戶代碼。Flash是一種非易失性存儲器,而且具有電可擦寫、容量大、價格便宜等特點,通常可用于在DSP系統中存放用戶代碼。
Flash在正常使用前要進行編程,即將用戶代碼寫入Flash。在系統編程方法不需要其它編程設備和編程電源,只借助于仿真器,可直接通過DSP燒寫程序對Flash進行編程。本文所使用的編程方法就屬于在系統編程。
本文首先介紹常見的Flash編程方法,然后詳細介紹本文方法的原理,以及DSP系統上電加載原理,最后給出整個實現過程并分析了Flash編程時需要注意的一些問題。


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


圖1 系統上電的工作步驟 圖2 程序流程
Flash編程方法
常見的Flash編程方式
Flash在正常使用前必須寫入用戶程序,傳統上有3種編程方法:由供應商出貨前把程序代碼寫入Flash、編程器編程和在系統編程。
第1種方法不能滿足用戶更改代碼的需求,所以在開發階段不宜采用。當使用編程器編程時,要求Flash固定在PCB板前必須把用戶程序寫入片內。因此,現在一般都優先考慮在系統編程方法,首先應確定所選的DSP是否直持在系統編程。現行的在系統編程的方法一般是先把待加載程序(用戶程序)的.out文件(COFF格式)轉成HEX格式,然后去掉HEX格式文件的文件頭,再通過燒寫程序寫到Flash里去。也可以不進行COFF格式到HEX格式的轉換這一步,把COFF文件作為源文件,去除文件頭信息后將其寫入Flash。
本文方法的編程原理
本文的實現方法比較簡單,首先把用戶程序映射到系統RAM,再把用戶程序作為數據直接從RAM搬入Flash中。
首先在CCS上完成用戶程序,生成可執行的.out文件,將該文件設為文件1進行加載;然后加載燒寫程序的.out文件,將其設為文件2;最后運行文件2,通過它把文件1燒入Flash。
操作步驟非常簡單,這里要說明幾點。首先,2個.out文件各自獨立,文件2加載后,文件1成為數據,CCS在運行時,運行的是最新加載的程序,也即文件2。其次,文件2與文件1映射到RAM中的物理空間各自獨立,也就是文件2不能映射到文件1已映射的地方,如果發生重疊,文件2的內容就會覆蓋原先文件1映射到該地址空間的內容,寫入Flash的內容就會發生錯誤。再次,用戶程序里包括了二次加載程序,以在自舉時把用戶程序從Flash還原到RAM中。
總線周期
命令1 2 3 4 5 6
序列地址 數據地址 數據地址 數據地址 數據地址 數據地址 數據
軟件復位XXXF0
芯片擦除XXXAAXXX55XXX80XXXAAXXX55XXX10
扇區擦除XXXAAXXX55XXX80XXXAAXXX55SA30
字節寫XXXAAXXX55XXXA0PAPD
表1 Am29LV033C內存指令表
二次加載和Bootloader
要保證用戶程序的正確運行,僅把程序寫入Flash是不夠的,必須保證上電后,程序能夠從Flash中正確恢復到RAM。系統上電工作步驟如圖1所示。
DSP首先自檢,得到程序的加載模式。在C6000中主要有2種模式,一種是主機加載模式,也即DSP從0x0000 0000開始執行程序;另一種是ROM加載模式,該模式又有8位、16位、32位幾種,不同的DSP略有不同,這里選用8位ROM模式。工作時,DSP先從地址0x9000 0000開始,把0x9000 0000~0x9000 0400這1K(在C62xx中是64K)的數據搬到0x0000 0000~0x0000 0400,然后再從0x0000 0000開始執行程序。這一次加載由DSP自行完成,但是1K的程序作為用戶程序顯然不夠,因此,這1K的程序要做成加載器,也就是手工寫的Bootloader,利用它把用戶程序從Flash搬入RAM。加載器搬運用戶程序又是一次加載,因此把這個過程統稱為二次加載。
Bootloader要完成兩項功能,第一,把其它程序搬到指定的地址;第二,跳轉到用戶程序入口,這里要先修改ISP,再跳轉到復位中斷,因此在Bootloader的最后總是一條跳轉指令。由于Bootloader在Flash中的位置是0x9000 0000~0x9000 0400,而Bootloader又是放在用戶程序里的,因此,為了方便燒寫程序把Bootloader寫到該位置,這里在用戶程序的.cmd文件中把bootloader定位在程序段的起始位置。
下載該資料的人也在下載
下載該資料的人還在閱讀
更多 >
- TMS320DM642 EVM OSD FPGA用戶指南
- TMS320DM642 EVM子卡規格1.0版
- TMS320DM642硬件設計人員資源指南
- TMS320DM642至TMS320DM6437遷移指南
- 從TMS320DM642/3/1/0遷移到TMS320DM648/7器件
- 從TMS320DM642遷移至TMS320DM648/DM6437
- 如何從進行TMS320DM642到TMS320DM6467的遷移 12次下載
- TMS320DM642中文資料 10次下載
- TMS320DM642中文手冊 28次下載
- 基于TMS320DM642的嵌入式Web服務器設計 15次下載
- TMS320DM642-500,pdf(Video/Imag
- 基于TMS320DM642的視頻采集卡設計
- TMS320DM642 E開發板技術參考手冊
- 基于TI TMS320DM642平臺的H.324可視電話設計
- TMS320DM642 pdf datasheet
- 基于TMS320DM642和EPM240芯片實現圖像采集與處理系統的設計 6.7k次閱讀
- 基于TMS320DM643芯片和TCP/IP NDK網絡開發包實現電視采集系統的設計 3.6k次閱讀
- 基于CY7C68033和TMS320DM6437芯片實現高速圖像采集處理系統的設計 3.4k次閱讀
- 基于DSP芯片TMS320DM642實現剖面聲納系統的設計 3.7k次閱讀
- 基于TMS320C6203 DSP芯片實現G.729ab聲碼器的應用方案 4.2k次閱讀
- 基于TMS320DM642 DSP芯片實現IMlab6421視頻服務器的設計 3.1k次閱讀
- 基于TMS320DM642多媒體芯片實現視頻監控系統的應用方案 4.5k次閱讀
- TMS320C6748和TMS320C6747芯片對比 1.9w次閱讀
- dsp tms320c6000基本作用的認識 1.1w次閱讀
- 以FPGA和TMS320DM642為核心的實時圖像采集和處理系統設計詳解 3.2k次閱讀
- TMS320f28335控制AD7656的硬件電路設計 1.3w次閱讀
- 基于DSP的嵌入式數字攝像夜間能見度測量系統 4k次閱讀
- DM642上5/3提升小波的優化 1.8k次閱讀
- 基于TMS320DM642的Flash編程 5.4k次閱讀
- 基于TMS320C642電子穩像的實現 2k次閱讀
下載排行
本周
- 1MDD品牌三極管BC807數據手冊
- 3.00 MB | 次下載 | 免費
- 2MDD品牌三極管BC817數據手冊
- 2.51 MB | 次下載 | 免費
- 3MDD品牌三極管D882數據手冊
- 3.49 MB | 次下載 | 免費
- 4MDD品牌三極管MMBT2222A數據手冊
- 3.26 MB | 次下載 | 免費
- 5MDD品牌三極管MMBTA56數據手冊
- 3.09 MB | 次下載 | 免費
- 6MDD品牌三極管MMBTA92數據手冊
- 2.32 MB | 次下載 | 免費
- 7STM32G474 HRTIME PWM 丟波問題分析與解決
- 1.00 MB | 次下載 | 3 積分
- 8新能源電動汽車高壓線束的銅鋁連接解決方案
- 2.71 MB | 次下載 | 2 積分
本月
- 1愛華AIWA HS-J202維修手冊
- 3.34 MB | 37次下載 | 免費
- 2NB-IoT芯片廠商的資料說明
- 0.31 MB | 22次下載 | 1 積分
- 3PC5502負載均流控制電路數據手冊
- 1.63 MB | 22次下載 | 免費
- 4H110主板CPU PWM芯片ISL95858HRZ-T核心供電電路圖資料
- 0.63 MB | 6次下載 | 1 積分
- 5UWB653Pro USB口測距通信定位模塊規格書
- 838.47 KB | 5次下載 | 免費
- 6技嘉H110主板IT8628E_BX IO電路圖資料
- 2.61 MB | 4次下載 | 1 積分
- 7蘇泊爾DCL6907(即CHK-S007)單芯片電磁爐原理圖資料
- 0.04 MB | 4次下載 | 1 積分
- 8蘇泊爾DCL6909(即CHK-S009)單芯片電磁爐原理圖資料
- 0.08 MB | 2次下載 | 1 積分
總榜
- 1matlab軟件下載入口
- 未知 | 935137次下載 | 10 積分
- 2開源硬件-PMP21529.1-4 開關降壓/升壓雙向直流/直流轉換器 PCB layout 設計
- 1.48MB | 420064次下載 | 10 積分
- 3Altium DXP2002下載入口
- 未知 | 233089次下載 | 10 積分
- 4電路仿真軟件multisim 10.0免費下載
- 340992 | 191439次下載 | 10 積分
- 5十天學會AVR單片機與C語言視頻教程 下載
- 158M | 183353次下載 | 10 積分
- 6labview8.5下載
- 未知 | 81602次下載 | 10 積分
- 7Keil工具MDK-Arm免費下載
- 0.02 MB | 73822次下載 | 10 積分
- 8LabVIEW 8.6下載
- 未知 | 65991次下載 | 10 積分
電子發燒友App





創作
發文章
發帖
提問
發資料
發視頻
上傳資料賺積分
評論