




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
1、f bt c 程 序 編 寫 ( 共 6 頁 )-本頁僅作為文檔封面,使用時(shí)請(qǐng)直接刪除即可- -內(nèi)頁可以根據(jù)需求調(diào)整合適字體及大小- 2 基于 dm642 的 fbtc 程序的編寫一、引言在嵌入式系統(tǒng)開發(fā)過程中,把編寫好的應(yīng)用程序燒寫進(jìn)目標(biāo)板的flash以實(shí)現(xiàn)系統(tǒng)的上電自舉是非常重要的一個(gè)環(huán)節(jié)。對(duì)于嵌入式dsp系統(tǒng),我們常使用flashburn system來對(duì) flash進(jìn)行燒寫。 flashburn system由兩部分組成,分別是flashburn應(yīng)用軟件( application)和 fbtc (flashburn target component )程序(program)。flash
2、brun的工作原理如圖 1 所示:圖 1 flashburn應(yīng)用軟件提供用戶操作界面,把fbtc程序通過 ccs和 jtag仿真器下載到 dsp目標(biāo)板中,由 fbtc程序?qū)?flash 存儲(chǔ)空間進(jìn)行操作和管理,并把用戶程序下載到flash 存儲(chǔ)器中。由此可見, flashburn應(yīng)用軟件就相當(dāng)于廠房里的各種機(jī)器設(shè)備,而fbtc程序則是生產(chǎn)和操作規(guī)程。從某種意義來說flashburn是硬件,而 fbtc是軟件,在相同的flashburn里應(yīng)用不同的 fbtc會(huì)得到完全不一樣的效果。事實(shí)上,當(dāng) ccs 、dsp目標(biāo)板、仿真器、 flashburn或 flash 芯片的型號(hào)不一樣時(shí), fbtc程序就
3、應(yīng)做相應(yīng)的改變,以成功地將用戶程序燒寫到flash中。本文試著將這些改變剖析一下。二、需要說明的問題本文使用的各種工具有、 dm642evm開發(fā)板、 xds560 jtag 仿真器、flashburn ,需要燒寫的 flash芯片是 amd 公司的 am29lv033c 。3 該 flash 的容量是 4mbytes(0x400000),在 dm642 上對(duì)應(yīng)的存儲(chǔ)空間位于ce1 emif ,其首地址是 0x。該款 flash 芯片的 datasheet 如圖 2:圖 2從上圖可知: 1)向 flash 的任意位置寫入序列0 xaa, 0 x55, 0 x80, 0 xaa, 0 x55, 0
4、 x10,表示擦出該位置的數(shù)據(jù);2)寫入 0 xf0 表示將 flash 設(shè)置為讀模式; 3)序列 0 xaa, 0 x55, 0 xa0后加上一字節(jié)的數(shù)據(jù)表式將該數(shù)據(jù)寫入到flash 的某一位置上。本文所舉的例子是在fbtc6416程序的基礎(chǔ)上修改而成的,該程序所在的文件可以在 flashburn的安裝文件中找到。之所以選擇teb6416 ,是因?yàn)樗蚫m642 屬于同一個(gè) isa (instruction set architecture)家族。三、得到 fbtc642 的步驟。(1)將 fbtc6416文件夾復(fù)制到你自己的工作區(qū)域,將文件名和文件中所有的 6416 改成 642。用記事本
5、打開 .pjt 文件,將里面的teb6416改成 dm642,將 projectdir=c:ccflashburnpitvobflashburnersrcfbtcteb6416 引號(hào)里內(nèi)容改成你現(xiàn)在的工程文件所在的路徑。保存后,在ccs里打開該工程文件,將build option 設(shè)置為 full debug和 no optimization 后編譯,鏈接。(2)修改 flash的起始地址和大小。在文件中:將“#define flash_size 0 x80000”改成“ #define flash_size 0 x40000”將“#define flash_start 0 x”改成“ #de
6、fine flash_start 0 x ”將“#define ce1_8 0 xffffff03 ”改成 “#define ce1_8 0 xf3a88e02 ”將 “#define ce1_32 0 xffffff23 ”改成 “#define ce1_32 0 xf3a88e22”4 (3)flash的尋址。flashburn把 flash image 當(dāng)做是從下標(biāo)為 0 開始的一個(gè)字節(jié)流, fbtc程序要做的就是把這一字節(jié)流和實(shí)際地址一一對(duì)應(yīng)起來,這一任務(wù)由里的相關(guān)函數(shù)實(shí)現(xiàn),另外還需要編寫一個(gè)新的函數(shù)setflashpage() 來設(shè)置 fpga的頁寄存器。即在里添加如下代碼:void
7、 setflashpage(flash_image_index_type index) ptr_sized_int addr = (u32)getflashbase() + index; *flash_page = (addr & 0 x380000) 19;(4)把 flash設(shè)置為讀狀態(tài)。這一功能由函數(shù) resetflash() 實(shí)現(xiàn)。根據(jù) flash 的 datasheet,其代碼應(yīng)為:void resetflash() volatile flash_data_type* volatile flashaddr; flashaddr = getflashaddr(0); /* do
8、nt care what address is used */ *flashaddr = 0 xf0;這里不用修改。(5)從 flash中讀取數(shù)據(jù)這一功能由函數(shù) getnextflashaddr ,getflashval(), sendflashbuftohost()聯(lián)合實(shí)現(xiàn),第一個(gè)函數(shù)負(fù)責(zé)尋址,第二個(gè)負(fù)責(zé)取數(shù),第三個(gè)負(fù)責(zé)傳數(shù)。在文件中:函數(shù) getflashval() 改成, u8 getflashval(unsigned long addr)*flash_page = (u8)(u32)addr & 0 x380000) 19);return *(volatile u8 *)(ad
9、dr & 0 xffc7ffff);(6)擦除 flash此功能由函數(shù) eraseflash ()實(shí)現(xiàn),由此型號(hào)的flash 可知,其參考代碼如下:5 void eraseflash(void) volatile flash_data_type* volatile pbase = getflashbase(); /* code to erase amd29lv033c */ *pbase = 0 xaa; *pbase = 0 x55; *pbase = 0 x80; *pbase = 0 xaa; *pbase = 0 x55; *pbase = 0 x10; checkflashe
10、rase(); resetflash(); return;(7)寫 flash此功能由函數(shù) burnflash ()完成,參考代碼如下:void burnflash(flash_image_index_type index, msg_data_type *data, u32 nbytes) u16 timeout; u8 c; volatile flash_data_type* volatile flashaddr; flash_image_index_type i = index; volatile flash_data_type* volatile pbase = getflashbase
11、();#if dbprint printf(burning %x bytes of flash at %xn, nbytes, flashaddr);#endif while(nbytes-) flashaddr = getflashaddr(i); setflashpage(i);6 *pbase = 0 xaa; *pbase = 0 x55; *pbase = 0 xa0; /* write a byte */ *flashaddr = *data; /* spin here until programming completes */ c = *data+; timeout = 0; do timeout += 1; while(*flashaddr != c & timeout (u16)0 xffff) ; i+; resetflash();對(duì)于不同型號(hào)的 flash ,*pbase對(duì)應(yīng)的值不同,對(duì)于不同的開發(fā)板就看是否有分頁。這些修改完成之后,就可以將整個(gè)工程進(jìn)行編譯、連接,得到的文件就可
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 放射醫(yī)學(xué)技術(shù)復(fù)習(xí)題及答案
- 第四單元第21課 活動(dòng)課讓我們共同來感受歷史2023-2024學(xué)年七年級(jí)上冊(cè)歷史同步教學(xué)設(shè)計(jì)(部編版)
- 《離騷》(節(jié)選) 教學(xué)設(shè)計(jì) 2023-2024學(xué)年統(tǒng)編版高中語文選擇性必修下冊(cè)
- 2025年液態(tài)食品包裝機(jī)械合作協(xié)議書
- 2024中國太平洋財(cái)產(chǎn)保險(xiǎn)股份有限公司自貢中心支公司招聘2人(四川)筆試參考題庫附帶答案詳解
- 2025年湖北省鄂州市單招職業(yè)傾向性測試題庫必考題
- 第13課《黃鶴樓》《渡荊門送別》教學(xué)設(shè)計(jì)2024-2025學(xué)年統(tǒng)編版語文八年級(jí)上冊(cè)
- 2025至2030年中國棉織睡袋數(shù)據(jù)監(jiān)測研究報(bào)告
- 山東省日照市2023-2024學(xué)年高二上學(xué)期期末校際聯(lián)合考試地理試題(解析版)
- 2025年廣東省汕尾市單招職業(yè)適應(yīng)性測試題庫學(xué)生專用
- 提升電子商務(wù)的發(fā)展邏輯
- 提升醫(yī)療質(zhì)量減少醫(yī)療糾紛
- (完整)特種設(shè)備專項(xiàng)應(yīng)急預(yù)案
- 小學(xué)體質(zhì)測試標(biāo)準(zhǔn)
- 機(jī)床安全操作培訓(xùn)課件
- 自動(dòng)化電氣控制方案
- 臍疝護(hù)理查房課件
- XX學(xué)校學(xué)校集體備課實(shí)施方案細(xì)則、方案、計(jì)劃、制度、總結(jié)(全套資料)
- 開展去向不明人員專項(xiàng)工作方案
- 南方談話學(xué)習(xí)匯報(bào)
- 高處作業(yè)吊籃施工安全監(jiān)理實(shí)施細(xì)則
評(píng)論
0/150
提交評(píng)論