蔣俊華,侯衛(wèi)周
(河南大學(xué) 物理與電子學(xué)院,河南 鄭州 475001)
ISA總線最早作為一種系統(tǒng)總線,主要用在IBM-PC、IBMPC/XT系列計算機(jī)當(dāng)中,后來成為工業(yè)總線標(biāo)準(zhǔn),并且產(chǎn)生了深遠(yuǎn)的影響。由于技術(shù)的不斷發(fā)展,ISA總線的傳輸速率跟不上處理器的速度,從而被其他總線所取代。
然而正是由于ISA總線的低速使得其與現(xiàn)在的外設(shè)速率十分匹配,適合作為一種外圍設(shè)備總線,用于擴(kuò)展設(shè)備接口。并且ISA總線的地址線是非常多的,可以連接數(shù)量龐大的設(shè)備。綜合這兩點(diǎn)原因,ISA總線在工業(yè)控制領(lǐng)域仍然占有一席之地,并且ISA總線工業(yè)領(lǐng)域中的應(yīng)用還會持續(xù)一段很長的時間[1]。
USB外設(shè)普及之后,將會使得PC機(jī)箱后面的各式各樣繁雜的連接線變得簡單,大多數(shù)老式的接口將被淘汰,如ISA接口、PS/2接口、串并行接口等,取而代之的是各種USB接口的外設(shè)[2-3]。但有些接口是USB無法取代的,如顯示器接口、SCSI接口和IEEE1394接口等。不過這還是不能阻擋USB接口的發(fā)展。
其實除了如顯卡這種數(shù)據(jù)傳輸量極高和一些對實時性要求特別高的控制設(shè)備外,幾乎所有的PC外設(shè)都可以移植到USB上來,因此USB的PC外設(shè)有不可限量的發(fā)展空間。正是基于這個原因,本文提出了一種設(shè)計方案,通過CH375芯片實現(xiàn)兩者之間的轉(zhuǎn)接。
本方案中采用CH375芯片實現(xiàn)ISA總線到USB總線的轉(zhuǎn)接。CH375是一個USB總線的通用接口芯片,支持USB-HOST主機(jī)方式和USB-DEVICE/SLAVE設(shè)備方式[4]。在本地端,CH375具有8位數(shù)據(jù)總線和讀、寫、片選控制線以及中斷輸出,可以方便地掛接到單片機(jī)、DSP、MCU、MPU等控制器的系統(tǒng)總線上[5]。它內(nèi)置了USB通訊中的底層協(xié)議,屏蔽了復(fù)雜的底層驅(qū)動;通過Windows驅(qū)動程序提供設(shè)備級接口,通過DLL提供API應(yīng)用層接口。下圖是轉(zhuǎn)接板的整體模塊圖,板卡通過USB接頭和上位計算機(jī)連接,通過ISA接口插接在下位機(jī)的ISA插槽上。
圖1 轉(zhuǎn)接板模塊圖Fig.1 The adapter plate module diagram
CH375芯片與外圍芯片連接電路如圖2所示。
圖2 CH375外圍電路連接圖Fig.2 The peripheral circuit connection diagram
UD+、UD-引腳分別連接USB總線的D+、D-數(shù)據(jù)線。
ACT#是CH375設(shè)備狀態(tài)輸出端,當(dāng)CH375作為USB設(shè)備配置完成后,該引腳輸出低電平,可以用來指示CH375的狀態(tài)。
INT#引腳為中斷請求輸出,將其連接到單片機(jī)的中斷0引腳。
CS#片選控制輸入引腳,將其接到單片機(jī)P2.7管腳。
A0是CH375數(shù)據(jù)端口和命令端口的選擇引腳,A0接到單片機(jī)的P2.6管腳。
RD#和WR#分別接到單片機(jī)的讀寫信號引腳。
D0~D7是數(shù)據(jù)總線,分別與單片機(jī)的P0.0~P0.7連接。
本設(shè)計中用了兩個74HC245,分別將數(shù)據(jù)信號、地址信號和讀寫控制信號引入到下位機(jī)中。采用74LS573芯片作為鎖存器。1)74LS573的使能端OE#引腳接地使其一直有效。2)LE為鎖存使能輸入端,當(dāng)其從高電平轉(zhuǎn)為低電平時鎖存輸入的數(shù)據(jù)(即為鎖存P0口的數(shù)據(jù))。由于單片機(jī)是在ALE的下降沿送出穩(wěn)定的地址信號,因此可將芯片的LE引腳直接與單片機(jī)的ALE連接。3)其他對應(yīng)連接即可[6]。
ISA總線的地址總線和數(shù)據(jù)總線是分開的,控制線也比較簡單,因而和單片機(jī)接口非常方便,可以直接接到ISA總線上。
本設(shè)計要完成的軟件程序設(shè)計主要是:上位機(jī)用戶界面應(yīng)用程序和下位單片機(jī)程序。
上位機(jī)的數(shù)據(jù)通過USB總線,由USB主機(jī)發(fā)送給CH375,CH375將接收的數(shù)據(jù)放入端點(diǎn)緩沖區(qū),接收完后通過中斷告知單片機(jī)數(shù)據(jù)接收完畢,然后單片機(jī)響應(yīng)中斷,在中斷中做相應(yīng)的處理,即在中斷中將數(shù)據(jù)轉(zhuǎn)換和發(fā)送到ISA總線。因此單片機(jī)的主要任務(wù)是與CH375通訊,接收CH375數(shù)據(jù)緩沖區(qū)中的數(shù)據(jù),然后再將數(shù)據(jù)經(jīng)過處理轉(zhuǎn)換成ISA總線信號后發(fā)送到ISA總線。圖3為主程序的流程圖。
圖4為CH375初始化子程序,其主要是測試和單片機(jī)的通訊是否正常,以及設(shè)置CH375的工作方式等。本文將CH375的工作方式設(shè)置為方式2,即內(nèi)置固件模式。
圖3 主程序流程圖Fig.3 The flowing chart of main program
圖4 CH375初始化子程序Fig.4 The CH375 initialization subprogram
圖5 單片機(jī)響應(yīng)CH375中斷子程序Fig.5 The interruption subprogram
圖5 是單片機(jī)中斷子程序,這是下位單片機(jī)程序最重要的部分,所有上位機(jī)程序發(fā)送的數(shù)據(jù)都是由中斷子程序響應(yīng)、接收和處理的。
中斷子程序如下:
CH375_INTER:PUSH PSW ;現(xiàn)場保護(hù)
PUSH ACC
PUSH DPL
PUSH DPH
SETB RS0;PSW.3,切換至工作寄存器組1
MOV DPTR,#CH375_CMD_PORT ;命令口地址
MOV A,#CMD_GET_STATUS
MOVX@DPTR,A;獲取中斷狀態(tài)并取消中斷請求
NOP;如果時鐘頻率低于16MHz則無需該指令延時,高于30MHz要多加2條指令
NOP
MOV DPTR,#CH375_DAT_PORT;數(shù)據(jù)口地址
MOVX A,@DPTR;返回操作狀態(tài)
CLR IE0;清中斷標(biāo)志,對應(yīng)于INT0中斷
CJNE A,#USB_INT_EP2_OUT,CH375_INT_1 ;批量端點(diǎn)下傳成功
LJMP CH375_DOWN_OK;USB批量數(shù)據(jù)接收成功CH375_INT_1: CJNEA,#USB_INT_EP2_IN,CH375_INT_2 ;批量端點(diǎn)上傳成功
LJMP CH375_UP_OK;USB批量數(shù)據(jù)發(fā)送成功
CH375_INT_2: CJNE A,#USB_INT_EP1_IN,CH375_INT_3;中斷端點(diǎn)
LJMP CH375_UP_INT_OK ;USB中斷數(shù)據(jù)發(fā)送成功
CH375_INT_3: SJMP CH375_INT_RET
CH375_INT_RET: POP DPH
POP DPL
POP ACC
POP PSW ;恢復(fù)寄存器
RETI ;中斷返回
本文采用了先部分后整體的調(diào)試方法,這樣可以節(jié)省時間,最快的速度發(fā)現(xiàn)問題。
把整個調(diào)試系統(tǒng)分成了兩部分,第一部分為上位機(jī)程序與單片機(jī)的通訊;第二部分為單片機(jī)與ISA總線的通訊。分別對此兩部分進(jìn)行調(diào)試,調(diào)試成功之后再將這兩部分組合成整體,最后進(jìn)行整體調(diào)試。
1)上位機(jī)與單片機(jī)數(shù)據(jù)傳送的調(diào)試
上位機(jī)部分由程序“調(diào)試程序V1.0.EXE”來完成控制,由他可以輸入I/O輸出板卡的地址以及要發(fā)送給ISA總線的數(shù)據(jù)。其主界面如圖6所示。
圖6 調(diào)試程序主界面Fig.6 The main interface debugging program
單片機(jī)部分由Keil C編程軟件、仿真器以及USB-ISA轉(zhuǎn)接卡組成。將仿真器的仿真頭連接到USB-ISA轉(zhuǎn)接卡單片機(jī)位置,由Keil C編程軟件、仿真器共同完成仿真功能。Keil C軟件的編程和調(diào)試界面如圖6。
利用仿真器就可以查看數(shù)據(jù)是否成功到達(dá),調(diào)試記錄如表1所示。
表1 調(diào)試記錄Tab.1 Debug record
2)單片機(jī)與ISA總線數(shù)據(jù)傳送的調(diào)試
單片機(jī)部分即可用仿真器仿真,也可以直接用通過編程器燒寫了程序的單片機(jī),但相比較而言用仿真調(diào)試會比較方便。這部分調(diào)試主要是看由單片機(jī)發(fā)送的ISA總線數(shù)據(jù)能否被I/O輸出卡接收到。數(shù)據(jù)是否接收到可由顯示板來指示,顯示卡LED燈的亮滅狀態(tài)可以指示I/O輸出卡是否被選中,以及是否接收到單片機(jī)的控制信號。
程序控制向ISA總線的某個地址發(fā)送數(shù)據(jù),如果顯示板能夠顯示程序中發(fā)送的數(shù)據(jù)信息,則表明單片機(jī)與ISA總線通訊成功。
3)系統(tǒng)整體調(diào)試
當(dāng)上述兩個部分都調(diào)試成功之后,就可以開始系統(tǒng)的整體調(diào)試了。上面兩步的調(diào)試成功說明硬件原理和硬件連接正確,上位機(jī)調(diào)試程序也沒問題,接下來就只剩下單片機(jī)對接收到的數(shù)據(jù)的處理的軟件程序調(diào)試了。這個部分也相對比較簡單,單片機(jī)對ISA總線數(shù)據(jù)的處理跟對擴(kuò)展存儲器的操作一樣:指向某個地址然后發(fā)送數(shù)據(jù)。
圖7 Keil C調(diào)試界面Fig.7 Keil Cdebugging interface
本文將USB和ISA這兩種總線的特點(diǎn)融合在一起,設(shè)計并制作了USB-ISA轉(zhuǎn)接卡,適應(yīng)于各種工控系統(tǒng),在有ISA總線的場合基本上都可以應(yīng)用此轉(zhuǎn)接卡。ISA總線是一種適合于中低速I/O設(shè)備的總線,,因其多地址線和較慢的傳輸速率,ISA總線在工業(yè)領(lǐng)域中仍然應(yīng)用得非常廣泛。而USB總線又是一種非常方便的總線,受到越來越多的使用者的喜愛,USB的優(yōu)越的特性將會使其具有不可抵擋的發(fā)展勢頭。因此USB總線和ISA總線的結(jié)合必將會在工業(yè)領(lǐng)域產(chǎn)生深遠(yuǎn)的影響,可以預(yù)期USB-ISA轉(zhuǎn)接卡在工業(yè)領(lǐng)域中會有非常廣泛的應(yīng)用前景。
[1]張國云.基于ISA總線的USB接口卡的設(shè)計[J].現(xiàn)代電子技術(shù),2005,20(211):12-14.ZHANG Guo-yun.Design of USB interface card based on ISA bus[J].Modern Electronics Technique,2005,20(211):12-14.
[2]易先威,劉偉,何方.基于ISA總線的USB協(xié)議棧的設(shè)計與實現(xiàn)[J].小型微型計算機(jī)系統(tǒng),2005,26(11):2057-2059.YI Xian-wei,LIU wei,HE fang.Design of USB interface card based on ISA bus[J].MINI-macro System,2005,26 (11):2057-2059.
[3]沈曉紅,魯延峰,李凱.基于FPGA的ISA總線接口邏輯設(shè)計[J].微計算機(jī)信息,2011,27(7):110-111.SHEN Xiao-hong,LU Yan-feng,LI Kai.The logical design of ISA bus interface based on FPGA[J].Microcomputer Information,2011,27(7):110-111.
[4]魏景斌,劉俊峰,錢稷,等.基于CH375的USB數(shù)據(jù)傳輸[J].微計算機(jī)信息,2010,26(2):150-152.WEI Jing-bin,LIU Jun-feng,QIAN Ji,et al.Based on CH375 transmit data to USB[J].Microcomputer Information,2010,26(2):150-152.
[5]劉井權(quán),王憲,戴旻.基于單片機(jī)的USB接口的設(shè)計[J].自動化儀表,2006,27(8):29-31.LIUJing-quan,WANGXian,DAIMin.Design of USB min interface based on single chip computer[J].Process Automation Instrumentation,2006,27(8):29-31.
[6]安曉莉.AT89S51單片機(jī)并行I/O端口的擴(kuò)展[J].電子設(shè)計工程,2009,17(8):66-70.AN Xiao-li.Expansion of AT89S51 MCU parallel I/O port[J].Electronic Design Engineering,2009,17(8):66-70.