新聞中心

        EEPW首頁 > 嵌入式系統 > 設計應用 > 基于單片機的Flash在系統編程方法

        基于單片機的Flash在系統編程方法

        作者: 時間:2016-12-02 來源:網絡 收藏


        編程方法實現

        系統配置和參數設置

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

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

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

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




        編程過程

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

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

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

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

        注意事項

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

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

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

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

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

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

        結語

        利用上面的方法,本文在TMS320DM642平臺中通過JTAG仿真頭,成功地實現了在系統編程,為程序的調試提供了一種非常方便的手段,也為用戶程序的升級提供了一種簡單異行的方法,同時這個方法也在C6211環境下成功實現,其他DSP同樣可參考本方法。

        上一頁 1 2 下一頁

        評論


        技術專區

        關閉
        主站蜘蛛池模板: 静安区| 崇仁县| 江都市| 鲁甸县| 西充县| 鲁山县| 玛多县| 沭阳县| 茌平县| 壤塘县| 托里县| 馆陶县| 宿州市| 开封县| 固始县| 肥西县| 东辽县| 梅州市| 常宁市| 宝应县| 抚宁县| 剑阁县| 南城县| 馆陶县| 丹江口市| 无锡市| 沙雅县| 资溪县| 囊谦县| 鞍山市| 甘肃省| 永吉县| 彭州市| 昔阳县| 汨罗市| 谷城县| 桐梓县| 星座| 大宁县| 明溪县| 哈尔滨市|