新聞中心

EEPW首頁 > 網(wǎng)絡(luò)與存儲 > 設(shè)計應(yīng)用 > ARM在數(shù)字化遠(yuǎn)程視頻監(jiān)控系統(tǒng)的應(yīng)(05-100)

ARM在數(shù)字化遠(yuǎn)程視頻監(jiān)控系統(tǒng)的應(yīng)(05-100)

——
作者:北京郵電大學(xué)電信學(xué)院 廖日坤 紀(jì)越峰 深圳市文錦渡職業(yè)技術(shù)學(xué)校 黃小迅 時間:2009-02-20 來源:電子產(chǎn)品世界 收藏

  控制CMOS圖像采集,然后從圖像緩沖SRAM中讀取圖像數(shù)據(jù)到內(nèi)部的LCD顯示存儲區(qū),顯示到LCD屏上。這也就打通了整個數(shù)據(jù)前向通道,ARM獲取了圖像后就可以進(jìn)一步做壓縮處理和傳輸。

本文引用地址:http://m.butianyuan.cn/article/91471.htm

  ARM程序開發(fā)

  ARM視頻監(jiān)控系統(tǒng)配備512KB的FLASHROM,用于程序存儲器,所以應(yīng)用程序與原始數(shù)據(jù)的總和必須小于512KB。以下是ARM程序開發(fā)流程:

  軟件的編寫與調(diào)試

  針對應(yīng)用編寫所需的各種程序,使用ADS(ARMDeveloperSuite)建立工程文件,把編寫好的匯編程序*.s文件、C語言程序*.c文件、*.h文件加入到工程中。然后對編譯參數(shù)進(jìn)行相應(yīng)設(shè)置,編譯工程文件,編譯通過后生成可執(zhí)行二進(jìn)制代碼。使用ADW調(diào)試已編譯工程,軟件調(diào)試只能調(diào)試ARM指令,無法仿真外圍設(shè)備;調(diào)試通過后,準(zhǔn)備下載可執(zhí)行二進(jìn)制代碼,進(jìn)行硬件測試。

  程序下載的實現(xiàn)

  通過bootloader程序來實現(xiàn)對FLASH程序存儲器的編程,bootloader程序是自己編寫的基于內(nèi)啟動方式下的小程序。

  (1)首先讓EP7312以內(nèi)啟動方式運行,PC通過串口1(9600bps)接收到"<"標(biāo)志,

  (2)然后PC從串口發(fā)送2KB的bootloader程序到EP7312。

  (3)這時bootloader程序開始運行,PC通過串口1(115200bps)發(fā)送"0x79"與EP7312再次建立連接,隨后PC發(fā)送"0xFF0xFA"命令,EP7312返回"Len:",PC再發(fā)送四字節(jié)的要下載的文件長度數(shù)據(jù)。接著PC繼續(xù)發(fā)送整個要下載的程序,發(fā)送完成后將接收到"Ok!",然后編程結(jié)束后將接收到"Done!"表明下載編程操作成功完成。

  (4)此時重新以外啟動方式啟動EP7312就可以運行剛下載的程序。

  以上是以工程方式來進(jìn)行ARM應(yīng)用程序開發(fā)的基本流程,在實際使用過程中如果應(yīng)用到新器件還需要一個硬件調(diào)試階段,在硬件調(diào)試通過以后才可以進(jìn)一步開發(fā)應(yīng)用程序。

  有關(guān)硬件調(diào)試的軟件方法

  在沒有硬件開發(fā)工具的情況下,可以通過串口來進(jìn)行硬件的調(diào)試,EP7312與外圍硬件的連接基本上有三種方式:直接總線連接、與EP7312的片內(nèi)外設(shè)專用引腳連接、連接EP7312的通用I/O引腳。

  以總線方式連接的外設(shè)可以通過總線讀寫來訪問;專用外設(shè)可以通過內(nèi)部專門的控制寄存器來訪問;經(jīng)通用I/O擴(kuò)展的外設(shè)則可以通過對內(nèi)部通用I/O設(shè)置寄存器的控制來訪問。由于內(nèi)部專用寄存器都對應(yīng)固定的總線地址,所以這三種方式都可以通過ARM的總線操作對指定地址的訪問來實現(xiàn)調(diào)試。

  軟件設(shè)計

  在ARM處理器硬件復(fù)位以后,需要運行匯編啟動代碼完成系統(tǒng)初始化,主要包括:中斷向量設(shè)置、各種處理器模式下的堆棧設(shè)置、系統(tǒng)寄存器設(shè)置、SDRAM、LCD等外圍部件的設(shè)置。以下是其部分程序代碼:

  ldrr1,=DRAMControlvalue;設(shè)置SDRAM參數(shù)

  ldrr12,=rSDCONF;rSDCONF= 0x8000.2300

  strr1,[r12]

  ldrr12,=rSYSCON2

  strr0,[r12];rSYSCON2= 0x8000.1100

  ldrr1,=DRAMConfigvalue;設(shè)置SDRAM刷新速度

  ldrr12,=rSDRFPR

  strr1,[r12];rSDRFPR= 0x8000.2340

  ;------------------------------------------------

  ldrr1,=0x06;設(shè)置系統(tǒng)時鐘為74MHz

  ldrr12,=rSYSCON3

  strr1,[r12];rSYSCON3= 0x8000.2200

  ;-----------------------------------------------

  MemConfig1valueEQU0x0202023c;nCS0 = NOR FLASH, 8-bit, 0 wait states

  MemConfig2valueEQU0x0000023f;nCS4 = for , 16-bit, 0 wait states

  ldrr1,=MemConfig1value;配置存儲器位寬格式與等待狀態(tài)

  ldrr12,=rMEMCFG1

  strr1,[r12];MEMCFG1= 0x8000.0180

  ldrr1,=MemConfig2value

  ldrr12,=rMEMCFG2

  strr1,[r12];MEMCFG2= 0x8000.01c0

  ;-----------------------------------------------

  ldrsp,=SVCStack;設(shè)置堆棧

  圖2是ARM主程序流程圖。ARM處理器從獲取圖像信息,執(zhí)行壓縮程序,壓縮后的文件通過公共電話線路傳遞到監(jiān)控主機(jī)端。由于系統(tǒng)采用相同的圖像分辨率和常量表,所以文件頭都相同,為了減少傳輸數(shù)據(jù)量,不傳送文件頭,文件頭在監(jiān)控主機(jī)端由軟件自動添加。

  

 

 

  圖2 ARM主程序流程圖

  本系統(tǒng)還使用調(diào)制解調(diào)器通過公共電話網(wǎng)來建立遠(yuǎn)程數(shù)據(jù)連接,在遠(yuǎn)程圖像監(jiān)控終端處的調(diào)制解調(diào)器處于待命狀態(tài),它使用"ATS0=3&D0W&W1"命令設(shè)置為自動應(yīng)答方式,在3次振鈴后自動摘機(jī),經(jīng)歷"數(shù)據(jù)風(fēng)暴"以后與主叫方建立連接。監(jiān)控中心的調(diào)制解調(diào)器由監(jiān)控軟件控制撥號建立連接或者掛斷連接。

  數(shù)據(jù)聯(lián)接建立好ARM會接收到“CONNECT”字符串表明通訊線路連接成功,此時就可以像使用普通串口一樣使用調(diào)制解調(diào)器建立的遠(yuǎn)程數(shù)據(jù)連接。ARM接收到從監(jiān)控中心發(fā)來的采集命令后,依次完成圖像采集、壓縮處理,然后通過串口以ASC碼形式直接發(fā)送圖像數(shù)據(jù)到監(jiān)控中心,完成一次操作后等待下一個采集命令。

  結(jié)語

  本文是完全針對低設(shè)備成本、低運行成本和超遠(yuǎn)距離的圖像監(jiān)控系統(tǒng)應(yīng)用提出的解決方案,前端使用便宜的一體化高集成數(shù)字化視頻采集模塊,簡化了系統(tǒng)前端的設(shè)計,大大降低了前端成本;信號處理使用由高速、高性能的ARM處理器與芯片構(gòu)建的,通過軟件來實現(xiàn)圖像壓縮;最后經(jīng)由公共電話網(wǎng)來實現(xiàn)同城范圍內(nèi)的全數(shù)字化遠(yuǎn)程圖像監(jiān)控。在降低系統(tǒng)成本的同時,提高了系統(tǒng)的靈活性。


上一頁 1 2 下一頁

關(guān)鍵詞: ARM 嵌入式系統(tǒng) FPGA

評論


相關(guān)推薦

技術(shù)專區(qū)

關(guān)閉