国产日韩欧美一区二区三区三州_亚洲少妇熟女av_久久久久亚洲av国产精品_波多野结衣网站一区二区_亚洲欧美色片在线91_国产亚洲精品精品国产优播av_日本一区二区三区波多野结衣 _久久国产av不卡

?

利用計算機并口ECP模式實現(xiàn)計算機對外圍設(shè)備的控制及數(shù)據(jù)采集

2009-01-06 04:55:38葉青青
關(guān)鍵詞:外設(shè)緩沖器字節(jié)

葉青青

[中圖分類號]R562.25[文獻標識碼]A[文章編號]1007-9416(2009)11-0121-04

1 并行口簡介

并行口是PC機的常用接口。并行口由4根控制線,5根狀態(tài)線及8根數(shù)據(jù)線構(gòu)成。并行口位于PC機背面,通常為D-25針母座,也有的是D-25針公座。并行口有5種向下兼容的操作模式,分別是:兼容模式(Compatibility Mode)、半模式(Nibble Mode)、BYTE模式(Byte Mode)、EPP模式(EPP Mode)和ECP.模式(ECP Mode)。兼容模式(SPP)、半模式、Byte模式均是軟件握手,速率只有50KByte/s,最多也就是150KByte/s。EPP、ECP模式都是硬件握手,傳輸速率相近,速率最高可達2Mbyt/s。EPP模式5根狀態(tài)線中只用了2條,因而在實時雙向通信中能力顯得不足,且ECP模式可以使用FIFO緩沖器來發(fā)送/接收數(shù)據(jù)同時在Windows下還可以使用DMA通道來移動數(shù)據(jù),因而ECP模式更適用。

2 ECP說明

(1)ECP協(xié)議里有一個叫做Run Length Encoding的簡單壓縮配置,它的最大壓縮比率是64:1,且它對發(fā)送重復(fù)單一字節(jié)的數(shù)據(jù)采用計數(shù)和COPY一個字節(jié)的方式工作,計的數(shù)確定重復(fù)字節(jié)的個數(shù)。例如,要發(fā)送出25個‘A,首先發(fā)送24緊隨其后是‘A。外圍設(shè)備接收到之后通過計數(shù)24及‘A恢復(fù)出25個‘A, 這對于像掃描儀、打印機那樣數(shù)據(jù)比較長的外設(shè)來說,是非常好的并行接口。

壓縮的 Byte在數(shù)據(jù)處理路徑上有別于其它Byte,它作為指令被送到ECP的地址FIFO端口(ECP Address FIFO),發(fā)送到Address FIFO寄存器的字節(jié)可能是兩種東西,一是壓縮數(shù)據(jù)長度的計數(shù),二是字符的ASCI碼。壓縮Byte的MSB為1,那么其它7個BIT(BIT0—BIT6)代表的就是字符的ASCI碼;如果壓縮Byte的BIT7為0,那么在其它BIT位傳輸?shù)木褪且粋€壓縮數(shù)據(jù)長度的計數(shù)。

(2) ECP硬件特性

普通計算機只有一個并行接口,ECP、SPP、EPP只是并行接口的幾種工作模式,它們之間的差異就在于引腳

功能分配的不同,軟件運行的方式不同。SPP是軟件握手,EPP、ECP是硬件握手,但ECP和EPP硬件握手的方式還不同。ECP向后兼容SPP、EPP,當(dāng)它工作在SPP模式時,并行端口上的每個數(shù)據(jù)線的用途與工作在SPP模式下并行口上的數(shù)據(jù)線的用途完全相同。當(dāng)它工作在EPP模式時,并行端口上的每個數(shù)據(jù)線的用途與工作在EPP模式下并行口上的數(shù)據(jù)線的用途完全相同。當(dāng)計算機工作在ECP模式下時,25腳并行接口各引腳功能定義如下表:

(4)ECP軟件寄存器

表格2列出了ECP寄存器的內(nèi)容。前三個寄存器和SPP寄存器幾乎完全相同,只是控制端口寄存器的Bit5位特殊,在ECP模式里它控制并行口的收發(fā)方向,進而影響ECR寄存器的FIFO Full及FIFO Empty Bit位。

當(dāng)并行口工作在SPP模式時,基地址通常被稱為數(shù)據(jù)端口或數(shù)據(jù)寄存器,它使用簡單,用于把數(shù)據(jù)放到并行口的數(shù)據(jù)線上(PINS2—9)。在標準SPP模式下,這個寄存器通常只負責(zé)把數(shù)據(jù)寫到并口上,如果你想讀這個寄存器,只能讀到上一次發(fā)出的數(shù)據(jù)。然而如果你的并口是雙向的(Byte Mode),就可以在這個地址上接收數(shù)據(jù)。當(dāng)并行口工作在ECP模式時,基地址+0用作地址FIFO(見表1、表2)。

基地址+1 稱為狀態(tài)端口或狀態(tài)寄存器,不可寫。狀態(tài)端口的高5位直接反映并行口的5條狀態(tài)線(引腳10,11,12,13,15)的狀態(tài),Bit2是顯示IRQ的狀態(tài)位,Bit1、Bit0是保留位。請注意BIT7位(BUSY)低電平有效,例如,如果寄存器的第7位是‘0,那就意味著并行口的第11腳加入的是+5V,同樣如果BIT2(NIRQ)是‘1那一定沒有中斷發(fā)生,詳見表格3。

控制端口(基地址+2)又稱為控制寄存器。在具體使用它時,讀是沒有意義的,一般用作只寫,詳見表格4。

基地址+402h :

基地址+402h是ECP的擴展控制寄存器(ECR),ECR設(shè)定在那一種模式ECP端口就將工作在那一種模式。

ECR的高三位字節(jié)用于選擇操作模式,共有7種模式,但并不是所有主機的并口硬件都支持這些模式,EPP就是其中一例。

Standard Mode :選擇這種模式,將使ECP端口工作于SPP標準模式,但不包含雙向功能。

Byte Mode / PS/2 Mode :ECP端口工作于SPP的雙向模式。

Parallel Port FIFO Mode :此種模式任何數(shù)據(jù)都可寫入DATA FIFO,端口使用SPP握手把FIFO中的DATA送給外圍設(shè)備,而握手過程是由硬件產(chǎn)生的。這對于非ECP的外設(shè)如打印機是非常有用的,你可以有一些ECP的特性如FIFO緩沖器、硬件握手,它是用已有的SPP握手而非ECP握手。

ECP FIFO Mode :ECP使用的標準模式。這種模式使用的是已經(jīng)講述過的ECP握手。

EPP Mode/Reserved :對于有些計算機,這種模式就是使ECP端口工作于EPP模式;而在有些計算機里這種模式仍作為保留模式。

Reserved :保留模式。

Configuration Mode :在這個模式里共有兩個配置寄存器可以用(CNFGA及CNFGB),它們都有指定的地址。

FIFO test mode:用于測試FIFO緩沖器的性能也用于確定這些功能的正確性。當(dāng)端口處于這種模式時,任何寫進TEST FIFO(BASE+400H)的字節(jié)都被放進FIFO緩沖器里,任何從TESTFIFO寄存器里讀出的字節(jié)都是取自FIFO緩沖器。你可以使用ECR的FIFO Full及FIFO Empty的Bit位來確定FIFO緩沖器的性能,通常FIFO緩沖器有16個字節(jié)的深度。

ECR的其它BIT位在ECP操作端口中也起到非常重要的作用,ECP中斷BIT(BIT4)位使能中斷,DMA Enable Bit (Bit 3)使能直接內(nèi)存的存取的。如果ECP?Service Bit (Bit 2)被置高說明一個中斷請求已開始。不同計算機并行口使用的芯片往往不同,而不同芯片的ECP Service Bit位的復(fù)位方法可能是不同的,有些芯片需要你置0該Bit位,而有些芯片只需對ECR讀一次就可實現(xiàn)對ECP Service Bit位的復(fù)位。

FIFO Full (Bit 1) and FIFO Empty (Bit 0)顯示FIFO緩沖器的狀態(tài)。由于這兩個Bit位是在并行口數(shù)據(jù)傳輸方向已確定的條件下取得的,所以這里無需考慮Control Register的Bit5位。如果BIT0(FIFO Empty)置為1,那么FIFO緩沖器為空;如果BIT1置為1,那么FIFO緩沖器為滿;如果這兩個BIT位都不為1的話,說明有數(shù)據(jù)在FIFO里但它不滿,這兩個BIT位可用在FIFO Test Mode,用以測定FIFO緩沖器的容量。

基地址 + 400h為ECP的配置寄存器A,有關(guān)ECP端口的一些內(nèi)容都可以在配置寄存器A里得到。MSB確定中斷方式:邊沿或電平觸發(fā),這主要依賴于你使用的并行卡。BIT4—6位列出了卡上的總線寬度,一些卡只有8位數(shù)據(jù)寬度,而有些卡卻有32或16位的數(shù)據(jù)寬度。為了使你的并行卡發(fā)揮最大的效能,可以先利用軟件讀出這些BIT位的狀態(tài),以此決定輸出端口的最大字的數(shù)據(jù)寬度(見表5)。

配置寄存器的低三位,用于主機的恢復(fù)。為了從一個錯誤中恢復(fù),軟件必須知道有多少個字節(jié)已送出,而獲取已送出字節(jié)的方法是查看暫存于FIFO的字節(jié)數(shù)。

有些外設(shè)的輸入端口可能有以Byte為單位的移位寄存器,需要并行口FIFO滿之后才將數(shù)據(jù)發(fā)送給外設(shè),Bit2就是確定并口是否FIFO滿之后再傳輸?shù)腂it位。還有,并行口只有8位寬度,而你需要傳輸字長16位或32位的指令,如果是這種情況,并行端口的字仍然能夠送出。字長可能是1Byte、2Byte或4Byte,而在發(fā)生錯誤時整個字的一些Byte可能還未送出,此時配置寄存器的Bite0和Bite1位就指明了剩余在FIFO里的Byte數(shù)量,繼而可以將剩余的Byte全部送出。

基地址+401h為配置寄存器B (cnfgB),是可讀/寫寄存器。一些并行口可以利用軟件配置CnfgB從而設(shè)置IRQ和DMA資源。而有些端口則需設(shè)置BIO或在并行卡上跳線來設(shè)置IRQ和DMA,因此此時ConfgB為只讀。

配置寄存器的Bit 7設(shè)為1時,選擇使用RLE壓縮輸出數(shù)據(jù),在發(fā)送之前主機將壓縮數(shù)據(jù),復(fù)位之后壓縮數(shù)據(jù)將被發(fā)送到外圍設(shè)備,BIT6將反饋IRQJ腳的狀態(tài)。有些設(shè)備不僅僅把IRQ用做反映并行口的狀態(tài),還用于診斷沖突(見表6)。

BIT5到BIT3提供了端口IRQ分配的狀態(tài),同樣BIT2到BIT0提供了DMA通道狀態(tài)。我們可以讀/寫前面提及的BIT位,但對于跳線的并行卡,只能讀它的狀態(tài)。

3 并行口ECP模式與外設(shè)通信實例

計算機實現(xiàn)對AT89C51單片機的控制,單片機上傳一組數(shù)據(jù)給計算機處理。單片機與計算機的所有對接端口需加10K上拉電阻(見圖1、圖2、圖3)。

計算機C語言:

#define ECPAddr 0x0378

#define ECPState 0x0379

#define ECPContr0x037A

#define DataFIFO0x0778

#define ConfigRegB 0x0779

#define ECR0x077A

#include >

/******************************** 下傳3452 *********************************/

outp (ECR, 0x60);

outp (ECPContr, 0x04);//進入1284傳輸模式

outp(DataFIFO,3); outp(DataFIFO,4);outp(DataFIFO,5);outp(DataFIFO,2);m= inp(ECR)&0x01;

while(m==0x00)//如果數(shù)據(jù)未完全移出循環(huán)等待

{

m= inp(ECR)&0x01;Outtime++;

if( Outtime>1024)

{

state = 0x10;//“通信失敗”顯示

break;

}

}

Outtime=0;

outp (ECPContr, 0x3c);//退出1284傳輸模式

/********************************** End*********************************/

/*************************** 接收100個數(shù)據(jù)*****************************/

outp (ECR, 0x60);

outp (ECPContr, 0x21);//0x21

for(i=0;i<=99;i++)

{

m= inp(ECR)&0x01;

while(m==0x01)//如果數(shù)據(jù)為空循環(huán)等待

{

m= inp(ECR)&0x01;

Outtime++;

if( Outtime>1024)

{

i=100;//退出本次100個讀數(shù)

break;

}

}

y[i]=inp (DataFIFO)/10.0-3.5;

}//數(shù)據(jù)完全讀入后,nreverse Request并未置高

outp (ECPContr, 0x0c);//退出1284傳輸模式并口17腳此時為低電平

/*********************************End ********************************/

上述程序片段是本人利用LabWindows軟件制作的,經(jīng)過實際測試,這里為限制篇幅而略去了一些變量的定義、控制。

單片機C語言:

sbit HostCLK=P2^0;sbit PeriphReq = P2^2;sbit PeriphCLK=P2^5;sbit HostACK=P2^1;

sbit PeriphACK=P2^6;sbit nReverReq=P2^3; sbit nACKRever = P2^7;sbit ACT1284=P2^4;

while(ACT1284&&nReverReq;==0)//主機未下傳指令之前等待

{ }

PeriphACK=1;//外設(shè)應(yīng)答置高停止接收數(shù)據(jù)

PeriphACK=0;//外設(shè)應(yīng)答置低準備接收數(shù)據(jù)計算機只有查詢到此信號為低電平才將數(shù)據(jù)移入總線。

for(j=0;j<=3;j++)

{

while(HostCLK)

{}

PeriphACK = 1;

while(HostCLK==0)

{}

DATA[j]=P0;//HostCLK上升沿將數(shù)據(jù)移入單片機

PeriphACK = 0;//外設(shè)應(yīng)答置低結(jié)束一個讀周期

}

While (nReverReq)//主機沒有上傳數(shù)據(jù)請求循環(huán)等待

{ }

if((DATA[0]==3)&&(DATA[1]==4)&&(DATA[2]==5)&&(DATA[3]==2))

{

nACKRever=0;//響應(yīng)主機上傳數(shù)據(jù)的請求

PeriphACK=1;//通知主機送出的是數(shù)據(jù)防止主機誤操作移出數(shù)據(jù)

for(j=0;j<=99;j++)

{

P0=j;

PeriphCLKC=0;//通知主機總線上的數(shù)據(jù)是有效數(shù)據(jù)

while(HostACK==0)//主機未響應(yīng)有效數(shù)數(shù)據(jù)前循環(huán)等待

{ }

PeriphCLKC=1;//正沿將數(shù)據(jù)移入主機

while(HostACK)//主機未響應(yīng)已讀入數(shù)據(jù)之前循環(huán)等待

{ }

}

}

上述程序段因篇幅所限略去了一些變量的定義、賦值。

計算機的并行口ECP模式傳輸速率最高可達2Mbyt/s,可實現(xiàn)實時通信。它成本低,在短距離數(shù)據(jù)傳輸及控制中是非常理想的通信方式。在辦公、工業(yè)控制中得到廣泛的應(yīng)用。

[參考文獻]

[1] http://www.beyondlogic.org/spp/parallel.pdf

[2] Http://www.deyondlogic.org/ecp/ecp.htm

[3] LabWindows/CVI8 Help

猜你喜歡
外設(shè)緩沖器字節(jié)
更正
輕兵器(2022年3期)2022-03-21 08:37:28
No.8 字節(jié)跳動將推出獨立出口電商APP
重載貨車用緩沖器選型的研究及分析
鐵道車輛(2021年4期)2021-08-30 02:07:14
No.10 “字節(jié)跳動手機”要來了?
簡談MC7字節(jié)碼
面向TIA和緩沖器應(yīng)用的毫微微安偏置電流運放可實現(xiàn)500MHz增益帶寬
Microchip推出具備雙ADC外設(shè)的全新器件,擴展其低成本8位PIC?單片機產(chǎn)品線
車輛緩沖器故障及選型
——以冶金企業(yè)為例
河南科技(2011年8期)2011-10-26 07:12:30
人類進入“澤它時代”
貼身呵護 必不可少的PSP外設(shè)
厦门市| 香港| 永顺县| 乐清市| 温州市| 衢州市| 高碑店市| 乳源| 峨眉山市| 荥阳市| 武川县| 天门市| 思南县| 达拉特旗| 黎平县| 墨脱县| 鸡泽县| 来安县| 兴安县| 凤凰县| 察隅县| 隆子县| 文昌市| 新田县| 蓬安县| 凤凰县| 永春县| 永清县| 正安县| 莱阳市| 普洱| 武鸣县| 北辰区| 来凤县| 宜君县| 岳西县| 新津县| 留坝县| 疏附县| 乃东县| 石渠县|