基于Linux 以太網(wǎng)的遠(yuǎn)程數(shù)據(jù)采集系統(tǒng)
摘要:本文所研究的數(shù)據(jù)采集系統(tǒng)結(jié)合了以太網(wǎng)Socket 技術(shù),USB 技術(shù)、嵌入式技術(shù)(ARM+Linux )等,開發(fā)了一套數(shù)據(jù)采集系統(tǒng)。采集的信號(hào),經(jīng)過CPU 處理后通過USB 總線傳輸?shù)紸rm-Linux 平臺(tái)或者本地PC 機(jī),實(shí)現(xiàn)本地監(jiān)測(cè)。又可以通過以太網(wǎng)傳輸采集的數(shù)據(jù)量到遠(yuǎn)程PC 機(jī),實(shí)現(xiàn)遠(yuǎn)端用戶通過Internet 對(duì)數(shù)據(jù)采集卡進(jìn)行訪問與監(jiān)測(cè)。
本文引用地址:http://www.ex-cimer.com/article/148607.htm引言
我們生活在一個(gè)五彩繽紛的模擬世界,而在數(shù)字化高速發(fā)展的今天,如何將模擬的信號(hào) 轉(zhuǎn)化到數(shù)字領(lǐng)域顯得尤其重要,這就需要數(shù)據(jù)采集技術(shù)。隨著網(wǎng)絡(luò)技術(shù)的發(fā)展,以太網(wǎng)越來 越能夠滿足工業(yè)應(yīng)用的需要?,F(xiàn)場(chǎng)總線的通信功能完全可由以太網(wǎng)較好地完成。最近幾年, 交換式以太網(wǎng)技術(shù)的出現(xiàn)大大地提高了以太網(wǎng)的確定性,這同時(shí)也使以太網(wǎng)技術(shù)在工業(yè)領(lǐng)域 的使用更加廣泛。
1. 遠(yuǎn)程數(shù)據(jù)采集系統(tǒng)的總體設(shè)計(jì)
本文以太網(wǎng)的數(shù)據(jù)采集系統(tǒng)的設(shè)計(jì)目標(biāo)是系統(tǒng)能夠采集 0~2.5V 的電壓信號(hào)量,然后通 過USB 接口將處理了的采樣信號(hào)傳輸?shù)角度胧狡脚_(tái),并且可以通過以太網(wǎng)傳輸?shù)接脩簟?一個(gè)良好的高速數(shù)據(jù)采集系統(tǒng)受很多方面的制約,例如采樣的頻率、AD 的精度、傳輸 的速度和平臺(tái)通用性等等,本系統(tǒng)主要依靠采用高性能AD 和改變采集卡CPU 對(duì)采樣的控 制方式和采樣信號(hào)的處理方式來解決。設(shè)計(jì)中使用了CYPRESS 公司的EZ-USB FX2 系列芯 片CY7C68013。這款芯片有GPIF(General ProgrammableInterface)模式,可以提供高速的數(shù) 字邏輯信號(hào)給外圍設(shè)備(這里給AD),該模式不受CPU 控制,是獨(dú)立于CPU 存在的。這就 克服了CPU 對(duì)于高速采樣的瓶頸約束,提高了對(duì)采樣頻率的控制能力。對(duì)于高性能AD, 文中采用了Analog devices 公司的AD7492,該芯片采樣可以達(dá)到1MSPS,是12 位并行的 持續(xù)逼近型高速模數(shù)轉(zhuǎn)換芯片,系統(tǒng)總體框圖如圖1。
圖1 總體框圖
2. 數(shù)據(jù)采集卡設(shè)計(jì)
該數(shù)據(jù)采集卡完成的不僅僅是一個(gè)數(shù)據(jù)采集的功能,而在于為以后的設(shè)計(jì)提供詳細(xì)的設(shè) 計(jì)基礎(chǔ)和平臺(tái),這些功能都可以方便的移植到以后的儀表設(shè)計(jì)中。數(shù)據(jù)采集卡的總體框圖如 圖2 所示,輸入信號(hào)是0~2.5V 的電壓信號(hào)量,需要經(jīng)過限壓、濾波等處理,然后直接輸入 到ADC 的IN 引腳(板上的IN 引腳端子)。AD 轉(zhuǎn)換的啟停等控制由CPU 完成,轉(zhuǎn)換時(shí)序由 GPIF 控制器控制。CPU 的GPIF 方式以查詢的形式檢測(cè)ADC 的BUSY 引腳,向GPIF 控制 器報(bào)告信號(hào)采集的狀態(tài)。為了達(dá)到改變采樣頻率的目的,利用定時(shí)器按照采樣頻率要求控制 CPU 的IO 端口,進(jìn)而控制GPIF 流程的啟停。一次采集流程結(jié)束后會(huì)自動(dòng)保存采集上來的 數(shù)據(jù)到寄存器中,然后CPU 處理寄存器中的數(shù)據(jù)并送到USB 輸出緩沖區(qū)便可輸出至USB 端口。
圖 2 數(shù)據(jù)采集卡的總體框圖
2.1AD 轉(zhuǎn)換部分硬件設(shè)計(jì)
該設(shè)計(jì)中使用了 AD7492 作為主采樣器件,AD7492 很容易與微處理器或DSP 接口。輸 入信號(hào)從CONVST 的下降沿開始被采樣,轉(zhuǎn)換也從此點(diǎn)啟動(dòng)。AD 的輸入為0-2.5V 單極性 電壓。REFOUT 引腳接有最小100nF 的電容,REFOUT 引腳接有最小100nF 的電容,以穩(wěn) 定內(nèi)部參考電壓值。CPU 負(fù)責(zé)控制AD 的啟動(dòng)、停止和讀取采集數(shù)據(jù)等工作。設(shè)計(jì)中使用 了GPIF 模式,由AD 的連接圖可以看出,68013 的CTL 引腳、RDY 引腳和AD 直接連接, 對(duì)AD 的時(shí)序進(jìn)行控制。CONVST 腳接到PA7 ( 68013 的IOA^7 )用于控制采樣的啟停,從 而可以控制采樣頻率,CTL, RDY 引腳的行為由GPIF 控制,其電路圖如圖3 所示。
圖 3 ADC 外圍接線圖
2.2CPU 與EEPROM 的接口電路
CY7C68013 芯片本身不帶ROM,所以擴(kuò)展一片64Kbit 的I2C 串行E2PROM 存儲(chǔ)程序 代碼。該芯片為低功耗應(yīng)用而開發(fā),可以充分利用FX2 的I2C 接口而不用占用其它IO 接口。 E2PROM 的連接決定了采集卡作為USB 設(shè)備上電枚舉的過程。如果上電沒有檢測(cè)到 E2PROM 的存在,則會(huì)采用默認(rèn)PID, VID。枚舉;上電如果檢測(cè)到連接有E2PROM 時(shí),loader: 讀E2PROM 的第一個(gè)字節(jié)來決定如何枚舉,電路圖如圖4 所示。
圖 4 EEPROM 外圍接線圖
2.3CPU 與鍵盤、顯示的接口電路
由于 56 引腳的68013 只有PA, PB, PD 三組IO,對(duì)于12 位的AD,使用了PB, PD 的第 二功能,配置為FD(Fifo Data)。這樣就只剩下PA 口8 個(gè)引腳可用,不足以完成鍵盤、顯示、 測(cè)試預(yù)留等功能。所以采用了PCF8574 I2C 轉(zhuǎn)I0 口的方式進(jìn)行擴(kuò)展。這樣也可以留出足夠 的IO 口用于擴(kuò)展和測(cè)試,連接如圖5。
圖 5 CPU I/O 擴(kuò)展
3.系統(tǒng)應(yīng)用軟件設(shè)計(jì)
軟件設(shè)計(jì)主要涉及到三個(gè)方面:一是對(duì)用CY7C68013 做CPU 的數(shù)據(jù)采集卡的固件設(shè)計(jì) 和應(yīng)用程序設(shè)計(jì)。CYPRESS 公司為其旗下的產(chǎn)品做了很好的技術(shù)支持,例如對(duì)該款芯片提 供了完善的固件架構(gòu)。用戶的應(yīng)用只要在此固件基礎(chǔ)上開發(fā)即可。二是針對(duì)數(shù)據(jù)采集卡設(shè)計(jì) 基于ARM-LINUX 的USB 設(shè)備驅(qū)動(dòng)程序。三是基于ARM-LINUX 平臺(tái),為提供給用戶可視 化界面設(shè)計(jì)應(yīng)用程序及遠(yuǎn)程PC 上通過以太網(wǎng)采集的應(yīng)用程序的設(shè)計(jì)。
3.1 USB 數(shù)據(jù)采集卡驅(qū)動(dòng)程序
編寫一個(gè) USB 設(shè)備的驅(qū)動(dòng)程序,首先需要把驅(qū)動(dòng)程序的對(duì)象注冊(cè)到USB 子系統(tǒng)中,然后再使用廠商標(biāo)識(shí)和設(shè)備標(biāo)識(shí)來判斷是否已經(jīng)安裝了硬件。注冊(cè)是在USB 驅(qū)動(dòng)程序模塊初
始化代碼中完成。例如在初始化代碼中有這樣的語句:
usb register(sample_driver);
linux操作系統(tǒng)文章專題:linux操作系統(tǒng)詳解(linux不再難懂)pid控制相關(guān)文章:pid控制原理
linux相關(guān)文章:linux教程
評(píng)論