基于DAC芯片AD9248和CY7C09449的PCI高速數(shù)據(jù)采集方案
將UserSIpaceAddress傳遞給應(yīng)用程序,則應(yīng)用程序就可以訪問存放數(shù)據(jù)的內(nèi)存空間了。
FPGA在每傳送給CY7C09449一塊2k雙字的數(shù)據(jù)后就通過CY7C09449的引腳IRQ_IN向主機(jī)發(fā)送中斷請求。在主機(jī)的中斷服務(wù)程序中用m_Me-morjPhyPhysicalAddress設(shè)置CY7C09449的DMA3E機(jī)物理基地址寄存器,然后設(shè)置DMA局部基地址寄存器、DMA長度寄存器來配置數(shù)據(jù)傳輸?shù)脑吹刂返刂泛蛿?shù)據(jù)長度,然后再寫CY7C09449的DMA控制寄存器來啟動DMA傳輸。在所有數(shù)據(jù)塊傳輸完畢,主機(jī)中斷服務(wù)程序發(fā)送給應(yīng)用程序一個(gè)消息,這時(shí)應(yīng)用程序就可以通過UserSpaceAddress訪問接收到的數(shù)據(jù)了。
5 結(jié)論
在高速數(shù)據(jù)采集卡的設(shè)計(jì)中FPGA對局部總線的控制邏輯由于采用了同步數(shù)據(jù)傳輸控制方式使得局部總線的最高傳輸速度可達(dá)200Mb/s。在 WindowsXP下的驅(qū)動程序設(shè)計(jì)使用了DMA數(shù)據(jù)傳輸方式,提高了數(shù)據(jù)存儲速度。高速數(shù)據(jù)采集卡可以達(dá)到80Mb/s的數(shù)據(jù)采集速度,設(shè)備運(yùn)行穩(wěn)定,達(dá)到了設(shè)計(jì)要求。
評論