国产毛片a精品毛-国产毛片黄片-国产毛片久久国产-国产毛片久久精品-青娱乐极品在线-青娱乐精品

基于單片機的Flash在系統(tǒng)編程方法

發(fā)布時間:2010-9-2 09:39    發(fā)布者:techshare
一個完整的嵌入式系統(tǒng)必須要有一個合適的存儲器存放用戶代碼。Flash是一種非易失性存儲器,而且具有電可擦寫、容量大、價格便宜等特點,通常可用于在DSP系統(tǒng)中存放用戶代碼。

Flash在正常使用前要進行編程,即將用戶代碼寫入Flash。在系統(tǒng)編程方法不需要其他編程設備和編程電源,只借助于仿真器,可直接通過DSP燒寫程序?qū)lash進行編程。本文所使用的編程方法就屬于在系統(tǒng)編程。

本文首先介紹常見的Flash編程方法。然后詳細介紹本文方法的原理,以及DSP系統(tǒng)上電加載原理,最后給出整個實現(xiàn)過程并分析了Flash變成時需要注意的一些問題。

Flash編程方法

常見的Flash編程方式


Flash在正常使用前必須寫入用戶程序,傳統(tǒng)上有3種編程方法:由供應商出貨前把程序代碼寫入Flash,編程器編程和在系統(tǒng)編程。

第1種方法不能滿足用戶更改代碼的需求,所以在開發(fā)階段不宜采用。當使用編程器編程時,要求Flash固定在PCB板前必須把用戶程序?qū)懭肫瑑?nèi)。因此,現(xiàn)在一般都優(yōu)先考慮在系統(tǒng)編程方法,首先應確定所選的DSP是否支持在系統(tǒng)編程。現(xiàn)行的在系統(tǒng)編程的方法一般是先把待加載程序(用戶程序)的.out文件(COFF格式)轉(zhuǎn)成HEX格式,然后去掉HEX格式文件的文件頭,再通過燒寫程序?qū)懙紽lash里去,也可以不進行COFF格式到HEX格式的轉(zhuǎn)換這一步,把COFF文件作為源文件,去除文件頭信息后將其寫入Flash。

本文方法的編程原理

本文的實現(xiàn)方法比較簡單,首先把用戶程序映射到系統(tǒng)RAM,再把用戶程序作為數(shù)據(jù)直接從RAM搬入Flash中。

首先在CCS上完成用戶程序,生成可執(zhí)行的.out文件,將該文件設為文件1進行加載;然后加載燒寫程序的.out文件,將其設為文件2;最后運行文件2,通過它把文件1燒入Flash。

操作步驟非常簡單,這里要說明幾點,首先,2個.out文件各自獨立,文件2加載后,文件1成為數(shù)據(jù),CCS在運行時,運行的是最新加載的程序,也即文件2。其次,文件2與文件1映射到RAM中的物理空間各自獨立,也就是文件2不能映射到文件1已影射的地方,如果發(fā)生重疊,文件2的內(nèi)容就會覆蓋原先文件1映射到該地址空間的內(nèi)容,寫入Flash的內(nèi)容就會發(fā)生錯誤。再次,用戶程序里包括了二次加載程序,以在自舉時把用戶程序從Flash還原到RAM中。

二次加載和Bootloader

要保證用戶程序的正確運行,僅把程序?qū)懭隖lash是不夠的,必須保證上電后,程序能夠從Flash中正確恢復到RAM,系統(tǒng)上電工作步驟如圖1所示。
   

DSP首先自檢,得到程序的加載模式。在C6000中主要有2種模式,一種是主機加載模式,也即DSP從0x0000 0000開始執(zhí)行程序;另一種是ROM加載模式,該模式又有8位、16位、32位幾種,不同的DSP略有不同,這里選用8位ROM模式,工作時,DSP先從地址0x9000 0000開始,把0x9000 0000-0x9000 0400這1K(在C62xx中是64K)的數(shù)據(jù)搬到0x0000 0000-0x0000 0400,然后再從0x0000 0000開始執(zhí)行程序,這一次加載由DSP自行完成,但是1K的程序作為用戶程序顯然不夠,因此,這1K的程序要做成加載其,也就是手工寫的Bootloader,利用它把用戶程序從Flash搬入RAM。加載器搬運用戶程序又是一次加載,因此把這個過程統(tǒng)稱為二次加載。

Bootloader要完成兩項功能,第一,把其他程序搬到指定的地址,第二、跳轉(zhuǎn)到用戶程序入口,這里要先修改ISP,再跳轉(zhuǎn)到復位中斷,因此在Bootloader的最后總是一條跳轉(zhuǎn)指令。由于Bootloader在Flash中的位置是0x9000 0000-0x9000 0400,而Bootloader又是放在用戶程序里的,因此,為了方便燒寫程序把Bootloader寫到該位置,這里在用戶成程序的.cmd文件中把Bootloader定位在程序段的起始位置。

編程方法實現(xiàn)

系統(tǒng)配置和參數(shù)設置

TMS320DM642是TI公司的一款視頻圖像DSP,工作時鐘最高可達到600MHz,程序存儲器最大可調(diào)至272M×8位,其EMIF接口分4個空間,即CE0-CE3,F(xiàn)lash映射到CE1空間,其地址為0x9000 0000-0x90400000,上電時采用8位ROM加載方式。

Am29LV033C是AMD公司生產(chǎn)的Flash存儲器,其主要特點有:3.3V單電源供電,可使內(nèi)部產(chǎn)生高電壓進行編程和擦除操作;只需向其命令寄存器寫入標準的微處理器指令,具體編程、擦除操作由內(nèi)部嵌入的算法實現(xiàn),并且可以通過查詢特定的引腳和數(shù)據(jù)線監(jiān)控操作是否完成,可以對任一扇區(qū)進行讀、寫或擦除操作,而不影響其他部分的數(shù)據(jù)。

由于4MB的Flash ROM有22根地址線,而DM642只有20根地址線,因此加入FPGA,對Flash進行分頁,這里分8頁,每頁512KB,每頁內(nèi)含8塊,每塊64KB。

Am29LV033C有多條內(nèi)存指令,可以實現(xiàn)芯片ID的讀取、軟件復位、整片擦除、塊擦除等。在這里主要介紹燒寫時用到的指令,其擦寫命令如表1所示,表中的XXX表示任意地址,SA為塊地址,即地址線的第16位到21位,PA為燒寫地址,PD為燒寫數(shù)據(jù)。待燒寫程序(用戶程序)為USER.out,大小為2M;燒寫程序為FBCT.out,大小為4K,地址分配如表2所示。




編程過程

第一步,對整個Flash進行一遍擦除,因此Flash在編程時只能把“1”置為“0”,而不能“0”置為“1”。

第二步,判斷擦除結束。通過DQ6、DQ7均可完成判斷,當DQ6位不再跳變時說明擦除結束。這里通過讀取最后一位數(shù)據(jù)是否為“0xFF”來完成判斷。

第三步,進行軟件復位。軟件復位使Flash處于就緒狀態(tài),當Flash在進行擦除,編程時軟件復位信號無效。

第四步,取得編程地址。如果地址超過最大地址則編程結束。

注意事項

對于不同的DSP,不同的Flash,在實現(xiàn)時可能不一樣,這里有幾個問題必須注意:

(1)文件1和文件2的.cmd文件要分配好各自的地址,地址空間不能重疊。

(2)不是每個DSP都可以實現(xiàn)在系統(tǒng)編程,如TMS320C6204就不行,而C621x,C64x等就可以。原因在于Flash在編程時速度較慢,一般為μs級,所以需要WE#信號的有效時間較長。但是,一般的WE#有效時間都只有幾十ns,這么短的時間不足以讓DSP把內(nèi)容寫進Flash。C64x等之所以能實現(xiàn)在系統(tǒng)編程,是因為在編程時DSP自動延長了編程的有效時間。

(3)如果用戶程序不含加載器程序,那么用戶程序的目的地址就不能從Flash的前1K的地址開始。

(4)不同型號Flash的編程時序和指令可能會有所不同,編程之前要弄清該Flash的編程時序和指令。如果Flash要求有偏移地址,就需要加上基地址。

(5)對于程序的未初始化段不必燒入Flash,可以參考.map文件,里面對于各段有詳細說明。

結語

利用上面的方法,本文在TMS320DM642平臺中通過JTAG仿真頭,成功地實現(xiàn)了在系統(tǒng)編程,為程序的調(diào)試提供了一種非常方便的手段,也為用戶程序的升級提供了一種簡單異行的方法,同時這個方法也在C6211環(huán)境下成功實現(xiàn),其他DSP同樣可參考本方法。
本文地址:http://m.qingdxww.cn/thread-25140-1-1.html     【打印本頁】

本站部分文章為轉(zhuǎn)載或網(wǎng)友發(fā)布,目的在于傳遞和分享信息,并不代表本網(wǎng)贊同其觀點和對其真實性負責;文章版權歸原作者及原出處所有,如涉及作品內(nèi)容、版權和其它問題,我們將根據(jù)著作權人的要求,第一時間更正或刪除。
您需要登錄后才可以發(fā)表評論 登錄 | 立即注冊

廠商推薦

  • Microchip視頻專區(qū)
  • 使用SAM-IoT Wx v2開發(fā)板演示AWS IoT Core應用程序
  • 使用Harmony3加速TCP/IP應用的開發(fā)培訓教程
  • 集成高級模擬外設的PIC18F-Q71家族介紹培訓教程
  • 探索PIC16F13145 MCU系列——快速概覽
  • 貿(mào)澤電子(Mouser)專區(qū)

相關在線工具

相關視頻

關于我們  -  服務條款  -  使用指南  -  站點地圖  -  友情鏈接  -  聯(lián)系我們
電子工程網(wǎng) © 版權所有   京ICP備16069177號 | 京公網(wǎng)安備11010502021702
快速回復 返回頂部 返回列表
主站蜘蛛池模板: 日韩一区二区免费视频 | 韩国一级成a人片在线观看 韩国一级a毛片 | 国产综合成人亚洲区 | 亚洲产在线精品第一站不卡 | 亚洲免费大全 | 最新版天堂资源中文下载 | 2022国产男人亚洲欧美天堂 | 国产精品久久久一区二区三区 | 日日日夜夜夜夜 | 色噜噜狠狠狠综合曰曰曰 | 四虎影视国产精品亚洲精品hd | 亚洲综合精品一二三区在线 | 91app入口下载免费 | 成人在线免费视频播放 | 国产精品热久久毛片 | 91播放| 青青青在线视频播放免费 | 婷婷麻豆 | 国产不卡精品一区二区三区 | 欧美日韩国产综合一区二区三区 | 亚洲欧美日韩中文字幕在线一区 | 欧美在线一区二区三区精品 | 一级网站在线观看 | 国产精品欧美一区喷水 | 亚洲精品不卡在线 | 精品一成人岛国片在线观看 | 黄色试频 | 经典三级一区在线播放 | 精品国产免费福利片 | 无吗无卡v清免费 | 热re99久久精品国99热 | 亚洲天堂色 | 国产精品妖精视频 | 香港黄页亚洲一级 | 99视频观看| 日韩国产午夜一区二区三区 | 精品一区 二区三区免费毛片 | 轻点灬大ji巴太粗太大了小说 | 四虎永久在线观看 | 亚洲乱码卡一卡二卡三 | 免费精品一区二区三区在线观看 |