一種單片機(jī)控制的指令轉(zhuǎn)換器的設(shè)計
1 引言
本文引用地址:http://www.ex-cimer.com/article/171804.htm在某大型指揮控制系統(tǒng)中,由于指令發(fā)送裝置與接收裝置的指令格式有很大的區(qū)別,兩者不能直接通信。而更換其中之一都會造成巨大的資金浪費,指令轉(zhuǎn)換器的目的就是在不改變發(fā)送和接收裝置的情況下對發(fā)送裝置所產(chǎn)生的指令進(jìn)行格式轉(zhuǎn)換,使產(chǎn)生的指令格式與接收裝置所能接收的指令格式一致,實現(xiàn)整個系統(tǒng)的順利通信。
2 硬件設(shè)計
2.1 總體結(jié)構(gòu)
指令轉(zhuǎn)換器的硬件總體結(jié)構(gòu)如圖2-1所示。所有電路模塊集中在一塊印刷電路板上,主要有89C51單片機(jī)、串口擴(kuò)展電路、中斷擴(kuò)展電路、監(jiān)測電路、靜態(tài)存貯器擴(kuò)展電路、輸出電路及分頻電路等幾個部分,下面將對各部分進(jìn)行詳細(xì)介紹。
2.2 中央控制單元
2.2.1時鐘電路
89C51的內(nèi)部有一個用于構(gòu)成振蕩器的高增益反相放大器,引腳XTAL1和XTAL2分別是此放大器的輸入端和輸出端,這個放大器與作為反饋元件的片外諧振器一起構(gòu)成一個自激振蕩器。89C51有內(nèi)部和外部兩種時鐘方式,本系統(tǒng)采用外部時鐘方式。
2.2.2復(fù)位電路
復(fù)位電路設(shè)計的核心是:在振蕩器運行時,保證89C51的RST引腳上出現(xiàn)10ms以上穩(wěn)定的高電平,這樣可以使89C51可靠地復(fù)位。常用的復(fù)位電路有上電復(fù)位、電平開關(guān)復(fù)位、兩種復(fù)位電路相結(jié)合的控制電路等,本系統(tǒng)采用上電復(fù)位電路。
2.3 串口擴(kuò)展電路
89C51單片機(jī)僅有一個異步串行通信接口,而指令轉(zhuǎn)換器需要同時與指令發(fā)送裝置、指令接收裝置進(jìn)行通信,需要兩個專用的串行口,利用Intel 8251擴(kuò)展串行口,可有效解決問題。8251可用于同步和異步傳輸。異步傳送時,可傳送5-8bits字符,時鐘速率為通信波特率的1、16或64倍;可產(chǎn)生1、1.5或2位的停止位,可檢查假啟動位,自動監(jiān)測和處理終止字符;完全雙工,具有雙緩沖器發(fā)送和接收器;具有奇偶、溢出和幀錯誤檢測電路。本系統(tǒng)用兩片8251進(jìn)行擴(kuò)展串口,其片選地址分別為#1FFFH、#3FFFH。
2.4 外部數(shù)據(jù)存儲器擴(kuò)展電路
89C51單片機(jī)內(nèi)部有128個字節(jié)RAM存儲器。CPU對內(nèi)部RAM具有豐富的操作指令。但在用于實時數(shù)據(jù)采集和處理時,僅靠內(nèi)部的128個字節(jié)的數(shù)據(jù)存儲器是遠(yuǎn)遠(yuǎn)不夠的,在這種情況下,可以利用89C51的擴(kuò)展功能,擴(kuò)展外部存儲器。
2.5 中斷擴(kuò)展電路
89C51單片機(jī)僅提供了兩個外部中斷源,而指令格式轉(zhuǎn)換器需要四個中斷源,為了解決此問題,利用能夠管理多級中斷請求Intel 8259A來進(jìn)行中斷擴(kuò)展是一個有效的辦法。
由于8259A與 89C51的接口并不完全兼容,因此必須對89C51輸出的控制信號進(jìn)行相應(yīng)的變換后再對8259A進(jìn)行控制。這需要解決硬件與軟件兩個問題,下面先給出硬件解決方案。
硬件方面,當(dāng)8259A發(fā)出中斷請求信號INT=1后,要求CPU返回一個中斷應(yīng)答信號 送至8259A,以控制8259A調(diào)用機(jī)器指令碼的發(fā)送,但89C51不會自動發(fā) =0的信號,可以通過對89C51的 信號與INT信號相結(jié)合,如圖2-2所示,通過CPU連續(xù)執(zhí)行三條指令MOVX A,@R0指令可產(chǎn)生8259A的 所需要的中斷應(yīng)答信號。
2.6 輸出電路
為了使信號轉(zhuǎn)換器和指令發(fā)送裝置之間能夠通信,本系統(tǒng)采用標(biāo)準(zhǔn)異步通信接口RS-232作為輸出端口。
RS-232電路采用MAXIM公司的232專用接口芯片MAX238DIP,該芯片單5V供電,包含4路收,4路發(fā),可以全雙工方式工作,MAX238DIP引腳定義及典型應(yīng)用電路如圖2-3所示,引腳定義見表2-1,T1IN、T2IN、T3IN、T4IN到T1OUT、T2OUT、 T3OUT、T4OUT實現(xiàn)驅(qū)動輸入到232轉(zhuǎn)換,R1IN、R2IN、R3IN、R4IN到R1OUT、R2OUT、R3OUT、R4OUT實現(xiàn)232 到驅(qū)動輸出轉(zhuǎn)換。
表2-1 MAX238DIP引腳定義
評論