新聞中心

EEPW首頁 > EDA/PCB > 設(shè)計(jì)應(yīng)用 > 基于C8051F320 USB接口的數(shù)據(jù)采集存儲電路

基于C8051F320 USB接口的數(shù)據(jù)采集存儲電路

——
作者:北京工業(yè)大學(xué)電子信息與控制工程學(xué)院 王鐵流 吳丹丹 李成 時(shí)間:2007-01-02 來源:電子產(chǎn)品世界 收藏

摘要: 介紹采用C8051F320 與AM45DB321構(gòu)成存儲系統(tǒng)的設(shè)計(jì)方案。

關(guān)鍵詞:  ;;

在一些特殊的工業(yè)場合,有時(shí)需要將傳感器的信號不斷的實(shí)時(shí)采集和存儲起來,并且到一定時(shí)間再把數(shù)據(jù)回放到PC機(jī)中進(jìn)行分析和處理。在工作環(huán)境惡劣的情況下采用高性能的單片機(jī)和工業(yè)級大容量的FLASH的方案恐怕就是最適當(dāng)?shù)倪x擇了。CYGNAL公司的C8051F320 是一種具有8051內(nèi)核的高性能單片機(jī),運(yùn)行速度為普通8051的12倍。該芯片內(nèi)部528字節(jié)隨機(jī)RAM和2048字節(jié)XRAM為數(shù)據(jù)緩沖和程序運(yùn)行提供了充足的空間。更受歡迎的是它的串行擴(kuò)展功能為當(dāng)前的各種串行芯片和外部設(shè)備接口的擴(kuò)展提供了極大的方便。高速的SPI硬件接口與串行FLASH RAM的無縫連接大大簡化了電路板布線,而片內(nèi)自帶的功能使數(shù)據(jù)的存儲和回放變得十分簡單和快捷。在協(xié)議的支持下,使這個(gè)采集的數(shù)據(jù)回放過程簡單到了極點(diǎn)。

本文給出的是用于大型光伏系統(tǒng)運(yùn)行狀態(tài)監(jiān)測的,由于采用表面貼片工藝制作,整個(gè)電路板的寬度僅為18毫米,就像使用U盤一樣方便。

采集電路硬件部分

電路的硬件結(jié)構(gòu)

本系統(tǒng)采用了CYGNAL公司的C8051F320芯片和ATMEL公司的AT45DB321C存儲芯片作為控制和存儲的主要芯片。圖1是信號采集系統(tǒng)的采集及存儲系統(tǒng)框圖。

圖1 基于USB數(shù)據(jù)采集及存儲系統(tǒng)框圖

從圖1中可見,在采集過程中,傳感器的輸入模擬信號經(jīng)可變增益放大器放大后送至C8051F320,經(jīng)過ADC轉(zhuǎn)換為數(shù)字信號。單片機(jī)片外有8個(gè)45DB321C芯片組成了一個(gè)32MB的Data flash,采集到的數(shù)據(jù)不斷地通過SPI接口傳送到45DB321C芯片中存儲。

與其他型號芯片相比,C8051F320帶有USB接口,片內(nèi)的USB功能控制模塊符合USB2.0規(guī)范,可在全速或低速下運(yùn)行,并具有1KB USB緩存、集成收發(fā)器,無需外部電阻??梢耘cPC機(jī)即插即用。當(dāng)需要數(shù)據(jù)時(shí),可將采集存儲電路從現(xiàn)場取回,通過USB接口回放到PC機(jī)中,在LabVEIW平臺上進(jìn)行波形顯示和數(shù)據(jù)分析處理。

8051F320與45DB321C的硬件接口

系統(tǒng)中C8051F320與45DB321CI采用SPI單主多從機(jī)的方式通信。引腳NSS作為從機(jī)選擇線,選擇存儲芯片,低電平有效;SCK作為串行外設(shè)接口發(fā)送和接收數(shù)據(jù)的同步時(shí)鐘信號;RDY/BUZ作為判斷設(shè)備不忙或準(zhǔn)備接收新的指令操作的信號線;SO、SI作為數(shù)據(jù)傳輸線。

本系統(tǒng)設(shè)計(jì)上考慮使用8片45DB321C芯片,最大容量達(dá)32MB,通過片選CS1~CS8分別連到各45DB321C的CS端。時(shí)鐘SCK只對被選中的45DB321有效。本系統(tǒng)使用多片F(xiàn)lash芯片的設(shè)計(jì)除了提供充足的存儲空間之外,還解決了一個(gè)關(guān)鍵問題,就是借鑒硬盤領(lǐng)域RAID技術(shù)的思路,通過對4片一組的Flash順序操作實(shí)現(xiàn)一個(gè)基本的并行加速,解決了Flash寫入速度過慢的問題,大大提高了存儲性能。

具體電路如圖2所示,其中8片的SPI采用級聯(lián)只畫出一片,各自的CS片選信號由74HC138譯碼給出。

圖2 單片機(jī)與FLASH存儲器的接口電路
          
采集電路的程序軟件

采集電路的程序是指固化在C8051F320 中的程序,采用c語言編寫,由主程序模塊、ADC數(shù)據(jù)采集、Flash數(shù)據(jù)存儲和USB通信四部分組成。

主程序和ADC數(shù)據(jù)采集

主程序主要完成系統(tǒng)初始化狀態(tài)指示操作控制和參數(shù)設(shè)置啟動A/D轉(zhuǎn)換等。

ADC數(shù)據(jù)采集程序?qū)碜詡鞲衅鞯哪M信號轉(zhuǎn)換成數(shù)字信號的。本系統(tǒng)中,ADC的轉(zhuǎn)換是通過Timer2的自動溢出來觸發(fā)的,而采集的速率可以事先通過上位機(jī)設(shè)置。

Flash數(shù)據(jù)存儲程序

C8051F320芯片與Flash存儲器的通信采用SPI接口方式,數(shù)據(jù)傳輸率為12MHz(位/秒)。本設(shè)計(jì)中,C8051F320工作在SPI主機(jī)模式,SPI總線的數(shù)據(jù)傳輸都將由C8051F320發(fā)起。 首先對SPI相關(guān)SFR SPI0CFG寄存器和SPI0CN寄存器進(jìn)行配置,使其工作在3線主模式12MHz。通信時(shí)首先用GPIO引腳來選擇相應(yīng)的Flash從器件,隨后通過讀取SPIDAT來進(jìn)行讀寫操作。在使用Flash芯片進(jìn)行讀寫操作時(shí),首先要確定Flash存儲器的狀態(tài)??赏ㄟ^寫入D7H命令,讀取狀態(tài)寄存器判斷設(shè)備是否Ready或處于Busy狀態(tài)。確定狀態(tài)后,可根據(jù)數(shù)據(jù)手冊中的命令格式進(jìn)行相關(guān)的讀寫以及擦除操作。

USB通信程序

固件編程是USB設(shè)備開發(fā)過程里的主要工作。固件的主要任務(wù)是初始化單片機(jī)和外設(shè),發(fā)送USB請求,響應(yīng)主機(jī)的標(biāo)準(zhǔn)設(shè)備請求。根據(jù)設(shè)備的功能分類完成各種數(shù)據(jù)交換請求。初始化編程主要完成USB控制器的初始化、端點(diǎn)初始化,交叉開關(guān)和I/O口初始化、系統(tǒng)時(shí)鐘設(shè)置,控制器使能。初始化后,USB設(shè)備可隨時(shí)插入主機(jī)中,主機(jī)將遵循USB協(xié)議對設(shè)備進(jìn)行識別和初始化。主機(jī)識別到設(shè)備之后對設(shè)備進(jìn)行配置,調(diào)用相應(yīng)的驅(qū)動程序,配上上位機(jī)軟件進(jìn)行相關(guān)通信操作。

Silicon lab公司提供了USBXpress的開發(fā)套件。通過使用USBXpress庫,大大簡化了USB固件程序和PC端驅(qū)動程序的開發(fā)。 USBXpress通過一系列函數(shù)實(shí)現(xiàn)單片機(jī)端的應(yīng)用程序接口(API)。這些函數(shù)封裝了USB協(xié)議的細(xì)節(jié),使得程序開發(fā)人員不需要了解USB的過多細(xì)節(jié)即可使用USB進(jìn)行數(shù)據(jù)通信(見圖3)。

圖3 單片機(jī)與PC機(jī)的USB通信

本系統(tǒng)中主要用到了初始化、讀、寫、中斷這四個(gè)函數(shù):
初始化USB_Init(0,0xEA61, NULL, NULL, Serial, 250,0x80,0x100)函數(shù);塊寫函數(shù)Block_Write();塊讀函數(shù)Block_Read();USB中斷使能函數(shù)。

USB的所有處理程序都是通過USB的中斷服務(wù)程序完成的。進(jìn)入U(xiǎn)SB中斷后,程序調(diào)用Get_Interrupt_Source()函數(shù)獲得USB中斷的進(jìn)入原因。然后根據(jù)不同的入口情況,來進(jìn)行相應(yīng)的處理。比如收到數(shù)據(jù)之后,讀取相應(yīng)的緩沖區(qū)內(nèi)容到內(nèi)存中;收到初始化命令時(shí),復(fù)位單片機(jī)內(nèi)的各個(gè)狀態(tài)參數(shù)。USB通信流程圖示于圖4。

圖4  USB通信流程圖

PC機(jī)端軟件程序

計(jì)算機(jī)端軟件程序包括兩部分:USB驅(qū)動程序和用戶應(yīng)用程序。

USB驅(qū)動程序

USB驅(qū)動程序是一個(gè)軟件組件,封裝了應(yīng)用程序存取硬件設(shè)備的功能函數(shù)。有些設(shè)備具有相同的屬性,把它們歸為一組標(biāo)準(zhǔn)類別,可以定義設(shè)備類規(guī)范作為該類設(shè)備的主機(jī)驅(qū)動框架。設(shè)備類驅(qū)動程序使用相似的函數(shù),處理不同設(shè)備間的通信,這樣使設(shè)備類驅(qū)動程序的開發(fā)可以脫離設(shè)備制造商。

USB驅(qū)動程序模型一般分為五層(見圖5)。

圖5  USB驅(qū)動程序模型

用戶端若要從設(shè)備讀取數(shù)據(jù),將調(diào)用一個(gè)應(yīng)用程序接口API,如OpenFile,SiUSBXp.dll實(shí)現(xiàn)這個(gè)API??偩€驅(qū)動程序控制對總線上所有設(shè)備的訪問。

本系統(tǒng)中,開發(fā)USB設(shè)備驅(qū)動程序的工具使用了USBXpress Development Kit。主要函數(shù)如下:
SI_Open()函數(shù);SI_Close()函數(shù);SI_Read函數(shù);SI_Write()函數(shù);SI_GetNumDevices()函數(shù);SI_CheckRXQueue()函數(shù)。

用戶應(yīng)用程序

本系統(tǒng)中,應(yīng)用程序采用NI公司的LabVIEW軟件進(jìn)行編寫,運(yùn)用圖形化的C語言進(jìn)行軟件開發(fā),實(shí)現(xiàn)數(shù)據(jù)的顯示、滿足不同需要的分析功能以及對數(shù)據(jù)采集硬件的參數(shù)設(shè)定(見圖6)。

圖6 回放數(shù)據(jù)波形顯示界面

結(jié)語

基于C8051F320 USB接口的采集存儲電路把計(jì)算機(jī)技術(shù)與傳統(tǒng)信號采集技術(shù)緊密結(jié)合起來,充分發(fā)揮PC機(jī)和單片機(jī)各自的優(yōu)點(diǎn),實(shí)現(xiàn)傳感器信號的采集、存儲、顯示和處理。而借助USB接口的通信功能,減小了數(shù)據(jù)傳輸系統(tǒng)的復(fù)雜性。
  
參考文獻(xiàn)
1.王鐵流, ‘采用ADUC812實(shí)現(xiàn)超大容量油井?dāng)?shù)據(jù)采集與存儲’,電子產(chǎn)品世界,  2002.8A
2.潘琢金,’C8051F高速SOC單片機(jī)原理及應(yīng)用’,北京航空航天大學(xué)出版社,2002年.
3.馬喜順,’高速SOC單片機(jī)C8051F’,電子產(chǎn)品世界, 2002.5A.

存儲器相關(guān)文章:存儲器原理




評論


相關(guān)推薦

技術(shù)專區(qū)

關(guān)閉