0 引 言
在計算機測量、控制及信號處理中,數(shù)據(jù)采集發(fā)揮著至關(guān)重要的作用。數(shù)據(jù)采集是獲取數(shù)據(jù)的重要手段,它是從傳感器或其他待測設(shè)備等模擬或數(shù)字被測單元中自動采集信息的過程。而采用ARM內(nèi)部的A/D轉(zhuǎn)換資源,具有轉(zhuǎn)換速度較高、工作可靠、設(shè)計的復(fù)雜度較低等優(yōu)點。同時,ARM還具有體積小、運算速度高,A/D轉(zhuǎn)換分辨率較高的特性,使ARM得到了廣泛的應(yīng)用。本文利用ATMEL公司ARM7系列中的AT91M55800A設(shè)計了一個簡易的數(shù)據(jù)采集方案。該方案具有結(jié)構(gòu)簡單、開發(fā)容易,可靠性強、價格低廉等特點,有一定的實用價值。
1 數(shù)據(jù)采集方案的結(jié)構(gòu)和功能
方案結(jié)構(gòu)如圖1所示。
該方案是由接收、A/D轉(zhuǎn)換和處理、輸出3部分組成。本方案以AT91M55800A為核心,該芯片是一個高性能的32位處理芯片,內(nèi)部有一個8選1的模擬通道,一個10位的A/D轉(zhuǎn)換通道。預(yù)處理電路將傳感器拾取的信號進行隔離放大和濾波至A/D轉(zhuǎn)換所需0~3 V,處理過的模擬信號通過AT91M55800A中的A/D轉(zhuǎn)換通道變成數(shù)字信號,并根據(jù)要求進行相應(yīng)的處理,最后由液晶顯示器輸出。同時,本方案使用Flash存儲器作為程序存儲器用于保存數(shù)據(jù)。
2 硬件組成
AT91M55800A是ATMEL公司基于ARM7TDMI核的AT91的16/32位微控制器家族成員。它通過完全可編程的外部總線接口直接連到片外存儲器,使讀或?qū)懖僮髯羁炜梢赃_到一個時鐘周期,通過將帶有片內(nèi)SRAM的ARM7TDMI處理器核、多種外圍功能模塊、模擬接口和低功耗振蕩器集成于單一硅片。AT91M55800A為低功耗應(yīng)用提供了一個高度靈活和高性價比的解決方案。其主要特點如下:
a)集成了ARM7TDMI ARM Thumb處理器核,高性能的32位RISC體系結(jié)構(gòu),高代碼密度的16位指令集,嵌入式ICE;
b)8 kB片內(nèi)SRAM,32位數(shù)據(jù)總線寬度,單時鐘周期訪問,方案可最大擴展64 MB存儲器,軟件可編程的8位或16位外部數(shù)據(jù)總線;
c)主/從式SPI接口,8位~16位可編程數(shù)據(jù)長度,4個外部從芯片選擇;
d)可編程的看門狗電路,提高方案的安全可靠性;
e)58個可編程I/O口線,擴展了輸入輸出口線;
f)先進電源管理控制器,具有正常、等待、慢速、待機和掉電方式;
g)8優(yōu)先級、可單獨屏蔽的向量中斷控制器,6通道16位定時器/計數(shù)器,3個USART,每個USART有2個專用的PDC通道;
h)8通道10位A/D轉(zhuǎn)換器,2通道10位D/A轉(zhuǎn)換器;
i) 采用片內(nèi)主振蕩器和PLL倍頻的時鐘產(chǎn)生器,采用片內(nèi)32 kHz振蕩器的實時時鐘。
圖2為方案的實際應(yīng)用電路。
該芯片中含有兩個完全相同的4通道10位A/D轉(zhuǎn)換器,可組成一個8通道10位A/D轉(zhuǎn)換器。每個A/D轉(zhuǎn)換器具有4個模擬輸入引腳和數(shù)字觸發(fā)輸入引腳,并提供一個AIC的中斷信號。兩個A/D轉(zhuǎn)換器共享模擬電源引腳和參考電壓輸入引腳。每一個通道可被單獨地使能或禁止,并具有自己的數(shù)據(jù)寄存器。A/D轉(zhuǎn)換器可以配置為在轉(zhuǎn)換序列后自動進入睡眠
模式,并可由軟件、T/D或外部信號來觸發(fā)。
由于AT91M55800A內(nèi)部不帶片內(nèi)程序存儲器,需要對方案外擴Flash存儲器作為程序存儲器用于存放程序代碼、常量表及掉電后需要保存的數(shù)據(jù)。AT91M55800A的總線讀寫周期最長可以有8個周期的延時,要求Flash存儲器的最低讀速度不低于該速度。考慮到方案的執(zhí)行速度和程序大小,選用訪問速度為70 ns的HY29LV160(芯片容量是1 M×16 bit共2 MB),基本上能夠滿足方案要求。
該系統(tǒng)中接入AD590作為溫度傳感器,該器件以電流作為輸出量來指示溫度,并且將得到的信號經(jīng)過放大器的緩沖隔離得到一個與溫度成正比的電壓,從而實現(xiàn)對溫度的測量。
3 A/D轉(zhuǎn)換編程
在AT91M55800A中,兩個A/D轉(zhuǎn)換器獨立工作,每個A/D轉(zhuǎn)換器只能讀取一個通道的A/D轉(zhuǎn)換器值。此程序讓用戶指定哪一個通道工作,然后讀取指定通道的值,并顯示出來。由于A/D轉(zhuǎn)換器的精度有10位和8位,這里設(shè)置為10位,因此獲得的數(shù)據(jù)范圍在0~3FF之間。
A/D轉(zhuǎn)換器的工作過程不同于一般的外圍設(shè)備。初始化后,必須有一個觸發(fā)命令高速A/D轉(zhuǎn)換器進行采集,此時A/D轉(zhuǎn)換器對其激活的某一個通道上的模擬信號進行采樣、保持,然后轉(zhuǎn)換成數(shù)據(jù),存儲在數(shù)據(jù)寄存器中。用戶可以從狀態(tài)寄存器中了解到A/D轉(zhuǎn)換器是否已經(jīng)轉(zhuǎn)換完成,然后通過讀取數(shù)據(jù)寄存器得到A/D轉(zhuǎn)換后的數(shù)值。
A/D轉(zhuǎn)換程序流程圖見圖3。
對A/D轉(zhuǎn)換器進行編程,使用AT91庫(在/pe-riph/adc目錄下),與A/D轉(zhuǎn)換器相關(guān)的代碼部分如下:
a)adc.h:A/D轉(zhuǎn)換器用戶接口結(jié)構(gòu)定義STructADC、控制寄存器ADC-CR、模式寄存器ADC-MR和其他一些重要寄存器的各個重要位的定義、A/D轉(zhuǎn)換器中斷服務(wù)程序函數(shù)定義。
b)Lid_adc.h:A/D轉(zhuǎn)換器描述符定義、庫函數(shù)的定義。
e)Lid_adc.c:庫函數(shù)的詳細代碼。包括:初始化ADC at91_adc_open、關(guān)閉ADC at91_adc_close、獲得狀態(tài)寄存器的值at91_adc_get_status、設(shè)置控制寄存器的值at91_adc_trig_cmd、讀取A/D轉(zhuǎn)換的值at91_adc_read、打開指定的A/D轉(zhuǎn)換通道at91_adc_channel_open、關(guān)閉指定的A/D轉(zhuǎn)換通道at91_adc_channel_close、獲取通道開和關(guān)的狀態(tài)at91_adc_channel_geI_status等。
4 結(jié)束語
本文介紹了一個基于ARM7的數(shù)據(jù)采集方案。該方案通過硬件的具體設(shè)計和軟件編程實現(xiàn)了預(yù)期的目標(biāo)。利用ARM進行數(shù)據(jù)采集可以使方案更穩(wěn)定,而且可以達到功耗小、性能高的效果,適合在多種工業(yè)場合中應(yīng)用。
轉(zhuǎn)載請注明出處。