基于SST89C54/58的單片機(jī)仿真器的設(shè)計(jì)
1 概 述
SST89C54/58(簡(jiǎn)稱89C54/58)是美國(guó)SST公司推出的多用途51系列單片機(jī),片內(nèi)集成了20 kB/36 kB的SuperFlashE'PROM程序存儲(chǔ)器,分為BLOCK0(16kB/32kB)和BLOCKl(4kB)兩塊。其中,BLOCKl可以映射(Mapping)到64kB存儲(chǔ)空間的最高端或最低端,而且,對(duì)于程序計(jì)數(shù)器來(lái)說(shuō)可以是不可見(jiàn)的。由于其存儲(chǔ)結(jié)構(gòu)上獨(dú)特的優(yōu)點(diǎn),使得89C54/58非常適合于用做單片機(jī)仿真器。
2 SST89C54/58的程序存儲(chǔ)結(jié)構(gòu)
2.1 存儲(chǔ)器結(jié)構(gòu)
89C54/58片內(nèi)的存儲(chǔ)塊BLOCK0占據(jù)從0000H到3FFFH/7FFFH的存儲(chǔ)空間,BLOCKl占據(jù)從F000H到FFFFH的存儲(chǔ)空間。89C54/58存儲(chǔ)結(jié)構(gòu)如圖1所示。
當(dāng)EA#=1時(shí),對(duì)于程序計(jì)數(shù)器來(lái)說(shuō),BLOCK0始終是可見(jiàn)的,用于代碼的存取;BLOCKl代碼的存取是通過(guò)特殊功能寄存器SFCM,SFCF,SFAL,SFAH,SFDT和SFST來(lái)實(shí)現(xiàn)的。當(dāng)SFCF[7]=1時(shí),BLOCKl是可見(jiàn)的。
2.2 存儲(chǔ)器再映射(Re-mapping)
89C54/58的存儲(chǔ)器再映射功能使得對(duì)BLOCK0進(jìn)行編程時(shí),其系統(tǒng)中斷向量區(qū)依然可用(普通8051系列單片機(jī)無(wú)此特點(diǎn))。89C54/58提供4種存儲(chǔ)器再映射方式,存儲(chǔ)器再映射數(shù)量的大小由MAP_ENCl:0)控制,當(dāng)MAP-
3 基于SST89C58的單片機(jī)仿真器的設(shè)計(jì)
3.1 設(shè)計(jì)原理簡(jiǎn)介
仿真器電路設(shè)計(jì)如圖2所示。圖中U2為串行通信接口芯片MAX232,U1為89C54/58。89C54/58的監(jiān)控程序通過(guò)PC機(jī)串行口與KEILC51進(jìn)行通信,實(shí)現(xiàn)實(shí)時(shí)仿真功能。
3.2 仿真器監(jiān)控程序的加栽
SST公司提供的89C54/58仿真器監(jiān)控程序SoftlCE(Softwareln-CircuitEmulator)可通過(guò)SST公司提供的BSL(Boot-StrapLoader)加載或通過(guò)支持SST89C54/58的第三方編程器寫入。
3.3 仿真器性能簡(jiǎn)介
基于89C54/58的單片機(jī)仿真器除不支持串行口仿真外,具有通用仿真器的所有功能。與KEIL軟件相結(jié)合,可完成大部分單片機(jī)應(yīng)用系統(tǒng)的仿真設(shè)計(jì)。
其具體性能如下:
(1)可下載IntelHEX格式文件。
(2)支持匯編及C51源代碼調(diào)試。
(3)支持在線匯編。
(4)支持單步(Step)功能。
(5)支持步越(StepOver)功能。
(6)最大可設(shè)置10個(gè)固定斷點(diǎn)和一個(gè)臨時(shí)斷點(diǎn)。
(?)支持讀寫數(shù)據(jù)存儲(chǔ)器。
(8)支持讀寫程序存儲(chǔ)器。
(9)支持讀寫特殊功能寄存器。
(10)支持讀寫端口。
(11)具有IAP(1n-ApplicationProgramming)功能。
3.4 KEIL軟件及設(shè)置
KEIL C51是德國(guó)KEIL公司推出的Windows版的8051系列單片機(jī)開(kāi)發(fā)套件,可用于編譯C源程序、匯編源程序,鏈接和定位目標(biāo)文件和庫(kù),創(chuàng)建HEX文件以及調(diào)試目標(biāo)程序,并內(nèi)嵌有RTX51實(shí)時(shí)操作系統(tǒng),可簡(jiǎn)化復(fù)雜的多任務(wù)實(shí)時(shí)應(yīng)用系統(tǒng)的設(shè)計(jì)。與89C54/58仿真器配合時(shí),在KEIL開(kāi)發(fā)環(huán)境中設(shè)置如下:
(1)創(chuàng)建項(xiàng)目,并選擇SST單片機(jī)SST89C54/58。
(2)從菜單選擇"Options for,Target 1/。
(3)在"OptionsforTarget,Targetl"窗口中,選擇使用KEILMonitor-51Driver,如圖3所示。
(4)雙擊圖3中Settings鍵,設(shè)置目標(biāo)參數(shù)如圖4所示,即可編譯調(diào)試目標(biāo)程序。
4 結(jié) 語(yǔ)
綜上所述,由于SST89C54/58獨(dú)特的存儲(chǔ)器結(jié)構(gòu),使得89C54/58除用做通用的51單片機(jī)外,只需配以少量的外圍電路,即可做成51系列單片機(jī)仿真器。與功能強(qiáng)大的KEIL軟件相結(jié)合,為單片機(jī)工程師提供實(shí)時(shí)仿真開(kāi)發(fā)環(huán)境,可完成大部分單片機(jī)應(yīng)用系統(tǒng)的設(shè)計(jì).詳細(xì)設(shè)計(jì)資料可從SST公司網(wǎng)站(www.sst.com)下載。
評(píng)論