新聞中心

EEPW首頁 > 嵌入式系統(tǒng) > 設(shè)計應(yīng)用 > 單片機系統(tǒng)Flash存儲器在系統(tǒng)編程設(shè)計

單片機系統(tǒng)Flash存儲器在系統(tǒng)編程設(shè)計

作者: 時間:2011-09-16 來源:網(wǎng)絡(luò) 收藏

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

本文引用地址:http://m.butianyuan.cn/article/172492.htm

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

1 Flash存儲器的在系統(tǒng)編程技術(shù)

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

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

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

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

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

3 在系統(tǒng)編程的實現(xiàn)

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

圖1 硬件方案

3.2 在系統(tǒng)編程的軟件方案
復(fù)位進入上電引導(dǎo)模式后,會自動進行串口的初始化等操作,然后通過串口接收程序,放到RAM內(nèi),并自動跳到此程序執(zhí)行。設(shè)計中依靠這個程序?qū)崿F(xiàn)對外部Flash存儲器的編程。

3.2.1 程序
此程序需要下載到M68HC11內(nèi)部RAM中,在引導(dǎo)程序完成后開始執(zhí)行。在本系統(tǒng)中用于實現(xiàn)與計算機繼續(xù)通訊接收程序代碼,并且用接收的代碼對外部Flash存儲器AM29F010B進行編程。

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

/3初始化,程序在RAM地址中存放,將單片切換到擴展模式,并設(shè)置波特率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

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

存儲器相關(guān)文章:存儲器原理



上一頁 1 2 下一頁

評論


相關(guān)推薦

技術(shù)專區(qū)

關(guān)閉