基于uPSD3254A單片機的EPP并口通信技術(shù)

發(fā)布時(shí)間:2010-8-4 09:49    發(fā)布者:lavida
關(guān)鍵詞: EPP , uPSD3254A , 并口通信
在IBM公司推出PC機開(kāi)始,并口已經(jīng)是PC機的一部分。最初并口就是為代替串口來(lái)驅動(dòng)高性能點(diǎn)陣式打印機,并口通信有SPP、EPP、ECP三種傳輸模式,SPP模式是半雙工單向傳輸的,傳輸速率僅為15KB/S;EPP增強型模式采用雙向半雙工數據傳輸,傳輸速度高達2MB/S;ECP擴充型模式采用雙向全雙工數據傳輸,傳輸速率比EPP高。在設計和實(shí)現方面,EPP模式比ECP模式更靈活、簡(jiǎn)潔、可靠,在工業(yè)界得到了更多的實(shí)際應用。本文介紹的是一種基于uPSD3254A的EPP增強并口的設計,其核心是使用uPSD323X內部的CPLD實(shí)現EPP接口與PC機上并口之間的高速硬件通信,實(shí)際測試中速度達到了900KB/S。

1EPP協(xié)議介紹

EPP協(xié)議是由Intel、Xircom、Zenith三家公司聯(lián)合提出的,于1994年在IEEE1284標準中發(fā)布。EPP協(xié)議有EPP1.7和EPP1.9兩個(gè)標準,可以在PC機的BIOS/外圍設備/并行口BIOS/PeripheralSetup/ParallelPortMode)方式中進(jìn)行設置[3]。與傳統并行口標準利用軟件實(shí)現握手不同,EPP接口協(xié)議通過(guò)硬件自動(dòng)握手,能達到500KB/s~2MB/s的通信速率。

1.1EPP工作模式的寄存器和引腳定義

PC并口采用25針的DB型陰極接口,EPP工作模式的25個(gè)引腳的定義如表1所示。

表1EPP協(xié)議引腳定義


引腳號  

EPP信號  

方向  

是否反向  

說(shuō)明  

1  

nWrite  

輸出  

是  

低電平表示寫(xiě),高電平表示讀  

2"9  

Data0"7  

輸出/輸入  

否  

數據  

10  

Interrupt  

輸入  

否  

上升沿觸發(fā)中斷  

11  

nWait  

輸入  

是  

低電平傳輸數據/地址,高電平傳輸結束  

12  

Spare  

輸入  

否  

EPP未定義,可用戶(hù)自定義  

13  

Spare  

輸入  

否  

EPP未定義,可用戶(hù)自定義  

14  

nDstrb  

輸出  

是  

低電平表示數據傳輸  

15  

Spare  

輸入  

否  

EPP未定義,可用戶(hù)自定義  

16  

nReset  

輸出  

否  

低電平有效  

17  

nAstrb  

輸出  

是  

低電平表示地址傳輸  

18"25  

GND  

—  

—  

地  

在寄存器方面,EPP定義了8個(gè)寄存器,繼承了SPP的3個(gè)寄存器,其中EPP與SPP共用狀態(tài)寄存器和控制寄存器,保證了EPP模式和SPP模式軟硬件兼容型,其寄存器定義如表2所示。將并口設置為EPP方式時(shí),需要在PC機的BIOS中設置并口工作于EPP方式,寄存器組的基地址(BASE)通常設為0x378。

表2EPP寄存器定義


地址  

端口名稱(chēng)  

讀/寫(xiě)  

BASE+0  

SPP數據端口  

寫(xiě)  

BASE+1  

SPP/EPP狀態(tài)端口  

讀  

BASE+2  

SPP/EPP控制端口  

寫(xiě)  

BASE+3  

EPP地址端口  

讀/寫(xiě)  

BASE+4  

EPP數據端口  

讀/寫(xiě)  

BASE+5"+7  

用戶(hù)自定義  

—  

1.2EPP讀寫(xiě)周期

為了能進(jìn)行有效的EPP數據通信,必須遵循EPP的握手時(shí)序。與SPP的軟件握手相比,EPP采用硬件完成的握手實(shí)現了高速的數據通信速度。EPP協(xié)議共分為四種周期:數據寫(xiě)周期、數據讀周期、地址寫(xiě)周期和地址讀周期,數據周期用于計算機和外設間傳送數據;地址周期用于傳送地址、通道、命令、控制和狀態(tài)等輔助信息。

1.2.1EPP數據/地址讀周期如圖1所示

EPP數據/地址讀周期CPU讀操作步驟如下:

1)程序對EPP數據寄存器(Base+4)/地址寄存器(Base+3)執行讀操作

2)nDstrb/nAstrb被置低如果nWaite信號為低,否則等待

3)主機等待nWaite為高表示數據發(fā)送成功

4)從并口中讀取8位數據/地址

5)nDstrb/nAstrb被置高

6)EPP數據/地址讀周期完成



圖1EPP數據/地址讀周期

1.2.2EPP數據/地址寫(xiě)周期如圖2所示

EPP數據/地址寫(xiě)周期CPU寫(xiě)操作步驟如下:

1)程序對EPP數據寄存器(Base+4)/地址寄存器(Base+3)執行寫(xiě)操作

2)將nWrite信號置低(低表示寫(xiě)操作)

3)將要寫(xiě)的數據/地址數據送到數據總線(xiàn)

4)nDstrb/nAstrb被置低如果nWaite信號為低,否則等待

5)主機等待nWait握手信號為高表示發(fā)送成功

6)nDstrb/nAstrb被置高

7)EPP數據/地址寫(xiě)周期完成



圖2EPP數據/地址寫(xiě)周期

其中,使用EPP1.7(PreIEEE1284)握手標準時(shí),則nDstrb/nAstrb信號不考慮nWait是否為低,直接被置低開(kāi)始一個(gè)新的讀/寫(xiě)周期;如果使用EPP1.9握手標準,則只有在nWait信號為低時(shí),nDstrb/nAstrb信號才會(huì )被置低開(kāi)始一個(gè)新的讀/寫(xiě)周期。但是EPP1.7和EPP1.9都要求nWait信號為高時(shí)一個(gè)讀/寫(xiě)周期才結束。

由于nWait、nWrite、nDstrb、nAstrb等信號傳輸后反向(見(jiàn)表1),因此圖1和圖2中的時(shí)序是從PC端考慮的,nWait信號表示單片機發(fā)出的原始信號,在PC端實(shí)際采用的是與單片機發(fā)出的原始信號取反后的信號。

2uPSD323X及其開(kāi)發(fā)環(huán)境介紹

ST公司的uPSD3254A是帶8032內核的Flash可編程系統器件,具有在線(xiàn)編程能力和超強的保密功能;256+32Kbytes的Flash存儲器;片內8K的SDRAM;帶有16位宏單元的3000門(mén)可編程邏輯電路(CPLD),可以實(shí)現EPP接口等一些不太復雜的接口和控制功能,50個(gè)I/O引腳等。

基于Windows平臺的一套軟件開(kāi)發(fā)環(huán)境。只要點(diǎn)擊鼠標即可完成對地址鎖存器、Flash、可編程邏輯電路等外設的所有配置和寫(xiě)入。使用PSDsoftEXPRESS工具對uPSD3200系列器件的可編程邏輯電路的操作簡(jiǎn)單、直觀(guān)。

3.基于uPSD3254A的EPP接口實(shí)現


3.1硬件接口

EPP增強并口的速度最高可達到500KB/s~2MB/s,這對外設的接口有很高的要求,如果外設響應太慢,系統的整體性能將大大下降。但如果采用可編程邏輯器件,使接口的響應完全由硬件來(lái)完成,系統的整體性能將大大提高。這種實(shí)現方案可以達到并口中的速度極限,而且保密性好,EPP接口(EPP1.9)外設硬件接口原理如圖3所示。


圖3EPP接口外設硬件接口圖

在本設計中,uPSD3254A采用主動(dòng)連續接收PC機并口的數據,當需要數據時(shí),連續接收PC的數據,否則PC一直等待nWait信號有效。而當外設準備好數據上傳到PC機時(shí),PC機采用的是中斷方式接收外設的數據。

3.2CPLD邏輯編程

在PSDsoftEXPRESS工具中,將PA端口(D0~D7)配置成帶有時(shí)鐘上升沿觸發(fā)的寄存器類(lèi)型(PTclockedregister)的輸入宏,PB4(nWrite)、PB6(nDstrb)、PB7(nAstrb)配置成CPLD邏輯輸入(logicinput)口。nDstrb信號和nAstrb信號各自取反再相與后的值作為輸入宏單元的時(shí)鐘。上述對PA、PB端口的配置用方程式表示如下:

EPP_D0.LD=!nDstrb&!nAstrb;

EEP_D1.LD=!nDstrb&!nAstrb;

EEP_D2.LD=!nDstrb&!nAstrb;

EEP_D3.LD=!nDstrb&!nAstrb;

EEP_D4.LD=!nDstrb&!nAstrb;

EEP_D5.LD=!nDstrb&!nAstrb;

EEP_D6.LD=!nDstrb&!nAstrb;

EEP_D7.LD=!nDstrb&!nAstrb;

nAstrb.LE=1;

nDstrb.LE=1;

數據正向傳輸過(guò)程:即計算機向外設單片機傳輸數據(即EPP數據寫(xiě)周期)為例,計算機首先把nWrite信號置為低,表明是寫(xiě)周期,同時(shí)將數據放到數據總線(xiàn)上,然后檢測nWait信號,如果nWait為低則置低nDstrb信號。此時(shí),!nDstrb&!nAstrb信號會(huì )出現一個(gè)上升沿,此上升沿會(huì )將PA端口的數據鎖存到輸入宏;當單片機檢測到nDstrb為低時(shí)將nWait信號變高表示外設正忙接收數據并處理,同時(shí)讀取數據總線(xiàn)上的數據。當計算機檢測到nWait信號為高后就會(huì )將數據握手信號nDstrb變高,EPP數據寫(xiě)周期結束。上述EPP數據的鎖存和nDstrb握手信號的產(chǎn)生都由硬件產(chǎn)生,因此數據傳輸速度快。整個(gè)數據傳輸過(guò)程可以在一個(gè)I/O周期內完成。

數據反向傳輸過(guò)程:?jiǎn)纹瑱C準備好數據需要上傳到計算機時(shí),uPSD3254A將數據放到PA端口,同時(shí)置低Intr信號線(xiàn),向計算機申請一個(gè)中斷,而計算機則由一個(gè)硬件驅動(dòng)程序來(lái)處理并口的硬件中斷。計算機首先把nWrite信號置高,表示當前為讀周期,當計算機讀取EPP數據口時(shí)同樣會(huì )檢測nWait信號。如果nWait為低,然后置低nDstrb并讀取數據總線(xiàn)上的數據。單片機在檢測到nDstrb為低時(shí)馬上將nWait信號置高,PC機在nWait為高后自動(dòng)將nDstrb信號置高,完成一個(gè)數據周期的讀(相對PC機而言)過(guò)程。

3.3單片機數據接收程序

sbitnwait=P1^0;

sbitERROR=P1^1;

sbitnDstrb=PB&0x40;

voidparallel_rcv(unsignedlongrcv_count)//并口接收,rcv_count為接收字節數

{

unsignedlongi;

rcv_data=(unsignedchar*)&rcv_buffer;

reread_sign=1;//非錯誤態(tài)

while(reread_sign==1)

{

for(i=0;i
{

nwait=1;//PC端反向后為低,表示外設準備好接收

while(nDstrb)//等待nDstrb為低時(shí)完成數據傳輸并鎖存

nwait=0;//完成寫(xiě)周期,

rcv_data[ i]=UPSD_xreg.IMC_A;//從鎖存的輸入宏中讀取數據

}//接收完成

ERROR=error_check(rcv_data);//檢測錯誤,1為正確,0為錯誤

if(ERROR)

{

reread_sign=0;//無(wú)錯則退出while循環(huán)

}

else

{

ERROR=1;//校驗有錯則while循環(huán)繼續

}

}

該程序為單片機數據接收(即PC寫(xiě)數據)子程序,其中rcv_buffer為接收緩存區,error_check為對接收的數據進(jìn)行校驗.如果出錯,則將用戶(hù)自定義引腳12置低,PC機讀取狀態(tài)寄存器時(shí)讀取到該用戶(hù)自定義狀態(tài)為低時(shí),將數據重發(fā),保證了通信的可靠性。
本文地址:http://selenalain.com/thread-19032-1-1.html     【打印本頁(yè)】

本站部分文章為轉載或網(wǎng)友發(fā)布,目的在于傳遞和分享信息,并不代表本網(wǎng)贊同其觀(guān)點(diǎn)和對其真實(shí)性負責;文章版權歸原作者及原出處所有,如涉及作品內容、版權和其它問(wèn)題,我們將根據著(zhù)作權人的要求,第一時(shí)間更正或刪除。
您需要登錄后才可以發(fā)表評論 登錄 | 立即注冊

相關(guān)視頻

關(guān)于我們  -  服務(wù)條款  -  使用指南  -  站點(diǎn)地圖  -  友情鏈接  -  聯(lián)系我們
電子工程網(wǎng) © 版權所有   京ICP備16069177號 | 京公網(wǎng)安備11010502021702
快速回復 返回頂部 返回列表
午夜高清国产拍精品福利|亚洲色精品88色婷婷七月丁香|91久久精品无码一区|99久久国语露脸精品|动漫卡通亚洲综合专区48页