《電子技術應用》
您所在的位置:首頁 > 可編程邏輯 > 設計應用 > 基于FPGA與VHDL的微型打印機的驅動設計
基于FPGA與VHDL的微型打印機的驅動設計
現代電子技術
粘朋雷,李國林,毛維平,鄭 重,楊 春
摘要: 摘要:為了取代傳統利用單片機驅動微型打印機,使用Altera公司的FPGA芯片EP3C225Q240C8N設計驅動打印機的硬件控制電路,并正確控制微型打印機的工作時序。軟件使用硬件描述語言VHDL實現對微型打印機的時序控制,并通
Abstract:
Key words :

摘要:為了取代傳統利用單片機驅動微型打印機,使用Altera公司的FPGA芯片EP3C225Q240C8N設計驅動打印機的硬件控制電路,并正確控制微型打印機的工作時序。軟件使用硬件描述語言VHDL實現對微型打印機的時序控制,并通過QuartusⅡ軟件平臺下栽到FPGA調試通過,證明該方法行之有效,完全可以取代傳統利用單片機來驅動微型打印機,且抗干擾性好,可靠性高,具有較強的可移植性。
關鍵詞:微型打印機;VHDL;時序;FPGA

0 引言
    FPGA即現場可編程邏輯陣列。是在CPLD的基礎上發展起來的新型高性能可編程邏輯器件。FPGA的集成度很高,其器件密度從數萬門到數千萬門不等,可以完成極其復雜的時序與組合邏輯電路功能,適用于高速、高密度的高端數字邏輯電路設計領域。新一代的FPGA甚至集成了中央處理器(CPLU)或數字處理器(DSP)內核,在一片FPGA上進行軟硬件協同設計,為實現片上可編程系統(SOPC)提供了強大的硬件支持。對微型打印機的驅動,傳統方法是使用單片機是實現對其的時序控制。隨著FPGA在各領域的普及使用,以及對微型打印機的需要,因此要實現FP-GA對微型打印機的時序控制。
    當前各ASIC芯片制造商都相繼開發了用于各自目的的HDL語言,但是大多數都為標準化和通用化。惟一被公認的是美國國防部開發的VHDL語言,它已成為IEEE STD_1076標準。另外從近期HDL語言發展的動態來看,許多公司研制的硬件電路設計工具業都逐漸向VHDL語言靠攏,使得他們的硬件電路設計工具也能支持VHDL語言。
    VHDL語言可以支持自上而下和基于庫的設計方法,而且還支持FPGA的設計。

1 微型打印機簡介
    RD-DH型微型打印機采用熱敏加熱點陣打印方式,是一款體積小,打印速度快的打印輸出設備。該型打印機可采用標準并行接口,RS232串行接口,TTL電平串口,485接口,USB接口,打印速度達到50 m/s,分辨率為8點/mm,384點/行,打印紙張采用57 mm熱敏紙。可打印國標一、二級漢字庫中全部漢字和西文字、圖標共8 178個。微型打印機并行接口與CENTRONICS標準接口兼容,可直接由微機并口或單片機控制。其26線雙排插座引腳序號如圖1所示。此26個并口各引腳信號定義如表1所示。

a.JPG

    注:“入”表示輸入到打印機;“出”表示從打印機輸出,信號的邏輯電平為TTL電平。
    對打印機的驅動主要是對其工作時序進行正確的控制,RD-DH型并行接口定時圖如圖2所示。

b.JPG

 

2 總體系統設計
    使用Altera公司的CyelonⅢ系列的FPGA芯片EP3C25Q240C8N實現對RD-DH型微型打印機的硬件電路控制,使用QuartusⅡ開發工具,通過VHDL語言實現對微型打印機的軟件功能實現。
2.1 硬件電路設計
    如圖3所示為打印機與FPGA的連接示意圖。DATA1~DATA8表示打印機的8個數據位,他們的邏輯‘1’表示高電平,邏輯‘O’表示低電
平;-STB為數據選通觸發脈沖,下降沿時讀入數據;-ACK為回答脈沖,低電平表示數據已被接受;BUSY為高電平時表示打印機正忙,此時不接收數據。由于-ACK和BUSY輸出的是5 V的TTL電平,而FPGA的I/O口標準為3.3 V LVCMOS電平,因此這兩個信號作為FPGA的輸入信號時,要進行分壓,保證電路正常運行。

c.JPG


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

d.JPG

 

e.JPG
    使用VHDL硬件描述語言來進行軟件設計。對微型打印機的驅動主要是對其工作時序進行正確的控制,利用VHDL常見的狀態機來實現對打印機的工作時序的控制,根據時序圖1所示的時序,狀態機使用4個狀態,狀態轉換圖如圖5所示。
    初始狀態STATE0時,數據選通觸發脈沖信號STB置‘1’(高電平),檢測打印機是否正忙,如果打印機為空閑狀態(busy=‘0’),轉入下一狀態STATE1,否則(busy=‘1’)繼續執行STATE0;在狀態STATE1,將數據寫入打印機,直接轉入下一狀態;在狀態STATE2,將數據選通觸發脈沖信號STB置‘O’,打印機讀數據,轉入下一狀態;在狀態STATE3,檢測數據是否已經被接受,若數據已被接受(ACK=‘O’),打印機轉入初始狀態STATE0,等待接受新數據,若數據未被接受(ACK=‘1’),繼續執行STATE3直到數據被接受。

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

此內容為AET網站原創,未經授權禁止轉載。
主站蜘蛛池模板: 午夜高清在线观看免费6 | 日韩免费一区二区 | free性china中文| 一二三四视频社区在线1 | 欧美顶级黄色大片免费 | 一级特黄a 大片免费 | 国产 欧美 日韩 在线 | 欧美成国产精品 | 色一级| 91精品在线观看视频 | 欧美影片一区二区三区 | www.五月天激情 | 看全黄大色黄大片美女51la | 久久久精品成人免费看 | 一区二区三区视频在线观看 | 香港一级a毛片在线播放 | 一区二区三区在线观看视频 | 欧美黄网在线 | 一级理论片免费观看在线 | 成年香蕉大黄美女美女 | 亚洲欧美丝袜综合精品第一页 | 久久99国产视频 | 麻豆国产精品一二三在线观看 | 视频h在线观看 | 97菊爱网 | av小说网站 | 国产一区在线看 | 羞羞视频免费网站含羞草 | 热热色网站 | 一个色在线视频 | 羞羞免费网站 | 在线毛片网 | 日本一区二区三 | 亚洲青青草 | 免费一级欧美片片线观看 | 怡红院视频在线观看 | 日韩一区三区 | 亚洲欧美日韩国产精品影院 | 欧美日韩免费一区二区三区 | 国产一级一级毛片 | 久久综合视频网 |