基于Linux和S3C2410的嵌入式圖象傳輸系統(tǒng)設(shè)計(jì)
如何更好的獲得監(jiān)控現(xiàn)場的圖象數(shù)據(jù)一直是棘手的一個(gè)問題,傳統(tǒng)的方法是采用CCD攝象機(jī)獲取現(xiàn)場的視頻信息,這種方法易于實(shí)現(xiàn),但成本較高。隨著ARM系列處理器應(yīng)用的越來越廣和基于linux的嵌入式技術(shù)的迅速發(fā)展,利用linux自身帶有的TCP/IP協(xié)議來實(shí)現(xiàn)遠(yuǎn)程監(jiān)控、圖象傳輸已成為可能。本文提出的正是一種這樣的方法,利用市場上很常見的中星微系列的USB攝象頭來得到現(xiàn)場的圖象數(shù)據(jù),利用linux內(nèi)核中的Video4Linux編程接口函數(shù)采集圖象,并把得到的圖象通過Internet傳輸?shù)缴衔粰C(jī)PC上,在PC上實(shí)現(xiàn)圖象的保存和顯示。
2 硬件系統(tǒng)設(shè)計(jì)原理
系統(tǒng)的硬件功能框圖如圖1所示,CPU采用的是三星公司的S3C2410。該處理器內(nèi)部集成了A R M 公司A R M 9 2 0 T 處理器核的3 2 位微控制器,并帶有獨(dú)立的16KB的指令Cache 和16KB的數(shù)據(jù)Cache、L C D 控制器、R A M 控制器、NAND 閃存控制器、3路UART、4路DMA 、4路帶PWM 的Timer、并行I/O口、8路10位ADC、觸摸屏接口、I2C接口、I2S接口、2
|
圖 1 S3C2410系統(tǒng)平臺(tái)的硬件功能框圖
3 軟件系統(tǒng)設(shè)計(jì)
本文的軟件系統(tǒng)設(shè)計(jì)采用C/S(客戶機(jī)/服務(wù)器)模式,以S3C2410平臺(tái)作為服務(wù)器,以PC作為客戶端。服務(wù)器的主要任務(wù)是把得到的圖象數(shù)據(jù)發(fā)送到Internet上去,客戶端的任務(wù)主要是從Internet上接收得到的數(shù)據(jù),并把數(shù)據(jù)以保存成文件。下面分別討論兩者的具體實(shí)現(xiàn)。
3.1 服務(wù)器端軟件系統(tǒng)設(shè)計(jì)
3.1.1 建立宿主機(jī)開發(fā)環(huán)境
本文以PC為宿主機(jī),并帶有RedHat9.0系統(tǒng),開發(fā)環(huán)境就建立在這個(gè)平臺(tái)上,其主要包括:交叉編譯器的的選擇和安裝、NFS和TFTP服務(wù)器的配置等。
對于嵌入式系統(tǒng)的開發(fā),由于沒有足夠的資源在目標(biāo)板上運(yùn)行開發(fā)工具和調(diào)試工具,所以通常采用交叉編譯調(diào)試的方式。開發(fā)時(shí)使用宿主機(jī)上的交叉編譯、匯編及連接工具形成可執(zhí)行的二進(jìn)制代碼。然后把可執(zhí)行文件下載到目標(biāo)機(jī)上運(yùn)行。本文采用的交叉編譯器為arm-linux-gcc,具體安裝不再贅述。為了方便調(diào)試和下載燒寫,可讓宿主機(jī)支持NFS和TFTP服務(wù)器。需要特別說明的是為了支持TFTP服務(wù)器需要在安裝RedHat9.0時(shí)須選擇完全安裝,如果沒有選擇完全安裝,需要將第三張光盤里面的tftp-server-0.32-4.i386.rpm和tftp-0.32-4.i386.rpm安裝到宿主機(jī)下。
3.1.2 攝象頭驅(qū)動(dòng)程序的實(shí)現(xiàn)
系統(tǒng)采用的是最普通的USB攝像頭,主芯片為中星微ZC0301P。這種攝象頭的一個(gè)特點(diǎn)是可以實(shí)現(xiàn)硬件JPEG編碼。其驅(qū)動(dòng)程序的編寫重點(diǎn)包括下面的內(nèi)容:提供基本的I/O 操作接口函數(shù)open、read、write、close的實(shí)現(xiàn)、對中斷的處理實(shí)現(xiàn)、內(nèi)存映射功能以及對I/O 通道的控制接口函數(shù)ioctl的實(shí)現(xiàn)等,并把它們定義在struct file_operations中。這樣當(dāng)應(yīng)用程序?qū)υO(shè)備文件進(jìn)行諸如open、close、read、write等系統(tǒng)調(diào)用操作時(shí),Linux內(nèi)核將通過file_operations結(jié)構(gòu)訪問驅(qū)動(dòng)程序提供的函數(shù)。
當(dāng)然,現(xiàn)在網(wǎng)上已經(jīng)有了這種攝象頭的通用驅(qū)動(dòng),可以從相關(guān)網(wǎng)站 下載usb-2.4.31.patch.gz,然后將這個(gè)補(bǔ)丁打到內(nèi)核對應(yīng)的位置即可。但是對有些內(nèi)核版本的linux系統(tǒng),在打補(bǔ)丁時(shí),會(huì)產(chǎn)生Config.in.rej和Makefile.rej。這時(shí)只需要將這兩個(gè)文件中修改失敗的部分手動(dòng)添加到對應(yīng)的Config.in和Makefile中去就可以了。
3.1.3 linux內(nèi)核配置
對于已經(jīng)做過基本移植的linux在配置內(nèi)核的時(shí)有以下幾個(gè)方面是值得注意的:
1) 因?yàn)橐玫絻?nèi)核中的Video4Linux編程接口函數(shù),所以在配置內(nèi)核時(shí)首先必須選中Video for Linux并且最好是直接編譯進(jìn)內(nèi)核而不用編譯成模塊的形式再加載;
2) 要選中USB Support、OHCI、UHCI。并在USB Support下的USB Multimedia devices 中選中對應(yīng)的攝象頭,對本系統(tǒng)來說,選擇USB SPCA5XX Sunplus Vimicro Sonix Cameras,并把它配置成Module。
3) 配置完內(nèi)核后做make dep, make zImage, make module。則在對應(yīng)的spca5xx目錄下會(huì)生成spc5xx..o,可以把spc5xx..o通過NFS mount到目標(biāo)板上或者加到主文件系統(tǒng)ramdisk中的某個(gè)目錄下。然后在目標(biāo)板上做 insmod spca5xx.o就會(huì)找到攝象頭。
3.1.4 服務(wù)器端應(yīng)用程序的編寫
完成驅(qū)動(dòng)程序和內(nèi)核配置后就開始應(yīng)用程序的編寫了,程序首先用交叉編譯器在宿主機(jī)上進(jìn)行編譯連接,生成的的可執(zhí)行文件通過NFS mount到目標(biāo)板上進(jìn)行調(diào)試。調(diào)試成功后再
|
1) 初始化設(shè)備基本信息
2) 打開設(shè)備文件,讀取設(shè)備基本信息和信號(hào)源基本信息,并設(shè)置video_mmap并為定義的幀結(jié)構(gòu)分配緩沖區(qū)并初始化線程互斥量
3) 創(chuàng)建圖象獲取的線程。該線程函數(shù)實(shí)現(xiàn)以內(nèi)存影射的方式讀取設(shè)備中的數(shù)據(jù),鎖定線程互斥量,接著對幀結(jié)構(gòu)的各個(gè)元素賦值。并解鎖互斥量。使該過程做一個(gè)死循環(huán)。
4) 創(chuàng)建一個(gè)基于連接的socket,并綁定到一個(gè)端口上,開始在該端口上偵聽。
5) 當(dāng)有連接到來時(shí),創(chuàng)建一個(gè)圖象發(fā)送的線程。該線程函數(shù)實(shí)現(xiàn):如果確定讀取了客戶端的數(shù)據(jù),則把緩沖區(qū)內(nèi)的一幀數(shù)據(jù)發(fā)送到網(wǎng)絡(luò)上。讓這個(gè)過程也為死循環(huán)。
6) 控制兩個(gè)線程的同步
7) 如果程序退出,則關(guān)閉套接字,釋放分配的資源。
可以看出,程序的內(nèi)容主要有三個(gè)部分:圖象采集部分,圖象的網(wǎng)絡(luò)發(fā)送部分和程序的多線程控制部分。下面分別介紹一下這三個(gè)部分主要涉及的內(nèi)容。
在圖象采集部分,定義了一個(gè)數(shù)據(jù)結(jié)構(gòu),它的主要成員變量有:
l Video_capability 包含基本的設(shè)備信息(設(shè)備名稱、支持的最大最小分辨率、信號(hào)源信息)
l video_channel 關(guān)于各個(gè)信號(hào)源的屬性
l video_mbuf 利用mmap進(jìn)行映射的幀的信息
l video_buffer 最底層對buffer的描述
l video_mmap 用于mmap
l pthread_mutex_t 線程互斥量
截取圖象方法有兩種:直接讀取設(shè)備文件和內(nèi)存影射的方法,本文采用后面一種。采用這種方法后,普通文件被映射到內(nèi)存地址空間,進(jìn)程可以象訪問普通文件一樣訪問內(nèi)存,這樣做的一個(gè)好處是可以提高效率。做視頻截取的兩個(gè)主要函數(shù)是:
n ioctl(vd->fd, VIDIOCMCAPTURE, &(vd->mmap)) 若調(diào)用成功,開始一副圖象的截取。是否截取完畢留給VIDIOCSYNC來判斷。
n ioctl(vd->fd, VIDIOCSYNC, &frame) 若調(diào)用成功,表明一幀截取已完成??梢蚤_始做下一次截取
對于網(wǎng)絡(luò)發(fā)送部分,主要是linux下的socket編程,調(diào)用的主要函數(shù)有:創(chuàng)建套接字函數(shù)socket、端口綁定函數(shù)bind、監(jiān)聽
多線程編程部分用到的主要函數(shù)有:互斥量初始化函數(shù)pthread_mutex_init、互斥量鎖定函數(shù)pthread_mutex_lock、互斥量解鎖函數(shù)pthread_mutex_unlock、互斥量注銷函數(shù)pthread_ mutex _destroy、線程創(chuàng)建函數(shù)pthread _ create、線程同步函數(shù)pthread_join。此外,程序中為了能更好的實(shí)現(xiàn)兩個(gè)進(jìn)程的同步,還需要用到信號(hào)量機(jī)制的一些內(nèi)容。受篇幅所限,這些函數(shù)的具體定義和用法請參考相關(guān)資料 。
3.2 客戶機(jī)端軟件系統(tǒng)設(shè)計(jì)
客戶端是建立在一臺(tái)PC機(jī)上,用Visual C++ 6.0設(shè)計(jì)一個(gè)基于MFC的界面作為接收端。在接收端主要完成從網(wǎng)絡(luò)緩沖區(qū)內(nèi)讀取數(shù)據(jù),并保存成文件的形式,文件以接收到數(shù)據(jù)的時(shí)間為名。圖2為圖象采集時(shí)間間隔為1秒時(shí)程序執(zhí)行的結(jié)果。圖象大小為320 象素。需要說明的是:服務(wù)器端發(fā)送的數(shù)據(jù)采用了單字節(jié)對齊,對應(yīng)的在客戶端接收的時(shí)候也要采用單字節(jié)對齊。在WINDOWS下實(shí)現(xiàn)內(nèi)存單字節(jié)對齊的方法是在定義的幀結(jié)構(gòu)體前面加上#pragma pack (1),并在其定義之后加上#pragma pack ()。
圖2 客戶端程序執(zhí)行結(jié)果(1秒種采集一次圖象)
4 結(jié)束語
本文提出了一套基于S3C2410平臺(tái)和linux系統(tǒng)的嵌入式圖象采集、傳輸系統(tǒng)的具體實(shí)現(xiàn),并給出了實(shí)驗(yàn)結(jié)果。實(shí)驗(yàn)結(jié)果證明:系統(tǒng)很好的完成了圖象采集和傳輸。得到的圖象清晰。服務(wù)器可以穩(wěn)定運(yùn)行,不會(huì)發(fā)生斷開或退出的現(xiàn)象。本系統(tǒng)可應(yīng)用于工業(yè)現(xiàn)場的監(jiān)控,也可以與其他系統(tǒng)如門禁系統(tǒng)相結(jié)合獲得門開或關(guān)時(shí)現(xiàn)場的重要圖象數(shù)據(jù)。
參考文獻(xiàn)
[1] Alessandro Rubini著 LISOLEG譯,linux設(shè)備驅(qū)動(dòng)程序開發(fā),中國電力出版社,2002
[2] 喬曉丹張鵬,一個(gè)基于Linux操作系統(tǒng)的嵌入式網(wǎng)關(guān)的實(shí)現(xiàn),微計(jì)算機(jī)信息,2005年第21卷第7-2期
[3] 朱剛 等,Linux網(wǎng)絡(luò)編程,科學(xué)出版社,2000.
[4] 于明儉 等,linux程序設(shè)計(jì)權(quán)威指南 機(jī)械工業(yè)出版社 2001.
評(píng)論