利用ColdFire uClinux實現(xiàn)數(shù)據(jù)采集和傳輸
發(fā)布時間:2007/8/30 0:00:00 訪問次數(shù):834
來源:電子技術(shù)應(yīng)用 作者:陸寶輅 李薦民 李 剛
摘要:介紹了利用ColdFire uClinux實現(xiàn)數(shù)據(jù)采集和傳輸。這項技術(shù)被用在大型集裝箱檢測系統(tǒng)中,取得了很好的效果。
關(guān)鍵詞:ColdFire uClinux 數(shù)據(jù)采集
在ColdFire上嵌入uClinux操作系統(tǒng)是一項比較成熟的技術(shù),般應(yīng)用在手持設(shè)備、家庭網(wǎng)關(guān)、工業(yè)控制中。但在數(shù)據(jù)采集應(yīng)用中使用這項技術(shù)卻不是很常見,原因是uClinux不是實時操作系統(tǒng),而數(shù)據(jù)采集應(yīng)用對數(shù)據(jù)采集的實時性要求很高。本文介紹如何利用在ColdFire上嵌入uClinux操作系統(tǒng)的方法來實現(xiàn)數(shù)據(jù)的采集和傳輸。
1 硬件平臺
任何嵌入式應(yīng)用系統(tǒng)都離不開具體的硬件平臺,這里先介紹一下系統(tǒng)采用的硬件平臺。圖1所示即為硬件結(jié)構(gòu)的示意圖。其中,SPM是數(shù)據(jù)處理模塊,它控制前端的A/D變換,根據(jù)設(shè)定的采集周期將A/D變換后的數(shù)據(jù)保存在其內(nèi)部的RAM中;同時發(fā)出一個中斷信號。ColdFire 5307 xBoard是基于Motorola公司高性能嵌入式32位處理器ColdFire 5307自行開發(fā)的嵌入式應(yīng)用開發(fā)板。其硬件配置包括:
ColdFire5307 90MHz 32位處理器;16M SDRAM;2M Flash ROM;10Mbps以太網(wǎng)接口;兩個UART串口;兩個64針的地址和數(shù)據(jù)總線接口。
ISC(圖像控制工作站)和IDS(圖像數(shù)據(jù)工作站)是兩個工作站,用來對系統(tǒng)實現(xiàn)控制,對圖像數(shù)據(jù)實現(xiàn)處理。XBoard和工作站處在同一個以太網(wǎng)上,該以太網(wǎng)上還配有其它的設(shè)備。uClinux所要實現(xiàn)的功能是實時地將SPM上采集的數(shù)據(jù)通過以太網(wǎng)傳到IDS上,同時接收來自ICS的命令以對SPM進行控制。
2 SPM和xBoard之間的連接
uClinux需要讀取SPM中的RAM,所以最好是把SPM中的RAM作為uClinux的內(nèi)存地址的一部分。SPM和xBoard上MCF5307之間的硬件連接如圖2所示。
SPM中RAM的地址線、數(shù)據(jù)線和控制線直接連到CPU的總線上。除了硬件上的連接之外,還需要設(shè)置MCF5307的寄存器,為SPM上的RAM分配內(nèi)存空間。XBoard在加電時首先運行debug程序,所以在debug中進行寄存器的設(shè)置是比較合適的。在debug源代碼中的sysinit.c文件里的mcf5307_cs_init函數(shù)中加上下面的語句:
MCF5307_WR_CS_CSAR5(imm,0xa000); SPM的地址從0xa0000000開始
MCF5307_WR_CS_CSCR5(imm,0x3d40); 采用8位的讀方式
MCF5307_WR_CS_CSMR5(imm,0x01FF0001); 空間大小為1M
將SPM控制的引腳和MCF5307的并口引腳相連,這產(chǎn)對SPM的控制就只需設(shè)置并口的相應(yīng)位了。
3 uClinux下的實時性
uClinux并不是一個實時操作系統(tǒng)(RTOS),如何使用uClinux完成有實時性要求的數(shù)據(jù)采集是需要考慮的問題。由于應(yīng)用中只一個實時的任務(wù)——從SPM中讀取數(shù)據(jù),所以采用中斷的方式來對數(shù)據(jù)采集完的信號提供實時響應(yīng)。下面的代碼用來向uClinux注冊IRQ7中斷處理程序:result=request_irq(ECM_IRQ,ecm_interrupt,0,“ecm”,NULL);
在中斷處理程序中,先關(guān)閉中斷,因為中斷嵌套在這里是沒有意義的,還有一個重要的原因是SPM中斷信號的低電平持續(xù)時間比較長。CPU是利用低電平來標志斷信號的,所以CPU可能在SPM的一個中斷信號中檢測到多次中斷。關(guān)閉中斷后,從SPM的RAM中讀取數(shù)據(jù)。由于SPM和xBoard之間的連接已得到保證,SPM的內(nèi)部RAM成為uClinux的內(nèi)存空間的一部分,所以讀的工作是很簡單的,只是將數(shù)據(jù)從一個地址讀到另外一個地址,讀完數(shù)據(jù)后打開中斷。讀數(shù)據(jù)之間發(fā)生的中斷都會被忽略。讀數(shù)據(jù)塊的大小為4096字節(jié),讀完所有的數(shù)據(jù)需要2ms。所以在采集周期低于2ms的情況下,系統(tǒng)無法正常工作。不過這個指標低于應(yīng)用的要求。
4 數(shù)據(jù)的臨時存放
xBoard上并沒有大的存儲設(shè)備,所以uClinux采集的數(shù)據(jù)必須及時地傳送出去。以太網(wǎng)上通過交換機連接著多個設(shè)備,在網(wǎng)絡(luò)繁忙的時候并不能保證數(shù)據(jù)會被及時地傳出去。解決這個問題的方法是開辟一個緩沖區(qū),將暫時無法傳出去的數(shù)據(jù)放在緩沖區(qū)中。
由于沒有MMU的支持,uClinux不能提供內(nèi)存保護機制,進程可以隨意讀取任何內(nèi)存地址。這樣,在帶來方便的同時也增加了一些麻煩。方便的一面表現(xiàn)在可以在進程中開辟緩沖區(qū),在內(nèi)核中用同樣的地址使用緩沖區(qū);不利的一方面表現(xiàn)在開辟動態(tài)內(nèi)存必須十分小心,不能和其它進程發(fā)生重疊。
在進程中開辟了50個數(shù)據(jù)緩沖片,這些緩沖片通過三個雙向鏈表維持形成緩沖區(qū)。所有的緩沖片被掛在一個稱為list的雙向鏈表中,退出進程的時候,應(yīng)該將這些動態(tài)內(nèi)存釋放。同時,將存有有效數(shù)據(jù)(即尚未被發(fā)送出去的數(shù)據(jù))的緩沖片放在稱為dirty的雙向鏈表中,將可以使用的緩沖片放在稱為clean的雙向鏈表中。中斷處理程序每次從clean鏈表中取得一個緩沖片,存入數(shù)據(jù)后放到dirt
來源:電子技術(shù)應(yīng)用 作者:陸寶輅 李薦民 李 剛
摘要:介紹了利用ColdFire uClinux實現(xiàn)數(shù)據(jù)采集和傳輸。這項技術(shù)被用在大型集裝箱檢測系統(tǒng)中,取得了很好的效果。
關(guān)鍵詞:ColdFire uClinux 數(shù)據(jù)采集
在ColdFire上嵌入uClinux操作系統(tǒng)是一項比較成熟的技術(shù),般應(yīng)用在手持設(shè)備、家庭網(wǎng)關(guān)、工業(yè)控制中。但在數(shù)據(jù)采集應(yīng)用中使用這項技術(shù)卻不是很常見,原因是uClinux不是實時操作系統(tǒng),而數(shù)據(jù)采集應(yīng)用對數(shù)據(jù)采集的實時性要求很高。本文介紹如何利用在ColdFire上嵌入uClinux操作系統(tǒng)的方法來實現(xiàn)數(shù)據(jù)的采集和傳輸。
1 硬件平臺
任何嵌入式應(yīng)用系統(tǒng)都離不開具體的硬件平臺,這里先介紹一下系統(tǒng)采用的硬件平臺。圖1所示即為硬件結(jié)構(gòu)的示意圖。其中,SPM是數(shù)據(jù)處理模塊,它控制前端的A/D變換,根據(jù)設(shè)定的采集周期將A/D變換后的數(shù)據(jù)保存在其內(nèi)部的RAM中;同時發(fā)出一個中斷信號。ColdFire 5307 xBoard是基于Motorola公司高性能嵌入式32位處理器ColdFire 5307自行開發(fā)的嵌入式應(yīng)用開發(fā)板。其硬件配置包括:
ColdFire5307 90MHz 32位處理器;16M SDRAM;2M Flash ROM;10Mbps以太網(wǎng)接口;兩個UART串口;兩個64針的地址和數(shù)據(jù)總線接口。
ISC(圖像控制工作站)和IDS(圖像數(shù)據(jù)工作站)是兩個工作站,用來對系統(tǒng)實現(xiàn)控制,對圖像數(shù)據(jù)實現(xiàn)處理。XBoard和工作站處在同一個以太網(wǎng)上,該以太網(wǎng)上還配有其它的設(shè)備。uClinux所要實現(xiàn)的功能是實時地將SPM上采集的數(shù)據(jù)通過以太網(wǎng)傳到IDS上,同時接收來自ICS的命令以對SPM進行控制。
2 SPM和xBoard之間的連接
uClinux需要讀取SPM中的RAM,所以最好是把SPM中的RAM作為uClinux的內(nèi)存地址的一部分。SPM和xBoard上MCF5307之間的硬件連接如圖2所示。
SPM中RAM的地址線、數(shù)據(jù)線和控制線直接連到CPU的總線上。除了硬件上的連接之外,還需要設(shè)置MCF5307的寄存器,為SPM上的RAM分配內(nèi)存空間。XBoard在加電時首先運行debug程序,所以在debug中進行寄存器的設(shè)置是比較合適的。在debug源代碼中的sysinit.c文件里的mcf5307_cs_init函數(shù)中加上下面的語句:
MCF5307_WR_CS_CSAR5(imm,0xa000); SPM的地址從0xa0000000開始
MCF5307_WR_CS_CSCR5(imm,0x3d40); 采用8位的讀方式
MCF5307_WR_CS_CSMR5(imm,0x01FF0001); 空間大小為1M
將SPM控制的引腳和MCF5307的并口引腳相連,這產(chǎn)對SPM的控制就只需設(shè)置并口的相應(yīng)位了。
3 uClinux下的實時性
uClinux并不是一個實時操作系統(tǒng)(RTOS),如何使用uClinux完成有實時性要求的數(shù)據(jù)采集是需要考慮的問題。由于應(yīng)用中只一個實時的任務(wù)——從SPM中讀取數(shù)據(jù),所以采用中斷的方式來對數(shù)據(jù)采集完的信號提供實時響應(yīng)。下面的代碼用來向uClinux注冊IRQ7中斷處理程序:result=request_irq(ECM_IRQ,ecm_interrupt,0,“ecm”,NULL);
在中斷處理程序中,先關(guān)閉中斷,因為中斷嵌套在這里是沒有意義的,還有一個重要的原因是SPM中斷信號的低電平持續(xù)時間比較長。CPU是利用低電平來標志斷信號的,所以CPU可能在SPM的一個中斷信號中檢測到多次中斷。關(guān)閉中斷后,從SPM的RAM中讀取數(shù)據(jù)。由于SPM和xBoard之間的連接已得到保證,SPM的內(nèi)部RAM成為uClinux的內(nèi)存空間的一部分,所以讀的工作是很簡單的,只是將數(shù)據(jù)從一個地址讀到另外一個地址,讀完數(shù)據(jù)后打開中斷。讀數(shù)據(jù)之間發(fā)生的中斷都會被忽略。讀數(shù)據(jù)塊的大小為4096字節(jié),讀完所有的數(shù)據(jù)需要2ms。所以在采集周期低于2ms的情況下,系統(tǒng)無法正常工作。不過這個指標低于應(yīng)用的要求。
4 數(shù)據(jù)的臨時存放
xBoard上并沒有大的存儲設(shè)備,所以uClinux采集的數(shù)據(jù)必須及時地傳送出去。以太網(wǎng)上通過交換機連接著多個設(shè)備,在網(wǎng)絡(luò)繁忙的時候并不能保證數(shù)據(jù)會被及時地傳出去。解決這個問題的方法是開辟一個緩沖區(qū),將暫時無法傳出去的數(shù)據(jù)放在緩沖區(qū)中。
由于沒有MMU的支持,uClinux不能提供內(nèi)存保護機制,進程可以隨意讀取任何內(nèi)存地址。這樣,在帶來方便的同時也增加了一些麻煩。方便的一面表現(xiàn)在可以在進程中開辟緩沖區(qū),在內(nèi)核中用同樣的地址使用緩沖區(qū);不利的一方面表現(xiàn)在開辟動態(tài)內(nèi)存必須十分小心,不能和其它進程發(fā)生重疊。
在進程中開辟了50個數(shù)據(jù)緩沖片,這些緩沖片通過三個雙向鏈表維持形成緩沖區(qū)。所有的緩沖片被掛在一個稱為list的雙向鏈表中,退出進程的時候,應(yīng)該將這些動態(tài)內(nèi)存釋放。同時,將存有有效數(shù)據(jù)(即尚未被發(fā)送出去的數(shù)據(jù))的緩沖片放在稱為dirty的雙向鏈表中,將可以使用的緩沖片放在稱為clean的雙向鏈表中。中斷處理程序每次從clean鏈表中取得一個緩沖片,存入數(shù)據(jù)后放到dirt
熱門點擊
- 在PC上運行的實時操作系統(tǒng)LabVIEW R
- Keil C動態(tài)內(nèi)存管理機制分析及改進
- ARM內(nèi)核的中斷技術(shù)
- 視頻采集卡Windows95驅(qū)動程序設(shè)計
- Microwindows在遠程紅外抄表器中的
- 利用ColdFire uClinux實現(xiàn)數(shù)據(jù)
- 采用8位單片機驅(qū)動PCI總線網(wǎng)卡的設(shè)計方案
- 基于I2C總線的MSP430單片機應(yīng)用系統(tǒng)設(shè)
- 基于8051軟核的SOPC系統(tǒng)設(shè)計與實現(xiàn)
- 一款32位嵌入式CPU的定點加法器設(shè)計
推薦技術(shù)資料
- CV/CC InnoSwitch3-AQ 開
- URF1DxxM-60WR3系
- 1-6W URA24xxN-x
- 閉環(huán)磁通門信號調(diào)節(jié)芯片NSDRV401
- SK-RiSC-SOM-H27X-V1.1應(yīng)
- RISC技術(shù)8位微控制器參數(shù)設(shè)
- 多媒體協(xié)處理器SM501在嵌入式系統(tǒng)中的應(yīng)用
- 基于IEEE802.11b的EPA溫度變送器
- QUICCEngine新引擎推動IP網(wǎng)絡(luò)革新
- SoC面世八年后的產(chǎn)業(yè)機遇
- MPC8xx系列處理器的嵌入式系統(tǒng)電源設(shè)計
- dsPIC及其在交流變頻調(diào)速中的應(yīng)用研究