糯米文學吧

位置:首頁 > 技能 > 電子技術

便攜式、低功耗體電信號採集存儲系統研究

摘要:介紹目前市場上最常見的幾種非易失低功耗靜態存儲介質,詳細説明Compact Flash Card軟、硬件接口;提出基於Compact Flash Card和TI公司的C24x、C28x系列DSP搭建體電信號採集的硬件平台的一種可行的低功耗、便攜式實時體電信號採集存儲系統的可行方案,説明其硬件連接和相關的程序實例。 關鍵詞:數據採集與存儲 便攜式 Compact Flash Card TMS320LF2407 引言 目前比較常見的臨牀體電信號採集及處理儀器是功能完備的微機系統,雖然能較快地分析和處理監測到的體電信號,但往往只能被固定在病房裏使用,在移動的情況下則顯得笨重和不便。體電信號採集往往需要長時間地採集、記錄海量數據,並進行進一步的信號處理和分析,以便臨牀病情的檢測和監護。

便攜式、低功耗體電信號採集存儲系統研究

目前,臨牀體電儀器主要還是採用紙張、磁帶及普通硬盤來存儲體電信號。存儲載體的體積和功耗的限制是臨牀醫療儀器功耗、便攜式發展的瓶頸。便攜的醫療設備能夠極大地方便病人的使用、監護並降低醫療費用。近幾年,隨着Flash Memory非易失存儲技術的發展以及處理器(如單片機和DSP)性能的不斷提高,使信號採集存儲系統的耗電量和體積不斷減少,滿足便攜式的要求。 經過實際調研和性能比較,TI公司的C2000系列DSP芯片具有諸多優點,包括定點處理器C24X和C28X。C24X系列為16位定點處理器,運算速度為20~40MIPS,可用於低速數據採集;TMS320C28X DSP系列為32位定點處理器,運算速度高達400MIPS,可用於高速數據採集。C2000系列採用高性能的靜態CMOS技術,3.3V電壓供電,內核電壓為1.8V,片內程序空間集成Flash,可以將系統控制程序直接燒入DSP芯片內部而不用外擴Flash存儲芯片,減少系統的功耗和體積。C24X 系列DSP內置2%26;#215;8通道10位數據轉換(ADC),轉換時間約為500ns;C28X系列DSP內置2%26;#215;8通道12位數模轉換(ADC),轉換時間為80ns。ADC的精度和速度幾乎可以滿足各種體電信號採集,因此係統須使用獨立A/D轉換芯片,進一步減少系統的功耗和體積。 Compact Flash Card(以下簡稱CF卡)是市場上最常見的基於Flash存儲芯片的低功耗移動存儲器,能與DSP芯片直接連接而用接口轉換芯片。由於CF卡的高速價比、大容量和系統的易實現性,首選作為信號採集的存儲載體。 下面以CF卡和DSP TMS320LF2407硬件平台為例,具體介紹這種可行的低功耗、便攜式體電信號採集存儲系統的搭建和軟、硬件接口的實現,並給出程序實例。

 1、各類基於Flash的閃存卡簡介 近幾年來,靜態存儲技術進步,誕生陳舊基於Flash存儲器非易失大容量多種類型閃爍存儲卡。PC(PCMCIA)、CF(CompactFlash)、 SD(SecureDigital)、MMC(MultMedia)、SM(SmartMedia)、MS(Memory Stick)以及基於USB接口的閃存是如今流行的7大卡系,具有大容量和低功耗等優點。移動存儲器被廣泛應用於各種數碼產品中,如婁碼相機、媒體播放器和PDA等,同時也為低功耗、便攜式體電信號的採集存儲系統提供了理想的存儲介質。表1為這7種流行卡系的簡介與比較。 7種流行卡系統比較 卡 系誕生時間/年體 積接 口目前最大容量 PC卡 1992 85.6mm%26;#215;54.0mm%26;#215;3.3mm類型I); 85.6mm%26;#215;54.0mm%26;#215;5.0mm類型II); 85.6mm%26;#215;54.0mm%26;#215;10.5mm類型III) 68針 5GB CF卡 1994 43mm%26;#215;36mm%26;#215;3.3mm 50針 2~3GB SM卡 1995 45mm%26;#215;37mm%26;#215;0.76mm 22 128MB MMC卡 1997 32mm%26;#215;24mm%26;#215;1.4mm 7針 128MB SD卡 1999 32mm%26;#215;24mm%26;#215;2.1mm 7針 128MB MS卡 1997 50mm%26;#215;21.5mm%26;#215;0.28mm 10針 128MB 基於USB接口的閃存盤 1999 型號不同,體積各異 USB接口 1GB 經過詳細的調研和性能比較,綜合各種移動存儲卡的性價比、最大容量和易實現性,筆者最終選擇CF卡作為便攜式體電信號採集存儲系統的存量載體。CF卡容量大,最大容量可達2GB以上,完全滿足長時間體電信號採集海量數據的要求;性價比高,同樣容量的卡價格是其它卡系的一半;易於系統的實現,CF卡提供了完整的ATA功能,而且通過TrueIDE工作模式兼容IDE接口;耗電量低,支持在低電壓(3.3V)下工作,實際工作電流為30~50mA,睡眠時僅為 600μA;數據吞吐量高,5V工作時吞吐量為20MB/s,3.3V工作時為6.6MB/s;可靠性高,平均無故障工作時間100萬小時。

2、CF卡的物理和硬件接口特性 CF卡可以工作在PC卡ATA I/O模式、PC卡ATA存儲模式和實IDE模式三種模式下,實IDE模式與IDE接口完全歉。CF卡遵從ATA協議,屬於塊存儲設備,存儲單元是通過磁頭(head)、柱面(cylinder,也稱磁道)和扇區(sector)組織起來的;在物理尋址(CHS)方式下,每一組H/C/S參數唯一確定存儲卡中的一個扇區,通常一個扇區擁有512字節的數據空間。一個驅動數格式化後的容量為磁頭數%26;#215;柱面數%26;#215;扇區數%26;#215;512字節。在物理尋址模式下,扇區(S)是最低的地址單位,其次是磁頭(H),最後的柱面(C)為最高尋址單位。此外,還有邏輯尋址方式(LBA)。在這種尋址方式下,CF卡按照以連續序列的邏輯扇區編號進行尋址,主機不必知道CF卡的物理幾何結構。使用28個數據位來表示邏輯扇區的地址,可以尋址2 28個扇區,理論上可以尋址136GB的容量。下面給出物理尋址方式與邏輯尋址方式的對應關係。設NS為每磁道扇區數,NH為磁頭數,C、H、S分別表示磁盤的柱面、磁頭和扇區編號,LBA表示邏輯扇區號,div為整除計算,mod為求餘計算,則:LBA=NH%26;#215;NS%26;#215; C+NC%26;#215;H+S-1;C=(LBA div NS)div NH;H=(LBA div NS)mod NH;S=(LBA mod NS)+1。 CF卡為50針接口。其中重要的信號線16根數據線、11根地址線(在TureIDE模式下僅用3根地址線)、2根寄存器組選擇信號線(CS0、 CS1)、數據的讀寫線(IORD、IOWR)、1根中斷信號請求線(INTRQ和1根復位線(RESET)。

3、CF卡的軟件接口和命令 CF內部控制器有多個寄存器,通過這些寄存器可以對CF卡內部的存儲空間進行控制和訪問。下面就實IDE模式下的寄存器組為例進行説明。 在實IDE模式下,寄存器組通過寄存器組選擇信號線(CS0、CS1)和低三位地址線(A0、A1、A2)進行訪問,具體功能和地址分配如表2所列。 表2 CF卡實IDE模式下寄存器組具體功能和地址分配表 CS1 CS0 A2 A1 A0 IORD=0 IOWR=0 位數/位 1 0 0 0 0 數據寄存器數據寄存器 16 1 0 0 0 1 錯誤寄存器特徵寄存器 8 1 0 0 1 0 扇區數寄存器扇區數寄存器 8 1 0 0 1 1 扇區號寄存器扇區號寄存器 8 1 0 1 0 0 柱面號寄存器(低字節)柱面號寄存器(低字節) 8 1 0 1 0 1 柱面號寄存器(高字節)柱面號寄存器(高字節) 8 1 0 1 1 0 驅動器選擇/磁頭寄存器驅動器選擇/磁頭寄存器 8 1 0 1 1 1 狀態寄存器命令寄存器 8 0 1 1 1 0 可選狀態寄存器設備控制寄存器 8 0 1 1 1 1 驅動器地址寄存器保留 8 CF-ATA的基本命令有30餘條,主要有數據的傳輸命令,包括扇區、緩衝區的讀寫等命令;CF卡的定義命令,包括磁道格式化、設置特徵參數等命令;電源管理命令,包括檢查電源管理模式、進入睡眠省電模式等命令;安全及權限的設置命令,包括CF卡安全密碼的設置、安全權限的鎖定與解鎖等命令。每執行一條命令都要向CF-ATA的寄存器組寫入參數和命令。下面以CF卡讀取一扇區數據為例,説明CF-ATA命令的.執行過程。 ①讀取CF卡狀態寄存器,檢測並等待當前CF卡是否空閒,若空閒,向下執行。 ②填寫地址寄存器塊。地址寄存器塊包括扇區數寄存器、扇區號寄存器、柱面號寄存器(低和高字節)、驅動器選擇/磁頭寄存器,選擇訪問的扇區地址。 ③寫命令寄存器,將讀扇區命令寫入命令寄存器(20h或21h)。 ④讀取CF卡狀態寄存器,檢測並等待CF卡的數據請求。有數據請求表示命令已被接收並處理,若長時間沒有數據請求,需要進行超時處理。 ⑤讀數據寄存器。由於數據寄存器端口為16位,因此,讀一個扇區512字節的數據僅需要連續執行256次訪問數據寄存器的操作。要注意的是,在CF卡中存儲的數據是低字節在前,高字節在後。在數據寄存器中,會產生高低字節顛倒的問題。 ⑥檢測執行結果。在執行命令後,需要查看狀態寄存器的D0位。若D0位為0,則表示命令執行成功,否則表示出錯。其相應的錯誤信息在錯誤寄存器中可以查出。

 4、TMS320LF2407與CF卡的電路連接 TMS320LF2407是TI公司C24X系列中功能最完整、資源最豐富的控制芯片DSP,提供了多種接口的最優數字控制,有最高的代碼效率。C24X 是其C2000系列新代16位定點處理器產生,內核CPU為低功耗、高性能TMS320TM構架的增強設計;最優化控制多個外設;有2個事件管理模塊,用於數據控制、電源轉換,產生多種波形PWM;同步16通道高性能10位ADC,轉換時間為500ns;支持串行異步通信接口(SCI)、串行同步外設接口(SPI)、CAN總線2.0標準接口。TMS320LF2407總尋址範圍192K字,其中包括64K字程序空間,64K字數據空間,64K字I/O空間,片內程序空間集成32K字Flash,數據空間集成2.5K字RAM,包括544字DARAM(其中256字與程序空間共享),2K字SARAM。圖 1給出了TMS320LF2401與CF卡的一種電路連接方框圖。CF卡佔用TMS320LF2407的I/O空間地址,不需要任何中間接口轉換芯片。

5、TI公司DSP彙編程序實例 考慮到TI公司的DSP各系列芯片彙編指令的兼容性例於跨平台移植和彙編語言代碼的高效性,下面給出基於連接框圖將CF卡中一扇區數據(512字節)讀到 TMS320LF2407片內RAM中彙編程序。READ_A_SECT: W_CF_RDY: ;檢測CF卡是否空閒 LDP #0h IN CF_IN,CFCOM_STAT ;讀狀態寄存器 LALC CF_IN AND #00FFh XOR #0050h BZ END_WAIT_RDY B W_CF_RDY END_WAIT_RDY: SPLK #0000h,CF_OUT OUT CF_OUT,CFERR_FEA ;寫特片寄存器 SPLK #0001h,CF_OUT OUT CF_OUT,CFSET_COU ;寫扇區數寄存器 SAR AR3,CF_OUT OUT CF_OUT,CFSEC_NO ;寫扇區號寄存器 SAR AR4,CF_OUT OUT CF_OUT,CFCYL_LOW ;寫柱面號寄存器(低字節) SAR AR5,CF_OUT OUT CF_OUT,CFCYL_HIG ;寫柱面號寄存器(高字節) SAR AR6,CF_OUT OUT CF_OUT,CF_CDH ;寫驅動器選擇/磁頭寄存器 SPLK #0020h,CF_OUT OUT CF_OUT,CFCOM_STAT ;寫命令寄存器 W_CF_DRQ:;檢測CF卡是否有數據請求 IN CF_IN,CFCOM_STAT LACL CF_IN AND #00FFh XOR #0058h BZ END_WAIT_DRQ B W_CF_DRQ END_WAIT_DRQ: LAR AR2,#0FFh ;作256次循環讀取一扇區數據(512字節) MAR *,AR1 INLOOP:IN *+,CFDATA,AR2 ;循環讀取數據寄存器 BANZ INLOOP,*-,AR1 RET 程序説明:CFDATA為數據寄存器端口地址;CFCOM_STAT為狀態/命令寄存器端口地址;CFERR_FEA為特徵寄存器端口地址;CFSEC_COU為扇區數寄存器端口地址;CFSEC_NO為扇區號寄存器端口地址;CFCYL_LOW為柱面號寄存器(低字節)端口地址;CFCYL_HIG為柱面號寄存器(高字節)端口地址;AR1、AR3~AR6輔助寄存器為程序入口參數,其中AR1為RAM數據緩衝區的起始地址;AR3~AR6為CF卡各寄存器待賦的值;CF_IN和CF_OUT為變量。程序中沒超時處理,在循環讀取數據的過程中,最好禁用時間較長的中斷。這是因為CF卡在15ms內沒有接收到命令就會進入休眠(sleep),因此不論是讀還是寫扇區,在命令出後15ms內應將數據取出或填充上,否則會出錯。

  結語

採用TI公司的C24X、C28X系列DSP與CF卡搭建體電信號採集的硬件平台,僅使用很少的外部邏輯。整個系統可以採用低電壓3.3V單一電壓供電,供電電路非常簡單。C24X、C28X系列DSP芯片對片內的各個模塊獨立供電,工作時可以屏蔽掉沒有用到的模塊,比如SCI、SPI、CAN總線接口等模塊,減少系統的功耗。在系統軟件實現上,可以採用交替式雙緩存機制,將採集到的數據先存入數據緩衝區中(1扇區佔512字節為易)。當數據緩衝區寫滿時發出溢出中斷,對CF卡進行突發寫操作。寫操作完畢可以發送命令,使CF卡立即進入休眠狀態,將功耗降至最低。這樣在數據採集系統工作的大部分時間,CF 卡處於休眠狀態,工作電流僅為600μA。 筆者TMS320LF2407與CF卡搭建建硬平台,進行16路體電信號採集,採集頻率為150Hz,CF卡容量為256MB。經實際測試,系統的功耗小於0.3W,使用3~4節乾電池或1~2手機鋰電池供電,可以連續工作10~20小時以上。該系統適於腦電、心電等體電信號的採集與存儲工作,具有低功耗、攜帶方便、長時間監護、性能價格比高等特點。