基于NiosII的IP Camera傳輸系統(tǒng)實(shí)現(xiàn)
1 引言
隨著網(wǎng)絡(luò)技術(shù)的發(fā)展,人們對監(jiān)控功能要求越來越高,網(wǎng)絡(luò)攝像頭以其特有的優(yōu)勢改變了傳統(tǒng)監(jiān)控手段,為遠(yuǎn)程實(shí)時監(jiān)控提供了出色的解決方案。人們只需打開網(wǎng)頁或視頻瀏覽器就可實(shí)時查看需要監(jiān)控場所的安全情況。
2 系統(tǒng)的硬件設(shè)計(jì)
IP Camera的硬件架構(gòu)如圖1所示,這是筆者參與開發(fā)的一種基于Altera公司NiosII嵌入式軟核CPU的網(wǎng)絡(luò)視頻傳輸設(shè)計(jì)方案,實(shí)現(xiàn)了以太網(wǎng)內(nèi)視頻數(shù)據(jù)傳輸。FPGA采用的是Altera公司的Cy-cloneII系列的EP2C35F672C6器件。IP camera主要是由視頻采集、Cyclone FPGA及系統(tǒng)存儲和網(wǎng)絡(luò)傳輸?shù)?部分組成。由于Cyclone FPGA及系統(tǒng)存儲的電路設(shè)計(jì)具有一定的通用性,所以這里僅介紹視頻采集和網(wǎng)絡(luò)傳輸?shù)碾娐吩O(shè)計(jì)。
2.1視頻采集模塊設(shè)計(jì)
本系統(tǒng)設(shè)計(jì)的視頻采集器件采用ADV7181B。ADV7181B是一款集成的視頻解碼器,通過配置可以接收CVBS復(fù)合視頻、S-Video及YPrPb分量多種模擬信號,ADV7181B的數(shù)字輸出是16位或8位、并與CCIR656標(biāo)準(zhǔn)兼容的YCrCb4:2:2視頻數(shù)據(jù),還包括垂直同步VS、水平同步HS及場同步信號。
本系統(tǒng)設(shè)計(jì)選用ADV7181B的AIN6作為CVBS復(fù)合視頻信號的輸入,ADV7181B的輸出數(shù)據(jù)采用8位的數(shù)據(jù)寬度。ADV7181B的27 MHz時鐘由FPGA提供,F(xiàn)PGA通過I2C總線讀/寫ADV7181B的寄存器控制ADV7181B,ADV7181B的I2C總線讀地址為0x40,寫地址為0x41。ADV7181B的8位YCrCb4:2:2視頻輸出數(shù)據(jù)及其他輸出信號直接連接至FPGA。視頻采集電路模塊電路圖如圖2所示。
2.2網(wǎng)絡(luò)傳輸模塊設(shè)計(jì)
本系統(tǒng)設(shè)計(jì)的網(wǎng)絡(luò)器件采用DM9000A。DM9000A是Davicom公司推出的一款低功耗高速網(wǎng)絡(luò)控制器,該器件具有通用處理器接口、10 M/100 M PHY和4 KB的SRAM。
本系統(tǒng)設(shè)計(jì)的以太網(wǎng)接口部分電路原理圖如圖3所示在DM9000A的48個引腳中,TX+、TX-、RX+、RX-分別連接到RJ45INTLED的TD+、TD-、RD+、RD-。而LED1和LED2則分別連接至RJ45INTLFD的黃色LED與綠色LED接口,除懸空引腳和電源相關(guān)引腳外,其余引腳均連接至FPGA。
3 系統(tǒng)軟件設(shè)計(jì)
系統(tǒng)軟件設(shè)計(jì)主要包括:建立底層軟件平臺一NiosII IDE提供的底層軟件開發(fā)平臺,建立應(yīng)用軟件,創(chuàng)建用戶傳輸任務(wù)等功能,從而實(shí)現(xiàn)TCP/IP連接和視頻數(shù)據(jù)傳輸。
3.1 建立底層軟件平臺-μC/OS-II和LWIP
考慮到嵌入式系統(tǒng)的有限資源及NiosII IDE開發(fā)環(huán)境對μC/OS-II的支持,系統(tǒng)選擇μC/OS-II作為操作系統(tǒng)。在NiosII IDE集成開發(fā)環(huán)境中,μC/OS-II的加載非常方便,只需在建立工程時選取μC/OS-II庫選項(xiàng)即可。更重要的是,它根據(jù)用戶在SOPC中搭建的硬件平臺而動態(tài)加載。開發(fā)系統(tǒng)時,需不斷修改和調(diào)整硬件平臺,從而獲取最佳配置。NiosIIIDE開發(fā)環(huán)境會自動根據(jù)開發(fā)者修改后的硬件平臺加載μC/OS-II。這樣,開發(fā)者無需考慮硬件平臺就可解決與操作系統(tǒng)μC/OS-II不匹配問題。
LWIP是瑞士計(jì)算機(jī)科學(xué)院的開發(fā)的TCP/IP協(xié)議棧,其開發(fā)的初衷是用于嵌入式系統(tǒng),一般它只需要幾十KB的RAM和約40 KB的ROM就可運(yùn)行。NiosII IDE開發(fā)環(huán)境內(nèi)部集成了LWIP協(xié)議棧,用戶在加載操作系統(tǒng)μC/OS-II后,只需選取相應(yīng)的LWIP選項(xiàng),即可加入?yún)f(xié)議棧。工程中,LWIP以系統(tǒng)庫的形式存在,應(yīng)用軟件只需加上相應(yīng)的頭文件,就可調(diào)用API函數(shù)實(shí)現(xiàn)網(wǎng)絡(luò)連接、數(shù)據(jù)收發(fā)等功能,迅速實(shí)現(xiàn)系統(tǒng)的網(wǎng)絡(luò)接入。
3.2建立應(yīng)用軟件
本系統(tǒng)設(shè)計(jì)的嵌入式應(yīng)用軟件流程圖如圖4所示。
首先對堆棧和驅(qū)動程序初始化。初始化堆棧,應(yīng)在調(diào)用OSStart啟動μC/OS-II調(diào)度程序之前調(diào)用IDE的庫函數(shù)lwip_stack_int(),該函數(shù)用于設(shè)置協(xié)議棧。堆棧初始化后,再調(diào)用庫函數(shù)init_done_func(),但該函數(shù)必須調(diào)用庫函數(shù)lwip_devices_init(),這個函數(shù)將對在system.h中定義的所有已安裝的以太網(wǎng)設(shè)備驅(qū)動程序進(jìn)行注冊。函數(shù)lwip_devices_init()還會調(diào)用函數(shù)get_mac_addr()和函數(shù)get_ip_address()從而獲取系統(tǒng)的mac地址和IP地址。當(dāng)lwip_devices_init()返回一個非0值則表示注冊成功。注冊成功后,LWIP??捎?,從而便可在程序中創(chuàng)建任務(wù)。
初始化完成后,使用函數(shù)sys_thread_new()創(chuàng)建使用套接字API與LWIP棧對話的新任務(wù)。系統(tǒng)中,由函數(shù)sys_thread_new(link_task,NULL,link_PRIO)創(chuàng)建的用戶任務(wù)是link_task()。該任務(wù)中,系統(tǒng)調(diào)用函數(shù)listen(fd_listen,1)監(jiān)聽上位機(jī)連接是否成功,一旦連接成功,調(diào)用NiosII IDE所提供的IO操作函數(shù)IOWR(OUT_PIO_BASE,0,0x01)控制接收模塊,將視頻數(shù)據(jù)保存到SRAM,當(dāng)存滿一幀后,接收模塊產(chǎn)生一個中斷,這時系統(tǒng)可通過指針讀取SRAM中的值a[i]=*(p+i+N/2*(TIMES-times),每讀取1 450 Byte就調(diào)用套接字API函數(shù)send(clisock,send_buf,N,0)發(fā)送至上位機(jī)。由于保存圖像的分辨率僅是320×240,所以數(shù)據(jù)量并不大。發(fā)送時,通過函數(shù)IOWR(OUT_PIO_BASE,0,0x00)控制接收模塊何時停止接收,一幀圖像發(fā)送完畢,再通過函數(shù)IOWR(OUT_PI-O_BASE,0,0x01)控制接收模塊開始接收下一幀圖像,如此反復(fù)循環(huán),直到連接斷開為止。
4 上位機(jī)軟件設(shè)計(jì)
本系統(tǒng)設(shè)計(jì)的客戶端視頻顯示應(yīng)用程序是利用LabWindows/CVI軟件開發(fā),此應(yīng)用程序利用套接字編程,可以作為客戶機(jī)與服務(wù)器NiosII系統(tǒng)之間通信。
本系統(tǒng)設(shè)計(jì)的上位機(jī)的應(yīng)用程序除了顯示視頻功能外,還添加了保存和回放功能。上位機(jī)通過創(chuàng)建一個標(biāo)準(zhǔn)的Socket接口完成連接以及接收數(shù)據(jù);當(dāng)接收完一幀數(shù)據(jù)后,對其進(jìn)行數(shù)據(jù)處理,再調(diào)用函數(shù)CreateDIBitmap()創(chuàng)建一幅位圖,最后再調(diào)用函數(shù)CanvasDrawBitmap()完整顯示。
5 結(jié)束語
本系統(tǒng)設(shè)計(jì)是基于NiosII IP攝像頭的系統(tǒng),介紹了從SOPC Builder創(chuàng)建NiosII軟核處理器、IDE建立底層軟件平臺,到設(shè)計(jì)NioslI應(yīng)用軟件的整個架構(gòu)。同時,對上位機(jī)的應(yīng)用程序做了說明。經(jīng)過硬件測試,整個系統(tǒng)運(yùn)行良好,實(shí)時性能良好。