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

          新聞中心

          EEPW首頁 > 設(shè)計應(yīng)用 > Tcl在Vivado中的應(yīng)用

          Tcl在Vivado中的應(yīng)用

          作者:周立娜 時間:2015-04-28 來源:電子產(chǎn)品世界 收藏

            如圖3所示,pins 在 Vivado 數(shù)據(jù)庫中有個獨特的存在形式,即 / 。 這里的“ /”不表示層次,而是其名字的一部分, 表示這個 pin 所屬的實體。 也就是說,在使用 get_pins配合-hier 來查找 pins 時,“ /”可以作為名字的一部分,出現(xiàn)在搜索條件內(nèi)(注意與上述get_ 和 get_nets 的使用區(qū)別) 。
              

          本文引用地址:http://www.ex-cimer.com/article/273292.htm

            2.2 目標(biāo)之間的關(guān)系

            Tcl 在搜索網(wǎng)表中的目標(biāo)時,除了上述根據(jù)名字條件直接搜索的方式,還可以利用目標(biāo)間的關(guān)系,使用-of_objects(在 Tcl 中可以簡寫為-of)來間接搜索特定目標(biāo)。 Vivado 中定義的五類目標(biāo)間的關(guān)系如圖4(左)圖所示。 以圖4(右)圖的設(shè)計來舉例。
              

            圖5是一個更復(fù)雜的示例,涉及跨層次搜索??梢钥吹皆?get_pins 時, 要加上-leaf才能準(zhǔn)確定位到門級元件(或 blackbox)的端口 q。另外, 在實際操作中, 使用 get_nets 和get_pins 時,需要視情況而加上其它條件( -filter) 才能準(zhǔn)確找到下述例子中的 ( i2)。

            2.3 高級查找功能

            在使用 get_*命令查找網(wǎng)表中的目標(biāo)時,除了名字這一直接條件,往往還需要輔以其它更復(fù)雜的條件判斷,這就需要用到高級查找功能: -filter 結(jié)合 Tcl 支持的各種關(guān)系和邏輯運算符( ==, !=, =~, !~, <=, >=, >, <, &&, ||)甚至是正則表達(dá)式來操作。
              

            在創(chuàng)建子程序時也常常用到-filter,例如下述 get_p 的子程序/過程就可以用來返回指定管腳的方向?qū)傩?,告訴用戶這是一個輸入管腳還是一個輸出管腳。
              

            3 Tcl 在 Vivado 中的延伸應(yīng)用

            Tcl 在 Vivado 中的應(yīng)用還遠(yuǎn)不止上述所列,其它常用的功能包括使用預(yù)先寫好的 Tcl腳本來跑設(shè)計實現(xiàn)流程,創(chuàng)建高級約束( XDC 不支持循環(huán)等高級 Tcl 語法)以及實現(xiàn)復(fù)雜的個性化設(shè)計流程等等。 Tcl 所帶來的強大的可擴展性決定了其在版本控制、 設(shè)計自動化流程等方面具有圖形化界面不能比擬的優(yōu)勢。

            Vivado 在不斷發(fā)展更新的過程中,還有很多新的功能,包括 ECO、 PR、 HD Flow 等等都是從 Tcl 腳本方式開始支持,然后再逐步放入圖形化界面中實現(xiàn)。這也解釋了為何高端 用戶和熟練的 Vivado 用戶都更偏愛 Tcl 腳本。


          上一頁 1 2 3 下一頁

          關(guān)鍵詞: Xilinx VivadoTcl FPGA cells

          評論


          相關(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); })();