基于ARM和DSP的嵌入式智能儀器系統(tǒng)
1 引言
隨著智能儀器及控制系統(tǒng)對實時性信號處理的要求不斷提高和大規(guī)模集成電路技術的迅速發(fā)展。越來越迫切的要求有一種高性能的設計方案與之相適應,將DSP技術和ARM技術結合起來應用于嵌入式系統(tǒng)中,將會充分發(fā)揮兩者優(yōu)勢以達到智能控制系統(tǒng)中對數據的實時性、高效性的通信要求。該嵌入式系統(tǒng)要求實時響應,具有嚴格的時序性。其工作環(huán)境可能非常惡劣,如高溫、低溫、潮濕等,所以系統(tǒng)還要求非常高的穩(wěn)定性。
2 嵌入式系統(tǒng)的總體設計
2.1 核心器件的主要功能
ARM和DSP分別選用Cirrus Logic公司的EP7312、TI公司的TMS320VC5402。充分利用ARM豐富的片上資源和DSP強大的信號處理功能,實現(xiàn)高效性、實時性的信號處理及網絡通信功能。
EP7312是專為高性能、超低功耗產品而設計的微處理器,采用ARM7TDMI處理器內核,具有8kB高速緩沖存儲器,支持存儲器管理單元,片內集成了液晶顯示器控制器,鍵盤掃描器,數字音頻接口,完全的JTAG等功能,廣泛地應用于嵌入式領域。TMS320C54xDSP提供了McBSPs(多通道緩沖串口);6通道的DMA控制器;可以與外部處理器直接通信的8位增強HPI(主機接口)。選擇這樣的SOC(片上系統(tǒng))作為該系統(tǒng)的核心器件,使得其穩(wěn)定可靠并具有廣泛的擴展功能。
2.2 系統(tǒng)總體設計及工作原理
系統(tǒng)總體設計框圖如圖1所示。本系統(tǒng)主要是實現(xiàn)信號的實時性處理及傳輸,滿足工業(yè)現(xiàn)場及各種測量儀器的高可靠性要求。ARM有豐富的片上資源,適合嵌入式系統(tǒng)的開發(fā),在該嵌入式系統(tǒng)中,ARM主要負責操作系統(tǒng)的運行、任務管理和協(xié)調以及DSP的控制任務,完成數據的遠程通信。擴展了外部擴展了多種外設,如通用串口、LCD顯示屏,以太網接口。通過連接以太網控制器實現(xiàn)網絡化功能。在ARM中移植了Linux操作系統(tǒng)和實現(xiàn)了系統(tǒng)外部硬件接口的驅動程序。由DSP執(zhí)行計算密集型操作,實現(xiàn)多種信號處理算法,然后將處理后的數字信號通過主機口接口(HPI)與ARM通信。再由ARM通過以太網控制器將數據傳輸到網絡,實現(xiàn)了遠程控制與監(jiān)測。
圖1 系統(tǒng)總體硬件框圖
3 系統(tǒng)硬件具體設計方案
3.1 ARM與DSP的接口設計
EP7312和TMS320VC5402連接的接口電路如圖2所示。VC5402通過HPI與ARM進行連接。ARM先向DSP寫入控制字,設置工作模式,然后將訪問地址寫入地址寄存器(HPIA),再對數據鎖存器(HPID)進行讀寫,即可讀出和寫入指定的存儲單元。主機由兩根地址線A2、A1可以尋址到HPI接口的所有控制寄存器、地址寄存器和數據寄存器;由HBIL、HCNTL1、HCNTL0區(qū)分16位數據的高、低字節(jié)。當向HBIL=0的地址寫入數據時,表示是第一個字節(jié),向HBIL=1的地址寫入數據表示第二個字節(jié)。尋址過程中HCS要為低電平。
圖2 EP7312與TMS320VC5402的連接
DSP的HPI接口片選信號使用EP7312擴展片選信號nCS4,HPI各個特殊功能寄存器的映射地址如下:
#define HPIC0 *(volatile unsigned char*)0x40000000
#define HPIC1 *(volatile unsigned char*)0x40000001
#define HPIA0 *(volatile unsigned char*)0x40000004
#define HPIA1 *(volatile unsigned char*)0x40000005
#define HPID0 *(volatile unsigned char*)0x40000006
#define HPID1 *(volatile unsigned char*)0x40000007
設置好DSP的狀態(tài)后,DSP向ARM發(fā)送中斷,通知ARM已將數據準備好,等待ARM發(fā)中斷,DSP在中斷中對接收的數據進行處理。ARM在初始化后,等待DSP發(fā)送中斷通知ARM數據已經準備好。ARM在檢測到中斷后,先判斷中斷是否有效,再從HPI口讀寫數據,在完成向HPI口發(fā)送數據后,向DSP發(fā)送中斷通知DSP接收數據。ARM通過控制端口信號模擬接口時序,來完成對HPI口寄存器的訪問。由于DSP在BOOT過程中向ARM發(fā)送了中斷,所以ARM在初始化時要清除這個中斷,并且在數據交互之前要設置控制寄存器中的BOB位,指示高地址在前還是低地址在前。這一步在程序初始化時由ARM來完成。
評論