
圖3 EPP接口外設(shè)硬件接口圖 在本設(shè)計(jì)中,uPSD3254A采用主動(dòng)連續(xù)接收PC機(jī)并口的數(shù)據(jù),當(dāng)需要數(shù)據(jù)時(shí),連續(xù)接收PC的數(shù)據(jù),否則PC一直等待nWait信號(hào)有效。而當(dāng)外設(shè)準(zhǔn)備好數(shù)據(jù)上傳到PC機(jī)時(shí),PC機(jī)采用的是中斷方式接收外設(shè)的數(shù)據(jù)。
3.2 CPLD邏輯編程
在PSDsoft EXPRESS工具中,將PA端口(D0~D7)配置成帶有時(shí)鐘上升沿觸發(fā)的寄存器類型(PT clocked register)的輸入宏,PB4(nWrite)、PB6(nDstrb)、PB7(nAstrb)配置成CPLD邏輯輸入(logic input)口。nDstrb信號(hào)和nAstrb信號(hào)各自取反再相與后的值作為輸入宏單元的時(shí)鐘。上述對(duì)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ù)正向傳輸過(guò)程:即計(jì)算機(jī)向外設(shè)單片機(jī)傳輸數(shù)據(jù)(即EPP數(shù)據(jù)寫周期)為例,計(jì)算機(jī)首先把nWrite信號(hào)置為低,表明是寫周期,同時(shí)將數(shù)據(jù)放到數(shù)據(jù)總線上,然后檢測(cè)nWait信號(hào),如果nWait為低則置低nDstrb信號(hào)。此時(shí),!nDstrb & !nAstrb信號(hào)會(huì)出現(xiàn)一個(gè)上升沿,此上升沿會(huì)將PA端口的數(shù)據(jù)鎖存到輸入宏;當(dāng)單片機(jī)檢測(cè)到nDstrb為低時(shí)將nWait信號(hào)變高表示外設(shè)正忙接收數(shù)據(jù)并處理,同時(shí)讀取數(shù)據(jù)總線上的數(shù)據(jù)。當(dāng)計(jì)算機(jī)檢測(cè)到nWait信號(hào)為高后就會(huì)將數(shù)據(jù)握手信號(hào)nDstrb變高,EPP數(shù)據(jù)寫周期結(jié)束。上述EPP數(shù)據(jù)的鎖存和nDstrb握手信號(hào)的產(chǎn)生都由硬件產(chǎn)生,因此數(shù)據(jù)傳輸速度快。整個(gè)數(shù)據(jù)傳輸過(guò)程可以在一個(gè)I/O周期內(nèi)完成。
數(shù)據(jù)反向傳輸過(guò)程:?jiǎn)纹瑱C(jī)準(zhǔn)備好數(shù)據(jù)需要上傳到計(jì)算機(jī)時(shí),uPSD3254A將數(shù)據(jù)放到PA端口,同時(shí)置低Intr信號(hào)線,向計(jì)算機(jī)申請(qǐng)一個(gè)中斷,而計(jì)算機(jī)則由一個(gè)硬件驅(qū)動(dòng)程序來(lái)處理并口的硬件中斷。計(jì)算機(jī)首先把nWrite信號(hào)置高,表示當(dāng)前為讀周期,當(dāng)計(jì)算機(jī)讀取EPP數(shù)據(jù)口時(shí)同樣會(huì)檢測(cè)nWait信號(hào)。如果nWait為低,然后置低nDstrb并讀取數(shù)據(jù)總線上的數(shù)據(jù)。單片機(jī)在檢測(cè)到nDstrb為低時(shí)馬上將nWait信號(hào)置高,PC機(jī)在nWait為高后自動(dòng)將nDstrb信號(hào)置高,完成一個(gè)數(shù)據(jù)周期的讀(相對(duì)PC機(jī)而言)過(guò)程。
3.3單片機(jī)數(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; //非錯(cuò)誤態(tài)
while(reread_sign ==1)
{
for(i=0;i<rcv_count;i++) //接收數(shù)據(jù)
{
nwait = 1; //PC端反向后為低,表示外設(shè)準(zhǔn)備好接收
while(nDstrb) //等待nDstrb為低時(shí)完成數(shù)據(jù)傳輸并鎖存
nwait = 0; //完成寫周期,
rcv_data[i] = UPSD_xreg.IMC_A; //從鎖存的輸入宏中讀取數(shù)據(jù)
} //接收完成
ERROR = error_check(rcv_data); //檢測(cè)錯(cuò)誤,1為正確,0為錯(cuò)誤
if(ERROR)
{
reread_sign = 0; //無(wú)錯(cuò)則退出while循環(huán)
}
else
{
ERROR = 1; //校驗(yàn)有錯(cuò)則while循環(huán)繼續(xù)
}
}
該程序?yàn)閱纹瑱C(jī)數(shù)據(jù)接收(即PC寫數(shù)據(jù))子程序,其中rcv_buffer為接收緩存區(qū),error_check為對(duì)接收的數(shù)據(jù)進(jìn)行校驗(yàn).如果出錯(cuò),則將用戶自定義引腳12置低,PC機(jī)讀取狀態(tài)寄存器時(shí)讀取到該用戶自定義狀態(tài)為低時(shí),將數(shù)據(jù)重發(fā),保證了通信的可靠性。
參





