<meter id="pryje"><nav id="pryje"><delect id="pryje"></delect></nav></meter>
          <label id="pryje"></label>

          關(guān) 閉

          新聞中心

          EEPW首頁 > 工控自動化 > 設(shè)計應(yīng)用 > 一種音視頻監(jiān)視系統(tǒng)的設(shè)計和實現(xiàn)

          一種音視頻監(jiān)視系統(tǒng)的設(shè)計和實現(xiàn)

          作者: 時間:2012-08-08 來源:網(wǎng)絡(luò) 收藏

          FPGA的選擇

          FPGA(Field-Programmable Gate Array),即現(xiàn)場可編程門陣列,它是在PAL、GAL、CPLD等可編程器件的基礎(chǔ)上進(jìn)一步發(fā)展的產(chǎn)物。它是作為專用集成電路(ASIC)領(lǐng)域中的一種半定制電路而出現(xiàn)的,既解決了定制電路的不足,又克服了原有可編程器件門電路數(shù)有限的缺點。

          我們根據(jù)幾個因素進(jìn)行選擇。器件需要滿足預(yù)計的I/O要求,并且必須具有相應(yīng)數(shù)量的邏輯單元、適宜的Block RAM尺寸以及一定數(shù)量的時鐘緩沖器和時鐘管理器件,如鎖相環(huán)(PLL)、數(shù)字時鐘管理(DcM)模塊和乘累加模塊。基于這些需求,我們選擇了 Virtex-5 XCVSX95T-FF1136.

          時鐘要求分析

          選擇FPGA之后,我們開始過程,即分析時鐘控制要求,然后將信號映射到I/O組或I/O引腳。

          對于時鐘要求分析,重要的是考慮以下幾個因素:FPGA是否具有足夠的時鐘功能I/O線和全局時鐘I/O線?是否有足夠的PLL、DCM和全局時鐘緩沖器?全局時鐘I/O緩沖器是否支持所要求的最高頻率?

          的時鐘控制要求包括:一個以150MHz-200MHz頻率運(yùn)行的全局時鐘,具有若干PLL供所有內(nèi)部邏輯用來進(jìn)行處理;一個以 250MHz頻率運(yùn)行的全局時鐘,具有PLL/DCM的PCI Express鏈接;一個以250MHz頻率運(yùn)行的全局時鐘緩沖器(帶有PLL和DCM)用于以太網(wǎng)MAC;以及一個200MHz的時鐘(由 PLL/DCM生成),用于I/O模塊中的逐位去歪斜等。

          我們總共需要4~6個全局時鐘緩沖器和16個局部時鐘緩沖器。FPGA XCVSX95T-FF1136提供每組20個全局時鐘輸入引腳和4個時鐘功能I/O.也可將I/O組的時鐘功能引腳直接連接到區(qū)域緩沖器或I/O緩沖器,并且將其用于特定區(qū)域或相鄰區(qū)域。另外,各GTP/MGT還有一個參考時鐘輸入引腳。

          初始布局規(guī)劃

          Virtex-5 FPGA共有18個I/O組,可以將各種輸入/輸出對映射到這些I/O組。有幾個I/O組支持20對輸入/輸出或10個全局時鐘。其他I/O組則大多支持 40對輸入/輸出,每對輸入/輸出上有4個輸入時鐘功能引腳和8個輸出時鐘功能引腳。

          同時,上下兩牛個FPGA包括三個時鐘控制模塊(CMT),即一個PLL和兩個DCM.對于需要上下兩半個器件中的PLL的所有全局時鐘信號,我們必須確保予以妥善映射,以使具有從全局時鐘輸入緩沖器到PLL的直接連接。然后我們使用剩下的14個I/O組,這些組支持40條I/O線,是單端/差分模式。每個組由4個單端時鐘功能引腳和8個差分時鐘功能引腳組成。接下來可以將時鐘功能引腳映射或連接到區(qū)域時鐘緩沖器或I/O時鐘緩沖器。

          一般情況下,可以使用這些時鐘功能引腳和區(qū)域緩沖器來映射源同步時鐘輸入。區(qū)域緩沖器具有較低歪斜度,可以訪問三個區(qū)域(一個區(qū)域緩沖器所在的區(qū)域,以及其上和其下各一個區(qū)域)。但對于源同步數(shù)據(jù)的組選擇,我們傾向于只使用一個I/O組。如果需要其他IIO,則最好將I/O組用于已事先映射到相鄰組的數(shù)據(jù)信號。

          設(shè)計的初始布局規(guī)劃按照幾個步驟進(jìn)行。首先將時鐘放在上半部,然后將自動采集(可選)時鐘放在下半部。我們鎖定了每半部分的CMT,以滿足 I/O組的3/4要求。這樣映射能確保每半部分都留有兩個PLL/DCM(CMT)可用于PCI Express和千兆位以太網(wǎng)的MAC(SGMII)功能。

          再把同步數(shù)據(jù)映射到含有區(qū)域時鐘的組,所以把10個信道輸入映射到剩下的I/O組。每條視頻信道由20條數(shù)據(jù)線、3個控制信號和3個視頻時鐘輸入組成。同時,每條音頻信道由4個數(shù)據(jù)信號、3個控制信號和1個音頻時鐘信號組成。這樣就滿足了32個信號至少使用兩個時鐘功能引腳的要求。

          對于本設(shè)計,10個信道使用10個I/O組。我們將視頻時鐘和音頻時鐘映射到了時鐘功能引腳,以確保有效使用區(qū)域時鐘緩沖器和I/O時鐘緩沖器。根據(jù)PCB的要求,我們?yōu)?a class="contentlabel" href="http://www.ex-cimer.com/news/listbylabel/label/音視頻">音視頻信道選擇了第5、 6、 13、 17、 18、 19、 20、 22和25組。

          對于DDR存儲器,設(shè)計支持1條32位的數(shù)據(jù)總線、14條地址線和若干條控制線。我們需要85~90個信號來映射DDR存儲器接口。根據(jù)PCB的布局,我們使用了I/O組11、23和15來映射DDR的全部I/0信號。由于DDR存儲器按照時鐘工作,所以我們選擇將DDR生成的讀數(shù)據(jù)DQS信號映射到具有時鐘功能的I/O線。

          核生成與IP集成

          Virtex-5支持可以用CORE Generator工具生成的時鐘控制模塊的各種配置。其中包括若干濾波器時鐘抖動PLL、一個具有濾波器時鐘抖動功能的PLL-DCM對、一個具有輸出雙倍數(shù)據(jù)速率(ODDR)的PLL-DCM對或DCM、一個標(biāo)準(zhǔn)型相移時鐘DCM和若干動態(tài)時鐘切換PLL.

          要生成PLL,首先需要了解輸入是單端的還是差分的。然后,必須確定時鐘抖動是否適宜,以及是否使用了全局緩沖器來緩沖所有輸出。

          為了使用ODDR觸發(fā)器在源同步輸出中驅(qū)動時鐘,我們了一個DCM,用于驅(qū)動ODDR觸發(fā)器來隨路時鐘控制。此DCM與我們用來進(jìn)行內(nèi)部時鐘控制的DCM并行運(yùn)行。

          在生成PCIExpress核時,我們必須確保參考時鐘具有與PC主板上的PCIExpress插槽輸出相同的性能(即100MHz)。另外,我們還需要確定該核需要多少基址寄存器(BAR),以及BAR是存儲器映射還是I/O映射。我們?yōu)榈刂方獯a使用了BAR器,這可以幫助生成BAR命中點。

          在設(shè)計PCIExpress與系統(tǒng)局部總線之間的橋接器時,我們使用了BAR來訪問存儲器映射或I/O映射的寄存器或BlockRAM,確保該核及總線能正確訪問所有寄存器或BlockRAM.

          如果上述任何點未命中,則主機(jī)PC在嘗試傳遞和執(zhí)行讀事務(wù)時就不會得到任何響應(yīng)。主機(jī)PC會進(jìn)入未知的狀態(tài),或者產(chǎn)生無法恢復(fù)的錯誤。

          IP是英文Internet Protocol(網(wǎng)絡(luò)之間互連的協(xié)議)的縮寫,中文簡稱為網(wǎng)協(xié),也就是為計算機(jī)網(wǎng)絡(luò)相互連接進(jìn)行通信而設(shè)計的協(xié)議。在因特網(wǎng)中,它是能使連接到網(wǎng)上的所有計算機(jī)網(wǎng)絡(luò)相互通信的一套規(guī)則,規(guī)定了計算機(jī)在因特網(wǎng)上進(jìn)行通信時應(yīng)當(dāng)遵守的規(guī)則。任何廠家生產(chǎn)的計算機(jī)系統(tǒng),只要遵守 IP協(xié)議就可以與因特網(wǎng)互連互通。IP地址具有唯一性,根據(jù)用戶性質(zhì)的不同,可以分為5類。另外,IP還有進(jìn)入防護(hù),知識產(chǎn)權(quán),指針寄存器等含義。

          對于IP集成,必須為各FPGA分別使用一個時鐘復(fù)位模塊。異步復(fù)位必須與每個時鐘都同步,無論是全局時鐘還是區(qū)域時鐘。就內(nèi)部而言,復(fù)位信號是相對于特定的時鐘而異步有效置位和同步無效置位,而其輸出則施加到各時鐘所屬的特定模塊。需要確保已經(jīng)將所有全局輸入時鐘連接到用CoreGen生成的 PLL/DCM核。

          將區(qū)域時鐘連接到BUFR/BUFIO.另外,為了避免布局布線工具使用不必要的布線資源,只能僅生成必要的復(fù)位信號。需要確保將PLL/DCM的鎖存條件傳送給外部引腳或配置寄存器。示例中,我們僅將200MHz系統(tǒng)時鐘的PLL鎖存器連接到了I/O引腳。

          因為我們是在用高速源同步輸入和輸出進(jìn)行設(shè)計,所以Virtex-5的逐位去歪斜功能幫助我們在輸入和輸出級滿足建立和保持要求,逐位去歪斜功能內(nèi)置于所有I/O模塊(10DELAY基元)。對于源同步輸入,源同步時鐘使用BUFIO或BUFR, 因此會引入附加延遲。為了補(bǔ)償此延遲,我們通過一個IODELAY實例來驅(qū)動數(shù)據(jù)和時鐘輸入,該實例是按照具有已知延遲計數(shù)的輸入延遲模式配置的。我們通過修改延遲計數(shù)值來幫助滿足輸入級的時序要求。

          輸出級的情況與此相似。因為同步時鐘信號是隨數(shù)據(jù)傳送,我們需要確保數(shù)據(jù)和時鐘信號的傳送方式能滿足FPGA或ASIC在另一端的建立和保持要求。對于時鐘和數(shù)據(jù)輸出,我們都使用了按照具有已知延遲計數(shù)值的輸出延遲模式配置的IODELAY實例。



          評論


          相關(guān)推薦

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

          關(guān)閉
          看屁屁www成人影院,亚洲人妻成人图片,亚洲精品成人午夜在线,日韩在线 欧美成人 (function(){ var bp = document.createElement('script'); var curProtocol = window.location.protocol.split(':')[0]; if (curProtocol === 'https') { bp.src = 'https://zz.bdstatic.com/linksubmit/push.js'; } else { bp.src = 'http://push.zhanzhang.baidu.com/push.js'; } var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(bp, s); })();