新聞中心

EEPW首頁 > EDA/PCB > 設計應用 > 基于FPGA 與VHDL 的微型打印機的驅動設計

基于FPGA 與VHDL 的微型打印機的驅動設計

作者: 時間:2011-03-14 來源:網絡 收藏

  2. 2 軟件設計

  軟件平臺采用A ltera 公司的 開發(fā)平臺Q uartus 。

  Quartus 提供了一種與器件結構無關的設計環(huán)境,設計者不需要精通器件的內部結構,只需要運用自己熟悉的輸入工具( 如原理圖輸入或數(shù)字電路描述語言輸入) 進行設計,利用Quar tus 可以將這些設計轉換為最終結構所需要的格式。有關結構的詳細知識已寫入開發(fā)工具軟件,設計人員無需手工優(yōu)化自己的設計。軟件的開發(fā)流程如圖4 所示。

3.jpg
圖4 軟件開發(fā)流程圖

  使用 硬件描述語言來進行軟件設計。

  對的驅動主要是對其工作時序進行正確的控制,利用 常見的狀態(tài)機來實現(xiàn)對打印機的工作時序的控制,根據時序圖1 所示的時序,狀態(tài)機使用4 個狀態(tài),狀態(tài)轉換圖如圖5 所示。

  初始狀態(tài)STA TE0 時,數(shù)據選通觸發(fā)脈沖信號STB 置“1” ( 高電平) ,檢測打印機是否正忙,如果打印機為空閑狀態(tài)( busy= “0”) ,轉入下一狀態(tài)STAT E1,否則( busy = “1 ” ) 繼續(xù)執(zhí)行ST AT E0; 在狀態(tài)STAT E1,將數(shù)據寫入打印機,直接轉入下一狀態(tài); 在狀態(tài)STAT E2,將數(shù)據選通觸發(fā)脈沖信號STB 置“0” ,打印機讀數(shù)據,轉入下一狀態(tài); 在狀態(tài)ST ATE3,檢測數(shù)據是否已經被接受,若數(shù)據已被接受( ACK = “0” ) ,打印機轉入初始狀態(tài)ST AT E0,等待接受新數(shù)據,若數(shù)據未被接受( ACK = “1” ) ,繼續(xù)執(zhí)行STAT E3 直到數(shù)據被接受。

5.jpg
圖5 狀態(tài)轉換圖

  3 結 語

  使用 與V HDL 硬件描述語言設計的驅動,通過系統(tǒng)調試能夠完成對打印機的時序控制,目前已經在某型測試儀中正常使用。該設計系統(tǒng)控制簡單,抗干擾性強,可靠性高,移植性較好,能夠用于任何使用 芯片的系統(tǒng)中,具有一定的應用前景。


上一頁 1 2 3 下一頁

評論


相關推薦

技術專區(qū)

關閉