0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

基于S3C2410和AT2042芯片實(shí)現(xiàn)視頻服務(wù)器的應(yīng)用設(shè)計

電子設(shè)計 ? 來源:單片機(jī)與嵌入式系統(tǒng)應(yīng)用 ? 作者:張石 , 趙百超 , 王 ? 2020-08-12 09:39 ? 次閱讀

系統(tǒng)總體設(shè)計

硬件部分以三星公司ARM9芯片S3C2410和韓國的專用視頻芯片AT2042為核心。S3C2410主要實(shí)現(xiàn)系統(tǒng)控制功能,例如對AT2042的配置,接收視頻流數(shù)據(jù)并利用USB存儲設(shè)備進(jìn)行存儲;配置網(wǎng)絡(luò)接口建立起完善的網(wǎng)絡(luò)功能,以方便用戶通過Internet對其進(jìn)行遠(yuǎn)程訪問與控制;同時,掛載U盤或硬盤,預(yù)留U口或IDE的接口,可供用戶選擇,實(shí)現(xiàn)本地的海量存儲功能。

整個系統(tǒng)軟件部分主要分為兩部分:服務(wù)器端和客戶端(C/S模式)。服務(wù)器端包括Bootloader的編寫,Linux操作系統(tǒng)內(nèi)核的生成,系統(tǒng)文件的配置以及用戶應(yīng)用軟件(實(shí)時視頻傳輸、錄像、遠(yuǎn)程回放、抓拍);客戶端是通過輸入IP地址訪問指定的服務(wù)器,這時客戶端會通過網(wǎng)絡(luò)從服務(wù)器端下載并安裝預(yù)先設(shè)計的ActiveX控件,用戶可以通過這個控件實(shí)現(xiàn)實(shí)時監(jiān)控、視頻回放、圖像抓拍等功能。系統(tǒng)總體框圖如圖1所示。

基于S3C2410和AT2042芯片實(shí)現(xiàn)視頻服務(wù)器的應(yīng)用設(shè)計

2 系統(tǒng)硬件設(shè)計

硬件系統(tǒng)主要由視頻編解碼部分、網(wǎng)絡(luò)傳輸部分、本地存儲部分、其他外設(shè)和接口部分組成,如圖2所示。包括S3C2410和AT2042、NAND Flash和SDRAM、數(shù)/模轉(zhuǎn)換芯片TVP5150和模/數(shù)轉(zhuǎn)換芯片SAA7112以及網(wǎng)卡芯片LAN91C11。接口包括USB接口、IDE接口、網(wǎng)卡接口、電源接口等。

2.1 視頻編解碼部分

視頻編解碼電路主要包括模/數(shù)轉(zhuǎn)換電路和視頻壓縮/解壓芯片AT2042。其中,AT2042主要負(fù)責(zé)對經(jīng)模/數(shù)轉(zhuǎn)換芯片TVP5150轉(zhuǎn)換來的數(shù)字視頻數(shù)據(jù)進(jìn)行硬件壓縮。壓縮編碼過程中,攝像頭采集的模擬視頻信號先經(jīng)過TVP5150進(jìn)行前端處理,產(chǎn)生符合AT2042視頻接口標(biāo)準(zhǔn)的數(shù)字視頻信號。在S3C2410的控制下,該數(shù)字視頻數(shù)據(jù)由壓縮/解壓芯片AT2042進(jìn)行硬件壓縮編碼,產(chǎn)生的編碼數(shù)據(jù)流通過芯片內(nèi)部集成的Mux FIFO接口輸出。網(wǎng)絡(luò)視頻服務(wù)器的解壓縮編碼是壓縮編碼的逆過程,需要解壓的數(shù)據(jù)流通過AT2042內(nèi)部集成的Demux FIFO接口輸入,解壓縮編碼電路基本原理類似于壓縮編碼,這里不再贅述。視頻編碼電路框圖如圖3所示。TVP5150是TI公司生產(chǎn)的一款電視信號解碼專用芯片。它對輸入的模擬信號進(jìn)行A/D轉(zhuǎn)換,TVP5105支持NTSC/PAL/SECAM三種制式,實(shí)現(xiàn)模擬視頻信號轉(zhuǎn)換為數(shù)字并行信號ITU-R BT.601或ITU-RBT.656碼流格式。由于AT2042視頻接口滿足ITU.RBT656標(biāo)準(zhǔn),故TVP5150輸出配置為8位的YUV422格式。

解碼芯片TVP5150的AIPIA模擬信號輸入口與攝像頭的信號輸出端相連,并向壓縮編碼芯片AT2042傳送視頻信號。由于TVP5150分場同步脈沖和行同步脈沖,分別對應(yīng)的輸出端為VSYNC和HSYNC,AT2042根據(jù)與之相連的VSYNCIN和HSYNCIN信號線來實(shí)現(xiàn)圖像的場同步和行同步操作;AT2042的視頻信號輸入數(shù)據(jù)線VIN[7:0]與TVP5150的輸出端YOUT[7:0]相連。AT2042將接收到的數(shù)據(jù)流傳送到壓縮編碼單元,壓縮編碼后的視頻數(shù)據(jù)存儲到外部SDRAM中,同時通過片內(nèi)的SDRAM控制器來實(shí)現(xiàn)對SDRAM的訪問,并將數(shù)據(jù)流通過HPI總線發(fā)送到S3C2410以便通過網(wǎng)絡(luò)傳輸?shù)絇C監(jiān)控端,用于實(shí)現(xiàn)遠(yuǎn)程的實(shí)時監(jiān)控。[page]

2.2 網(wǎng)絡(luò)傳輸部分

主控制芯片S3C2410通過地址、數(shù)據(jù)、控制線以及片選信號線對網(wǎng)絡(luò)芯片LAN91C11進(jìn)行控制和通信。主芯片發(fā)送信號時首先置發(fā)送使能信號,數(shù)據(jù)發(fā)送信號端TXD0~TXD1與LAN91C11的TXD0~TXD1引腳連接,作為數(shù)據(jù)的發(fā)送通道以S3C2410的時鐘信號TCK發(fā)送數(shù)據(jù)。數(shù)據(jù)接收端RXD0~RXD1與LAN91C11的RXD0~RXD1引腳對應(yīng)連接,為數(shù)據(jù)接收通道。

LAN91C11由S3C2410選通信號線AEN來選通,通過對LAN91C11一系列寄存器的設(shè)置,可以實(shí)現(xiàn)視頻流的網(wǎng)絡(luò)傳輸。LAN91C11的INTRQ0端用來產(chǎn)生中斷信號。以太網(wǎng)控制芯片通過DMA通道進(jìn)行數(shù)據(jù)的傳輸。首先設(shè)置好傳輸控制和傳輸?shù)刂芳拇嫫鞯?a target="_blank">參數(shù),依次從指定的數(shù)據(jù)存儲區(qū)域讀取數(shù)據(jù),送入內(nèi)部發(fā)送緩沖器中,用MAC對數(shù)據(jù)進(jìn)行封裝發(fā)送,并同時記錄已發(fā)送完的字節(jié)數(shù),等到整個數(shù)據(jù)塊發(fā)送完畢。一組數(shù)據(jù)發(fā)送完后請求DMA中斷,由S3C2410進(jìn)行處理。網(wǎng)絡(luò)接口框圖如圖4所示。

2.3 本地存儲部分

存儲接口選用S3C2410自身的LJSB接口功能,該接口可以實(shí)現(xiàn)USB1.1協(xié)議。隨著大容量、小體積U盤的問世,更多的用戶都選擇使用該存儲介質(zhì)。

當(dāng)今的USB技術(shù)使得各種能夠自行識別的外部設(shè)備與設(shè)備終端連接,并自行裝載驅(qū)動程序以運(yùn)行新的裝置。而一般即插即用裝置,需要有電源的USB接口進(jìn)行數(shù)據(jù)傳輸并提供電源。當(dāng)發(fā)生短路或連接了受損設(shè)備時,如受損的電纜或連接頭插入USB接口時,必須對USB集線器及主機(jī)裝置提供有效保護(hù)。USB接口的設(shè)計電路如圖5所示。

2.4 其他外設(shè)和控制接口

其他外設(shè)包括Flash、SDRAM、以太網(wǎng)接口、串行通信接口RS232。其中,F(xiàn)lash用于存儲操作系統(tǒng)內(nèi)核和系統(tǒng)軟件,待系統(tǒng)上電后加載到內(nèi)存中;以太網(wǎng)接口將壓縮編碼后的音視頻數(shù)據(jù)傳輸?shù)骄W(wǎng)絡(luò);RS232接口主要用于基于控制臺的配置和管理。另外,在調(diào)試過程中,RS232和以太網(wǎng)接口用于連接宿主機(jī)和目標(biāo)系統(tǒng)平臺,方便了網(wǎng)絡(luò)視頻服務(wù)器系統(tǒng)的開發(fā)和調(diào)試。

3 系統(tǒng)軟件設(shè)計

整個嵌入式系統(tǒng)的軟件部分由4部分組成:Boot-loader代碼、Linux操作系統(tǒng)的內(nèi)核生成和Linux下驅(qū)動程序及應(yīng)用程序的開發(fā)、文件系統(tǒng)的生成和配置以及用戶應(yīng)用程序。設(shè)備驅(qū)動模塊向上層軟件提供一致的接口,主要包括硬件的初始化、總線內(nèi)存地址映射、內(nèi)存分配等,分別被存儲在NAND Flash的4個分區(qū)模塊中。本設(shè)計采用的是較節(jié)省空間的CRAMFS只讀文件系統(tǒng)。

3.1 MPEG-4壓縮編碼的實(shí)現(xiàn)

AT2042支持MPEG-1、MPEG-2、MPEG-4、H.263和Motion-JPEG等多種視頻壓縮標(biāo)準(zhǔn),以及ADPCM、MPEG-1 Layer-II和Lyer-III(MP3)等音頻壓縮標(biāo)準(zhǔn)。這些功能是通過配置相應(yīng)的編碼寄存器實(shí)現(xiàn)的,例如編碼模式、編碼像素點(diǎn)、編碼幀率及設(shè)置編碼流格式(PES、PS、TS)等等。本系統(tǒng)中采用MPEG-4模式、720X576、每秒25幀及生成PES流來對視頻數(shù)據(jù)進(jìn)行編碼。

MPEG-4壓縮編碼部分完成對AT2042和TVP5150相關(guān)寄存器的配置,保證了MPEG-4數(shù)據(jù)流的正常輸出。系統(tǒng)啟動后,首先配置AT2042的寄存器,初始化完成后,通過I2C總線對TVP5150進(jìn)行初始化配置。在壓縮編碼過程中,MPEG-4數(shù)據(jù)流接收存儲程序由AT2042的數(shù)據(jù)流緩沖器標(biāo)志信號來進(jìn)行控制。當(dāng)緩沖器滿時,RISC_INT0置低,主控制器通過DMA通道把從AT2042的網(wǎng)卡接口接收過來的碼流通過網(wǎng)絡(luò)通道傳輸?shù)絇C端。其壓縮編碼模塊程序流程如圖6所示。

[page]

3.2 遠(yuǎn)程網(wǎng)絡(luò)程序模塊

網(wǎng)絡(luò)控制模塊是外部擴(kuò)展應(yīng)用程序與視頻服務(wù)器交互的一個模塊。其工作過程是:在監(jiān)控終端的IE瀏覽器中輸入網(wǎng)絡(luò)視頻服務(wù)器的IP地址,嵌入式網(wǎng)絡(luò)視頻服務(wù)器根據(jù)請求,將相應(yīng)的控制頁面(即ActiveX控件)反饋給IE瀏覽器,用戶下載控件后,根據(jù)控件上的指令,進(jìn)行相應(yīng)的操作,然后提交。該模塊提取操作的信息,根據(jù)不同信息通過socket套接口與服務(wù)器進(jìn)行通信來分別處理相應(yīng)的事件,如調(diào)節(jié)MPEG-4相關(guān)屬性、攝像頭的相關(guān)操作等。該網(wǎng)絡(luò)控制模塊的設(shè)計主要包括3部分:本地嵌入式web服務(wù)器的配置、ActiveX控件的編寫、socket套接字實(shí)現(xiàn)服務(wù)器與監(jiān)控端通信。遠(yuǎn)程網(wǎng)絡(luò)程序模塊框圖如圖7所示。

3.3 本地存儲部分的實(shí)現(xiàn)

該部分主要實(shí)現(xiàn)的三大功能:U盤空間的監(jiān)測,以系統(tǒng)時間來命名存儲文件并將文件保存到U盤上,實(shí)現(xiàn)MPEG-4編碼。視頻編碼存儲主要是利用Linux系統(tǒng)指令、AT2042芯片的視頻編碼功能和自動生成傳輸流功能。

(1)顯示U盤存儲空間

首先,利用Linux系統(tǒng)指令與C語言的接口函數(shù)sys-tem(const char*string),執(zhí)行指令會把U盤空間的容量、可用空間等信息寫入設(shè)定目錄下,然后利用display_string(char*string)函數(shù)將該信息顯示在顯示層面上。這樣可以使用戶很清楚地了解到可用存儲空間的大小。

(2)以系統(tǒng)時間命名文件名

調(diào)用系統(tǒng)函數(shù)time、localtime,這里需要定義相應(yīng)的結(jié)構(gòu)體tm來獲取系統(tǒng)時間,然后將這些信息與建立文件的路徑保存在同一個字符串,調(diào)用fopen(const char*path,const char*mode)函數(shù)。這樣就實(shí)現(xiàn)了以系統(tǒng)時間來命名文件名,可以方便用戶按時間來查看文件。

3.4 運(yùn)動圖像監(jiān)測的實(shí)現(xiàn)

該視頻監(jiān)控系統(tǒng)配置AT2042的相關(guān)寄存器,可實(shí)現(xiàn)運(yùn)動檢測的功能。通過運(yùn)動檢測來控制視頻數(shù)據(jù)的存儲和報警。運(yùn)動檢測(報警)算法可以控制存儲動作,節(jié)省存儲空間。例如,開始無運(yùn)動報警信號,存儲模塊處于等待狀態(tài);運(yùn)動報警信號到來,啟動存儲模塊,在一定時間內(nèi)如果沒有繼續(xù)收到運(yùn)動報警信號,存儲模塊自動停止工作。這樣存儲量比連續(xù)存盤少得多,大量無運(yùn)動的視頻被剪截掉了,大大提高了存盤效率,有效地節(jié)省了存儲空間。工作過程是這樣的:預(yù)先進(jìn)行檢測區(qū)域設(shè)定,從攝像機(jī)來的視頻信號一方面進(jìn)行視頻壓縮,壓縮的碼流輸出到緩沖區(qū)中;另一方面進(jìn)行運(yùn)動檢測,當(dāng)運(yùn)動條件滿足時發(fā)出報警信號,存儲設(shè)備開始工作。存儲設(shè)備一接到啟動信號就將緩沖區(qū)的壓縮碼流全部保存下來,接著連續(xù)存儲視頻壓縮輸出的碼流,直到存儲控制指示停止存盤為止。運(yùn)動方向的估計可以實(shí)現(xiàn)監(jiān)控系統(tǒng)中的警戒線報警功能。在圖像畫面上設(shè)定警戒線以及方向,相應(yīng)地產(chǎn)生一個預(yù)警區(qū)域。圍繞邊界線產(chǎn)生邊界區(qū)域或邊緣點(diǎn)集,監(jiān)測是否有運(yùn)動越過警戒線進(jìn)入警戒區(qū)。

結(jié) 語

本視頻服務(wù)器既有視頻遠(yuǎn)程實(shí)時傳輸,又具有本地存儲的功能,再配置AT2042實(shí)現(xiàn)多種視頻格式的編碼和運(yùn)動檢測、報警功能,使用起來方便易行,可以得到廣泛的應(yīng)用。該視頻服務(wù)器集成普通攝像機(jī)和網(wǎng)絡(luò)轉(zhuǎn)換器,將圖像轉(zhuǎn)換為基于TCP/IP網(wǎng)絡(luò)標(biāo)準(zhǔn)的數(shù)據(jù)包,使攝像機(jī)所攝的畫面通過RJ-45以太網(wǎng)接口直接傳送到網(wǎng)絡(luò)上,通過網(wǎng)絡(luò)即可遠(yuǎn)程監(jiān)視畫面。該視頻服務(wù)器采用了最先進(jìn)的攝像技術(shù)和網(wǎng)絡(luò)技術(shù),具有強(qiáng)大的功能。內(nèi)置的系統(tǒng)軟件能實(shí)現(xiàn)真正的即插即用,使用戶免去了復(fù)雜的網(wǎng)絡(luò)配置;內(nèi)置的大容量內(nèi)存能存儲警報觸發(fā)前的圖像;內(nèi)置的I/O端口和通信口便于擴(kuò)充外部周邊設(shè)備,如門禁系統(tǒng)、紅外線感應(yīng)裝置、全方位云臺。

責(zé)任編輯:gt

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 芯片
    +關(guān)注

    關(guān)注

    455

    文章

    50851

    瀏覽量

    423984
  • 三星電子
    +關(guān)注

    關(guān)注

    34

    文章

    15863

    瀏覽量

    181028
  • 服務(wù)器
    +關(guān)注

    關(guān)注

    12

    文章

    9184

    瀏覽量

    85489
收藏 人收藏

    評論

    相關(guān)推薦

    基于S3C2410AT2042芯片實(shí)現(xiàn)服務(wù)器的遠(yuǎn)程監(jiān)控系統(tǒng)的設(shè)計

    硬件部分以三星公司的ARM9芯片S3C2410和韓國的專用視頻芯片AT2042為核心。S3C2410
    的頭像 發(fā)表于 10-19 10:06 ?3820次閱讀
    基于<b class='flag-5'>S3C2410</b>和<b class='flag-5'>AT2042</b><b class='flag-5'>芯片</b><b class='flag-5'>實(shí)現(xiàn)</b><b class='flag-5'>服務(wù)器</b>的遠(yuǎn)程監(jiān)控系統(tǒng)的設(shè)計

    基于S3C2410AT2042芯片設(shè)計的遠(yuǎn)程監(jiān)控功能的視頻服務(wù)器

    視頻服務(wù)器既有視頻遠(yuǎn)程實(shí)時傳輸,又具有本地存儲的功能,再配置AT2042實(shí)現(xiàn)多種視頻格式的編碼
    發(fā)表于 11-26 07:21

    斯道s3c2410

    斯道s3c2410
    發(fā)表于 03-25 11:52 ?21次下載

    s3c2410 pdf datasheet 下載

    s3c2410 pd
    發(fā)表于 07-21 14:12 ?430次下載

    s3c2410開發(fā)板原理圖,s3c2410原理圖pcb

    s3c2410
    發(fā)表于 09-09 15:41 ?954次下載
    <b class='flag-5'>s3c2410</b>開發(fā)板原理圖,<b class='flag-5'>s3c2410</b>原理圖pcb

    s3c2410 datasheet

    s3c2410 da
    發(fā)表于 03-14 16:05 ?166次下載

    基于S3C2410的Linux移植代碼

    基于S3C2410的Linux移植代碼
    發(fā)表于 03-28 09:50 ?32次下載

    基于S3C2410的嵌入式串口通信設(shè)計

    本文通過基于S3C2410的嵌入式串口通信的實(shí)現(xiàn),按照嵌入式系統(tǒng)的軟、硬件結(jié)構(gòu)組成,較為詳細(xì)地介紹了串行通信的硬件電路和軟件實(shí)現(xiàn)方法。該系統(tǒng)的硬件主體設(shè)計以三星S3C2410
    發(fā)表于 12-23 16:11 ?120次下載

    S3C2410 LCD控制的外部管腳圖和內(nèi)部方框圖

    S3C2410管腳S3C2410 LCD控制器用于傳輸視頻數(shù)據(jù)和產(chǎn)生必要的控制信號,像VFRAME、VLINE、VCLK、VM等等。除了控制信號,
    發(fā)表于 09-10 23:28 ?2855次閱讀
    <b class='flag-5'>S3C2410</b> LCD控制<b class='flag-5'>器</b>的外部管腳圖和內(nèi)部方框圖

    基于S3C2410的RTC模塊應(yīng)用設(shè)計

    基于S3C2410的RTC模塊應(yīng)用設(shè)計 摘 要:本文簡要介紹了S3C2410嵌入式微處理,分析了RTC(Real-time clock)硬件構(gòu)架及其工作
    發(fā)表于 04-08 23:13 ?1610次閱讀
    基于<b class='flag-5'>S3C2410</b>的RTC模塊應(yīng)用設(shè)計

    基于AT2042的網(wǎng)絡(luò)視頻服務(wù)器設(shè)計

    詳細(xì)介紹了Pentamicro 公司的2通道A/V 編解碼AT2042的功能結(jié)構(gòu)、主要特點(diǎn)和通信接口的基礎(chǔ)上,提出了一種基于AT2042的網(wǎng)絡(luò)視頻
    發(fā)表于 05-17 15:42 ?29次下載
    基于<b class='flag-5'>AT2042</b>的網(wǎng)絡(luò)<b class='flag-5'>視頻</b><b class='flag-5'>服務(wù)器</b>設(shè)計

    視頻編解碼AT2042的linux設(shè)備驅(qū)動程序設(shè)計

    論文在分析各種多媒體壓縮標(biāo)準(zhǔn)的基礎(chǔ)上,詳細(xì)介紹了Pentamicro 公司的2 通道A/V 編解碼AT2042 的功能結(jié)構(gòu)和主要特點(diǎn),提出了一種基于AT2042 芯片的網(wǎng)絡(luò)
    發(fā)表于 11-07 15:10 ?36次下載
    音<b class='flag-5'>視頻</b>編解碼<b class='flag-5'>器</b><b class='flag-5'>AT2042</b>的linux設(shè)備驅(qū)動程序設(shè)計

    基于S3C2410的CAN總線通信設(shè)計與開發(fā)

    ARM芯片S3C2410沒有集成控制,為保障通訊穩(wěn)定與效率,采用帶SPI接口的獨(dú)立CAN控制MCP2515來給S3C2410擴(kuò)展CAN接
    發(fā)表于 03-01 10:45 ?2789次閱讀
    基于<b class='flag-5'>S3C2410</b>的CAN總線通信設(shè)計與開發(fā)

    基于S3C2410和Windows CEnet的智能移動終端設(shè)計

    本文介紹 S3C2410 微處理的性能以及 Windows CE. net 作為嵌入式操作系統(tǒng)的開發(fā)流程 。闡述基于 S3C2410芯片和 Windows CE. net 操作平臺設(shè)
    發(fā)表于 04-18 10:46 ?0次下載

    基于S3C2410的開發(fā)原理圖

    基于S3C2410的開發(fā)原理圖免費(fèi)下載。
    發(fā)表于 07-08 14:56 ?66次下載