新聞中心

        EEPW首頁 > 嵌入式系統 > 設計應用 > 單片機系統Flash存儲器在系統編程設計

        單片機系統Flash存儲器在系統編程設計

        作者: 時間:2011-09-16 來源:網絡 收藏

        隨著排放法規的加嚴,發動機電子控制單元(ECU)成為了現代汽車中一個必備部分。在發動機控制單元這種中,已成為其一個基本配置,主要用來存放控制程序代碼。

        本文引用地址:http://www.104case.com/article/172492.htm

        將程序代碼裝入的方法有3種:第1種方法是要求供應商在發貨前將數據寫入,但無法滿足產品開發階段修改程序的要求;第2種方法是使用,但由于存儲器正在向小型化、貼片式發展,從而使Flash存儲器難以利用器編程;第3種方法是將存儲器安裝到電路板上進行編程,即在編程(In System Programming,ISP),這種編程方式是通過的微處理器實現對Flash存儲器的編程,不需要其他編程設備和附加編程電源,具有靈活、方便的優點。因此,在發動機控制單元時,結合M68HC11上電引導程序實現了存儲器AM29F010B的在系統編程。

        1 Flash存儲器的在系統編程技術

        AM29F010B是AMD公司生產的Flash存儲器,這種Flash存儲器編程簡單。此芯片僅需5V單電源供電便可使內部產生高電壓進行編程和擦除操作。用戶只需向其命令寄存器寫入標準的微處理器指令,具體編程、擦除操作便由內部電路實現。

        在編寫程序時需要注意,由于只有擦除指令能使“0”變為“1”,擦除結果為“1”;而編程指令不能使“0”寫為“l”,所以用戶在進行Flash存儲器編程時,應先擦除,再進行編程。

        2 M68HC11與上電引導模式(Bootstrap Mode)

        M68HC11是由Motorola公司推出的微處理芯片(Microcontroller Unit,MCU),由于其優越的性能,目前在發動機控制領域有著廣泛地使用。M68HC11具有一種上電引導模式,使得用戶程序可以通過串行接口(SCI)下載到內部的RAM區中,然后將M68HC11轉到用戶程序中執行。下載的程序可以像任何普通用戶程序一樣運行。雖然上電引導模式是一種單芯片模式,但是在這種模式下可以改變模式控制字,因此同樣可以訪問外部資源。

        硬件的模式選擇通過MCU復位時MODA和MODB管腳進行控制,MODA和MODB的邏輯狀態在RESET管腳電平變高之前被鎖存。當RE2SET管腳變高后,模式選擇管腳對MCU的運行模式不再起作用。復位時如果MODA和MODB管腳全為低電平,則MCU進入上電引導模式。

        3 在系統編程的實現

        3.1 硬件方案
        為了通過M68HC11對AM29F010B進行在系統編程,除了基本組件的之外,本系統在硬件方面做了以下準備:
        1)為了能夠從計算機上下載程序代碼,即與計算機進行通訊,本系統設計了MAX232進行TTL電平和RS232電平的轉換;
        2)為了使MCU開機或者復位能夠進入上電引導模式,需要在MODA和MODB管腳處設計跳線,使復位時為低電平。硬件方案簡圖見圖1。

        圖1 硬件方案

        3.2 在系統編程的軟件方案
        復位進入上電引導模式后,會自動進行串口的初始化等操作,然后通過串口接收程序,放到RAM內,并自動跳到此程序執行。設計中依靠這個程序實現對外部Flash存儲器的編程。

        3.2.1 程序
        此程序需要下載到M68HC11內部RAM中,在引導程序完成后開始執行。在本系統中用于實現與計算機繼續通訊接收程序代碼,并且用接收的代碼對外部Flash存儲器AM29F010B進行編程。

        程序的執行過程為1)進行初始化操作;2)等待開始字節“W”;3)等待編程開始地址;4)擦除Flash EPROM,并發送擦除后的地址FFFE和FFFF處數據;5)接收二進制數據,執行編程操作;6)發送AA表明編程成功,并開始執行外部程序。由于M68HC11的RAM只有256個字節,因此程序用匯編語言進行編寫,下面是其中幾個子程序。

        /3初始化,程序在RAM地址中存放,將單片切換到擴展模式,并設置波特率96003/
        ORG$0
        START LDS #$FF
        LDX #$1000
        BSET hprio,X,#00100000B
        BCLR hprio,X,#00010000B
        BCLR hprio,X,#01000000B
        LDAA #00110000B
        STAA BAUD
        /3片擦除子程序3/
        ERASE_FLASH  ldab   #$AA
        stab  $555
        ldab  #$55
        stab  $2AA
        ldab  #$80
        stab  $555
        ldab  #$AA
        stab  $555
        ldab  #$55
        stab  $2AA
        ldab  #$10
        stab  $555
        rts
        /3編程子程序3/
        FlashProgByte  ldab  #$AA
        stab  $555
        ldab  #$55
        stab  $2AA
        ldab  #$A0
        stab  $555
        staa  X

        這是根據AM29F010B編程的時序要求編寫的程序,其時序見表1、表2。

        存儲器相關文章:存儲器原理



        上一頁 1 2 下一頁

        評論


        相關推薦

        技術專區

        關閉
        主站蜘蛛池模板: 都昌县| 东明县| 靖安县| 洪洞县| 商都县| 千阳县| 漳平市| 麻阳| 临朐县| 金阳县| 扎兰屯市| 子洲县| 霍林郭勒市| 乃东县| 手机| 奎屯市| 鹤庆县| 小金县| 噶尔县| 景洪市| 麻城市| 崇明县| 鞍山市| 高台县| 湖北省| 岱山县| 临夏县| 宜州市| 翁牛特旗| 巧家县| 延寿县| 邻水| 东光县| 岳阳县| 白水县| 沙湾县| 乌拉特前旗| 陇西县| 长武县| 清徐县| 永济市|