新聞中心

EEPW首頁 > 嵌入式系統(tǒng) > 設計應用 > 基于DSP的嵌入式視覺客流檢測系統(tǒng)

基于DSP的嵌入式視覺客流檢測系統(tǒng)

作者: 時間:2009-05-06 來源:網(wǎng)絡 收藏

2.2 與FIFO存儲器的無縫連接與圖像采集的實現(xiàn)
FIFO與和OV7141的無縫連接如圖2所示。OV7141的工作頻率是27 MHz,每秒鐘能輸出30幀(VGA模式)或者60幀(QVGA模式)。由于性能有限,而且實際上很多情況下也不需要如此高的幀率,因此并不是所有采集到的圖像數(shù)據(jù)都需要DSP進行處理(例如在的實際應用中只要求每秒鐘能處理5幀即可),但是必須保證DSF進行處理的圖像為一幅完整的圖像??梢岳肙V7141的3個輸出信號來完成這個功能,分別是PCLK(像素時鐘信號)、VSYNC(場同步信號)和HREF(行有效信號)。并且OV7141可通過改變片內(nèi)控制寄存器的值來調(diào)整輸出圖像的窗口大小,窗口可在4×2到652×482像素之間任意選擇。HREF、只在所選擇窗口內(nèi)的像素信號輸出時才置高電平,這使得圖像的非完整模式下的處理也變?yōu)榱丝赡?。另外?V7141的片內(nèi)控制寄存器配置功能由SCCB總線實現(xiàn),由于DSP不具有SCCB總線接口,因而為了通過DSP實現(xiàn)對0V7141的寄存器配置,利用DSP的2根數(shù)據(jù)線DO和D1借助CPLD實現(xiàn)sCcB總線時鐘線SCL和數(shù)據(jù)線SDA的模擬以實現(xiàn)虛擬SCCB總線。
控制FIF0的信號主要是寫信號和讀信號,它們都由DSP根據(jù)FIF0的狀態(tài)信號及DSP對圖像的處理結果來控制對FIFO的讀/寫。讀/寫操作時序如圖3所示。CM0s圖像傳感器采集獲得的圖像數(shù)據(jù)在CPLD控制下逐行寫入FIFO,當FIFO的存儲容量達到半滿時,F(xiàn)IFO的半滿標志位以外部中斷方式通知DSP,DSP,檢測到外部中斷后開啟DMA,利用DMA通道將FIFo中的圖像數(shù)據(jù)搬移到DSP的片內(nèi)圖像緩沖區(qū)中。需要注意的是,在DMA從FIFO搬運圖像數(shù)據(jù)的過程中CMOS圖像傳感器并沒有停止向FIFO寫入圖像數(shù)據(jù),由于CMOS寫入FIFO速度Vw。比DMA從FIFO中讀出數(shù)據(jù)的速度Vr慢(Vw=(1/2)Vr),使得CMOS和DMA在對FIFO進行雙向訪問時FIFO的實際存儲容量始終保持在0和最大存儲量之間,既不會上溢也不會下溢;從而保證一幀完整的圖像可以被DMA控制器順利的轉移至DSP的片內(nèi)圖像緩沖區(qū)中。當一幀完整的圖像搬運完成后,DMA會開啟處理使能標志,當DSP發(fā)現(xiàn)處理使能標志開啟后將從片內(nèi)圖像緩沖區(qū)中獲得圖像數(shù)據(jù)以完成圖像處理算法,在DSP進行圖像處理的同時,DMA控制器可以同時進行下一幀圖像數(shù)據(jù)的搬移工作以提升系統(tǒng)的并行處理能力。DSP對于當前幀圖像處理完成后將等待處理使能標志的再次開啟以繼續(xù)下一幀圖像的處理。DSP對于當前幀圖像的處理結果將在當前幀處理完成后采用以太網(wǎng)傳輸至接收終端。


此外,DMA在執(zhí)行圖像數(shù)據(jù)搬移功能時,為了保證數(shù)據(jù)搬移過程與DSP圖像處理的并行性,通常需要在DSP片內(nèi)開辟2塊圖像數(shù)據(jù)緩沖區(qū)。由于5416DSP片內(nèi)DARAM在速度上優(yōu)于SARAM,因而通常重要的程序代碼以及算法的堆棧都放在DARAM中,為了節(jié)省DARAM資源并充分利用SARAM,在DSP程序空間所在的SARAM和數(shù)據(jù)空間所在的DARAM中各開辟1塊作為圖像數(shù)據(jù)緩沖區(qū)。SARAM中的緩沖區(qū)用于DMA通道0從FIF0中讀取當前幀圖像數(shù)據(jù),DMA通道1從SARAM緩沖區(qū)中讀取上一幀圖像數(shù)據(jù),兩個DMA通道的數(shù)據(jù)搬移功能都可以在DSP完成某個子算法的過程中并行實現(xiàn)。
2.3 TCP/IP協(xié)議的以太網(wǎng)傳輸?shù)膶崿F(xiàn)與圖像的實時傳輸
考慮到實際情況中通常采用圖像處理系統(tǒng)與接收終端采用雙絞線直連的方式傳輸圖像數(shù)據(jù),因而直接采取TCP/IP協(xié)議族中傳輸效率更高的用戶數(shù)據(jù)包協(xié)議(UDP)完成系統(tǒng)與接收終端的數(shù)據(jù)交互。接收終端可采用套接字(Socket)獲取UDP數(shù)據(jù)包,并從UDP數(shù)據(jù)包中還原出圖像數(shù)據(jù)或其他系統(tǒng)參數(shù)。而在圖像處理系統(tǒng)中,UDP數(shù)據(jù)包的發(fā)送主要通過DSP讀寫LAN9115的片內(nèi)寄存器以及FIF0的方式實現(xiàn),具體有以下幾個步驟:
(1)初始化。完成LAN9115的喚醒工作,判別其工作狀態(tài),通過讀寫指定內(nèi)部寄存器,激活他的各項功能。
(2)設置MAC地址。初始化時DSP通過更改LAN9115內(nèi)部寄存器ADDRH和ADDRL的值,完成對網(wǎng)絡MAC地址的設置。
(3)發(fā)送ARP數(shù)據(jù)包。根據(jù)UDP協(xié)議,發(fā)送數(shù)據(jù)時要獲取對方機器的IP地址和MAC地址。該程序根據(jù)ARP協(xié)議,發(fā)送ARP數(shù)據(jù),再接收圖像接收端發(fā)回的RARP數(shù)據(jù)包,分析里面的數(shù)據(jù),即可生成符合要求的UDP數(shù)據(jù)。
(4)發(fā)送圖像數(shù)據(jù)。在發(fā)送數(shù)據(jù)包(Packet)過程中,DSP先更改LAN9115的寄存器TX_CMD_A和Tx_CMD_B的值,其中包含了要發(fā)送的數(shù)據(jù)大小,數(shù)據(jù)包(Packet)長度等信息,該系統(tǒng)目前采取的圖像大小為320×240像素。在實際傳輸中,每幀圖像分20塊(1 Frame=20 Block),每塊又分6個數(shù)據(jù)報傳輸(1 Block=6 Slice),每個數(shù)據(jù)包中圖像數(shù)據(jù)為1 280 B(1 Slice=1 280 B)。這樣做是因為以太網(wǎng)協(xié)議里規(guī)定每個數(shù)據(jù)包大小不能超過1 514 B,Windows系統(tǒng)中Socket套接字的緩沖區(qū)是8 KB。然后DSP利用I/0端口訪問模式將數(shù)據(jù)依次寫入LAN9115中。要中斷當前傳輸過程,可設置寄存器TX―CFG中sTOP―Tx比特為1。這個傳輸過程就將立即結束。LAN9115與DSP的接口如圖4所示。

linux操作系統(tǒng)文章專題:linux操作系統(tǒng)詳解(linux不再難懂)


評論


相關推薦

技術專區(qū)

關閉