基于FPGA的數(shù)據(jù)采集系統(tǒng)的設(shè)計與實現(xiàn)
2.3 FPGA的頂層模塊的設(shè)計
由圖4可知,top.v模塊是FPGA整個系統(tǒng)的頂層模塊,它通過頂層調(diào)用的方式把adc.v和usb.v兩個模塊組合成一個完整的系統(tǒng),系統(tǒng)與外界進行通信是通過top.v這個模塊對外的各個接口來實現(xiàn)的,具體到器件層面,就表現(xiàn)為由top.v文件定義的FPGA的相關(guān)的管腳來和A/D與USB2.0芯片進行數(shù)據(jù)的交換、控制信息以及時鐘信號的傳遞。這種自頂向下的設(shè)計方法,不僅符合人的思維邏輯,也大大地簡化了大規(guī)模邏輯電路的設(shè)計工作,使人們從繁瑣的自底向上的底層設(shè)計中解放出來,以一種系統(tǒng)級的思維模式設(shè)計電路。這是自頂向下設(shè)計方法的巨大優(yōu)勢之一。頂層top.v模塊是通過例化的方式來調(diào)用adc.v模塊和usb.v模塊的以及PLL模塊。
2.4 USB2.0芯片的固件程序設(shè)計
在USB的體系中,無論是其本身的規(guī)范還是各種廠家所提供的芯片資料,關(guān)于主機對USB的檢測都稱之為枚舉Enumeration(and ReNumer-ation),即枚舉(與重新枚舉)。固件在這發(fā)揮了無法替代的作用。應(yīng)該說所有基于微控制器及其外圍電路的功能設(shè)備的正常工作都離不開固件的參與,固件的作用就是輔助硬件,或者說是控制硬件來完成預(yù)期的設(shè)備功能。沒有固件的參與和控制,硬件設(shè)備只是芯片的簡單堆砌,無法實現(xiàn)預(yù)期的功能。
CY7C68013A內(nèi)部集成了增強型的8051內(nèi)核,它與8051指令集二進制是兼容的,那么就可以選擇匯編或者高級語言C51來編寫固件代碼,兩者各有優(yōu)缺點,適用的環(huán)境也不同。本設(shè)計中采用C51來編寫固件程序,關(guān)于開發(fā)C51語言的Keil μVision 2開發(fā)編譯環(huán)境在此不再贅述。
Cypress公司為了簡化和加速用戶使用CY7C68013A芯片進行USB外設(shè)的開發(fā)過程,特別設(shè)計了一個完整的固件程序的框架。這個框架可以執(zhí)行CY7C68013A芯片的初始化、USB標(biāo)準(zhǔn)設(shè)備請求的處理和USB掛起電源管理服務(wù)。用戶只需要提供一個USB描述符表,添加其他端點接收和發(fā)送數(shù)據(jù)的通信代碼,以及控制外圍電路的程序代碼。
在Keil μVision 2集成開發(fā)環(huán)境下,新建工程后,需要將工程代碼復(fù)制到工程目錄中并添加至工程列表中,開發(fā)固件程序需要幾個重要的文件依次為:1)fw.c,框架程序的代碼。2)periph.c,用戶函數(shù)掛鉤的相關(guān)定義,外圍設(shè)備的控制文件。在上節(jié)中,主程序fw.c調(diào)用的TD_lnit()函數(shù)即在此定義出來。3)dscr.a(chǎn)51,USB描述符表,上節(jié)中關(guān)于描述符的定義在這個文件中給出。4)EZUSB.lib,EZ-USB函數(shù)庫目標(biāo)代碼。5)USBJmpTb.OBJ,EZ-USB中斷向量和跳轉(zhuǎn)表。6)FX2.h,程序運行所需要的一些宏定義。7)fx2regs.h,CY7C68013A相關(guān)的寄存器定義及位屏蔽的宏定義。8)syncdly.h,定義了若干延時函數(shù)供程序調(diào)用。本文引用地址:http://www.butianyuan.cn/article/195052.htm
3 Modelsim環(huán)境下仿真與結(jié)果
ModelSim是Model Technology(Mentor Graphics的子公司)的HDL硬件描述語言的仿真軟件,該軟件可以用來實現(xiàn)對設(shè)計的VBDL、Verilog HDL或是兩種語言混合的程序進行仿真,同時也支持IEEE常見的各種硬件描述語言標(biāo)準(zhǔn)。
目前需要對adc.v模塊進行功能仿真,以此驗證該模塊的功能的正確性。仿真測試的方法就是給adc.v這個模塊的s_data數(shù)據(jù)輸入端,即A/D芯片的串行數(shù)據(jù)的輸出端,加載一組測試數(shù)據(jù),每16個為一組測試數(shù)據(jù),模擬在真實環(huán)境下從A/D芯片讀取出來的二進制數(shù)據(jù),然后在adc.v模塊的輸出端,即并行的16位寬的data_out端口觀察是否與給定的測試數(shù)據(jù)相一致。假如一致,則模塊的功能是正確的。假如有個別位的數(shù)據(jù)不一致,則需要檢查模塊的代碼是否存在問題。在編輯器中編寫Testbench程序如下(非關(guān)鍵的程序限于篇幅,就省略了):
評論