新聞中心

EEPW首頁 > EDA/PCB > 設(shè)計(jì)應(yīng)用 > 基于FPGA與VHDL的微型打印機(jī)的驅(qū)動(dòng)設(shè)計(jì)

基于FPGA與VHDL的微型打印機(jī)的驅(qū)動(dòng)設(shè)計(jì)

作者: 時(shí)間:2011-03-08 來源:網(wǎng)絡(luò) 收藏

e.JPG
使用硬件描述語言來進(jìn)行軟件設(shè)計(jì)。對(duì)的驅(qū)動(dòng)主要是對(duì)其工作時(shí)序進(jìn)行正確的控制,利用常見的狀態(tài)機(jī)來實(shí)現(xiàn)對(duì)打印機(jī)的工作時(shí)序的控制,根據(jù)時(shí)序圖1所示的時(shí)序,狀態(tài)機(jī)使用4個(gè)狀態(tài),狀態(tài)轉(zhuǎn)換圖如圖5所示。
初始狀態(tài)STATE0時(shí),數(shù)據(jù)選通觸發(fā)脈沖信號(hào)STB置‘1’(高電平),檢測(cè)打印機(jī)是否正忙,如果打印機(jī)為空閑狀態(tài)(busy=‘0’),轉(zhuǎn)入下一狀態(tài)STATE1,否則(busy=‘1’)繼續(xù)執(zhí)行STATE0;在狀態(tài)STATE1,將數(shù)據(jù)寫入打印機(jī),直接轉(zhuǎn)入下一狀態(tài);在狀態(tài)STATE2,將數(shù)據(jù)選通觸發(fā)脈沖信號(hào)STB置‘O’,打印機(jī)讀數(shù)據(jù),轉(zhuǎn)入下一狀態(tài);在狀態(tài)STATE3,檢測(cè)數(shù)據(jù)是否已經(jīng)被接受,若數(shù)據(jù)已被接受(ACK=‘O’),打印機(jī)轉(zhuǎn)入初始狀態(tài)STATE0,等待接受新數(shù)據(jù),若數(shù)據(jù)未被接受(ACK=‘1’),繼續(xù)執(zhí)行STATE3直到數(shù)據(jù)被接受。

3 結(jié)語
使用硬件描述語言設(shè)計(jì)的驅(qū)動(dòng),通過系統(tǒng)調(diào)試能夠完成對(duì)打印機(jī)的時(shí)序控制,目前已經(jīng)在某型測(cè)試儀中正常使用。該設(shè)計(jì)系統(tǒng)控制簡(jiǎn)單,抗干擾性強(qiáng),可靠性高,移植性較好,能夠用于任何使用芯片的系統(tǒng)中,具有一定的應(yīng)用前景。


上一頁 1 2 3 下一頁

評(píng)論


相關(guān)推薦

技術(shù)專區(qū)

關(guān)閉