機電之家資源網(wǎng)
單片機首頁|單片機基礎|單片機應用|單片機開發(fā)|單片機文案|軟件資料下載|音響制作|電路圖下載 |嵌入式開發(fā)
培訓信息
贊助商
基于uPSD3254A單片機的EPP并口通信技術
基于uPSD3254A單片機的EPP并口通信技術
 更新時間:2008-8-19 13:37:32  點擊數(shù):96
【字體: 字體顏色

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

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

3.2 CPLD邏輯編程

  在PSDsoft EXPRESS工具中,將PA端口(D0~D7)配置成帶有時鐘上升沿觸發(fā)的寄存器類型(PT clocked register)的輸入宏,PB4(nWrite)、PB6(nDstrb)、PB7(nAstrb)配置成CPLD邏輯輸入(logic input)口。nDstrb信號和nAstrb信號各自取反再相與后的值作為輸入宏單元的時鐘。上述對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;

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

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

3.3單片機數(shù)據(jù)接收程序

sbit nwait = P1^0;

sbit ERROR = P1^1;

sbit nDstrb = PB & 0x40;

void parallel_rcv(unsigned long rcv_count)   //并口接收,rcv_count為接收字節(jié)數(shù)

{

unsigned long i;

rcv_data = (unsigned char * )&rcv_buffer;

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

while(reread_sign ==1)

{

for(i=0;i<rcv_count;i++)   //接收數(shù)據(jù)

{

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

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

nwait = 0;   //完成寫周期,

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

}   //接收完成

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

if(ERROR)

{

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

}

else

{

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

}

}

  該程序為單片機數(shù)據(jù)接收(即PC寫數(shù)據(jù))子程序,其中rcv_buffer為接收緩存區(qū),error_check為對接收的數(shù)據(jù)進行校驗.如果出錯,則將用戶自定義引腳12置低,PC機讀取狀態(tài)寄存器時讀取到該用戶自定義狀態(tài)為低時,將數(shù)據(jù)重發(fā),保證了通信的可靠性。

  • 上一篇: 基于單片機的等精度數(shù)字測頻
  • 下一篇: SH69P42單片機在電磁爐控制中的應用
  • 發(fā)表評論   告訴好友   打印此文  收藏此頁  關閉窗口  返回頂部
    熱點文章
     
    推薦文章
     
    相關文章
    網(wǎng)友評論:(只顯示最新5條。)
    關于我們 | 聯(lián)系我們 | 廣告合作 | 付款方式 | 使用幫助 | 機電之家 | 會員助手 | 免費鏈接

    點擊這里給我發(fā)消息66821730(技術支持)點擊這里給我發(fā)消息66821730(廣告投放) 點擊這里給我發(fā)消息41031197(編輯) 點擊這里給我發(fā)消息58733127(審核)
    本站提供的機電設備,機電供求等信息由機電企業(yè)自行提供,該企業(yè)負責信息內(nèi)容的真實性、準確性和合法性。
    機電之家對此不承擔任何保證責任,有侵犯您利益的地方請聯(lián)系機電之家,機電之家將及時作出處理。
    Copyright 2007 機電之家 Inc All Rights Reserved.機電之家-由機電一體化網(wǎng)更名-聲明
    電話:0571-87774297 傳真:0571-87774298
    杭州濱興科技有限公司提供技術支持

    主辦:杭州市高新區(qū)(濱江)機電一體化學會
    中國行業(yè)電子商務100強網(wǎng)站

    網(wǎng)站經(jīng)營許可證:浙B2-20080178-1