單片機(jī)系統(tǒng)Flash存儲(chǔ)器在系統(tǒng)編程設(shè)計(jì)
隨著排放法規(guī)的加嚴(yán),發(fā)動(dòng)機(jī)電子控制單元(ECU)成為了現(xiàn)代汽車中一個(gè)必備部分。在發(fā)動(dòng)機(jī)控制單元這種單片機(jī)系統(tǒng)中,Flash存儲(chǔ)器已成為其一個(gè)基本配置,主要用來存放控制程序代碼。
本文引用地址:http://butianyuan.cn/article/172492.htm將程序代碼裝入Flash存儲(chǔ)器的方法有3種:第1種方法是要求供應(yīng)商在存儲(chǔ)器發(fā)貨前將數(shù)據(jù)寫入,但無法滿足產(chǎn)品開發(fā)階段修改程序的要求;第2種方法是使用編程器編程,但由于Flash存儲(chǔ)器正在向小型化、貼片式發(fā)展,從而使Flash存儲(chǔ)器難以利用編程器編程;第3種方法是將存儲(chǔ)器安裝到電路板上進(jìn)行編程,即在系統(tǒng)編程(In System Programming,ISP),這種編程方式是通過系統(tǒng)的微處理器實(shí)現(xiàn)對(duì)Flash存儲(chǔ)器的編程,不需要其他編程設(shè)備和附加編程電源,具有靈活、方便的優(yōu)點(diǎn)。因此,在設(shè)計(jì)發(fā)動(dòng)機(jī)控制單元時(shí),結(jié)合M68HC11上電引導(dǎo)程序設(shè)計(jì)實(shí)現(xiàn)了存儲(chǔ)器AM29F010B的在系統(tǒng)編程。
1 Flash存儲(chǔ)器的在系統(tǒng)編程技術(shù)
AM29F010B是AMD公司生產(chǎn)的Flash存儲(chǔ)器,這種Flash存儲(chǔ)器編程簡(jiǎn)單。此芯片僅需5V單電源供電便可使內(nèi)部產(chǎn)生高電壓進(jìn)行編程和擦除操作。用戶只需向其命令寄存器寫入標(biāo)準(zhǔn)的微處理器指令,具體編程、擦除操作便由內(nèi)部電路實(shí)現(xiàn)。
在編寫程序時(shí)需要注意,由于只有擦除指令能使“0”變?yōu)?ldquo;1”,擦除結(jié)果為“1”;而編程指令不能使“0”寫為“l”,所以用戶在進(jìn)行Flash存儲(chǔ)器編程時(shí),應(yīng)先擦除,再進(jìn)行編程。
2 M68HC11與上電引導(dǎo)模式(Bootstrap Mode)
M68HC11是由Motorola公司推出的微處理芯片(Microcontroller Unit,MCU),由于其優(yōu)越的性能,目前在發(fā)動(dòng)機(jī)控制領(lǐng)域有著廣泛地使用。M68HC11具有一種上電引導(dǎo)模式,使得用戶程序可以通過串行接口(SCI)下載到內(nèi)部的RAM區(qū)中,然后將M68HC11轉(zhuǎn)到用戶程序中執(zhí)行。下載的程序可以像任何普通用戶程序一樣運(yùn)行。雖然上電引導(dǎo)模式是一種單芯片模式,但是在這種模式下可以改變模式控制字,因此同樣可以訪問外部資源。
硬件的模式選擇通過MCU復(fù)位時(shí)MODA和MODB管腳進(jìn)行控制,MODA和MODB的邏輯狀態(tài)在RESET管腳電平變高之前被鎖存。當(dāng)RE2SET管腳變高后,模式選擇管腳對(duì)MCU的運(yùn)行模式不再起作用。復(fù)位時(shí)如果MODA和MODB管腳全為低電平,則MCU進(jìn)入上電引導(dǎo)模式。
3 在系統(tǒng)編程的實(shí)現(xiàn)
3.1 硬件方案
為了通過M68HC11對(duì)AM29F010B進(jìn)行在系統(tǒng)編程,除了基本組件的設(shè)計(jì)之外,本系統(tǒng)在硬件方面做了以下準(zhǔn)備:
1)為了能夠從計(jì)算機(jī)上下載程序代碼,即與計(jì)算機(jī)進(jìn)行通訊,本系統(tǒng)設(shè)計(jì)了MAX232進(jìn)行TTL電平和RS232電平的轉(zhuǎn)換;
2)為了使MCU開機(jī)或者復(fù)位能夠進(jìn)入上電引導(dǎo)模式,需要在MODA和MODB管腳處設(shè)計(jì)跳線,使復(fù)位時(shí)為低電平。硬件方案簡(jiǎn)圖見圖1。
圖1 硬件方案
3.2 在系統(tǒng)編程的軟件方案
當(dāng)單片機(jī)復(fù)位進(jìn)入上電引導(dǎo)模式后,會(huì)自動(dòng)進(jìn)行串口的初始化等操作,然后通過串口接收程序,放到RAM內(nèi),并自動(dòng)跳到此程序執(zhí)行。設(shè)計(jì)中依靠這個(gè)程序?qū)崿F(xiàn)對(duì)外部Flash存儲(chǔ)器的編程。
3.2.1 單片機(jī)程序
此程序需要下載到M68HC11內(nèi)部RAM中,在引導(dǎo)程序完成后開始執(zhí)行。在本系統(tǒng)中用于實(shí)現(xiàn)與計(jì)算機(jī)繼續(xù)通訊接收程序代碼,并且用接收的代碼對(duì)外部Flash存儲(chǔ)器AM29F010B進(jìn)行編程。
程序的執(zhí)行過程為1)進(jìn)行初始化操作;2)等待開始字節(jié)“W”;3)等待編程開始地址;4)擦除Flash EPROM,并發(fā)送擦除后的地址FFFE和FFFF處數(shù)據(jù);5)接收二進(jìn)制數(shù)據(jù),執(zhí)行編程操作;6)發(fā)送AA表明編程成功,并開始執(zhí)行外部程序。由于M68HC11的RAM只有256個(gè)字節(jié),因此程序用匯編語言進(jìn)行編寫,下面是其中幾個(gè)子程序。
/3初始化,程序在RAM地址中存放,將單片切換到擴(kuò)展模式,并設(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編程的時(shí)序要求編寫的程序,其時(shí)序見表1、表2。
存儲(chǔ)器相關(guān)文章:存儲(chǔ)器原理
評(píng)論