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

          新聞中心

          EEPW首頁 > 嵌入式系統 > 牛人業(yè)話 > 零基礎學FPGA(四)Verilog語法基基礎基礎(中)

          零基礎學FPGA(四)Verilog語法基基礎基礎(中)

          作者: 時間:2014-12-31 來源:網絡 收藏

            4、循環(huán)語句

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

            語法**有4中循環(huán)語句,這里只簡單說一下C語言里沒有的兩種

            (1) forever語句

            連續(xù)執(zhí)行語句,這種語句主要用在產生周期性的波形,用來做仿真信號。個人理解和always語句差不多的功能,但是,forever語句只能用在initial塊中。

            (2)repeat 語句后面接常量表達式,可以指定循環(huán)次數,例如;

            repeat (8)

            begin

            …

            end

            表示循環(huán)8次相應語句。

            5、順序塊和并行塊

            所謂順序塊就是前面說的begin…end,他的作用就是把多條語句組合到一起執(zhí)行,在順序塊里面,語句是一條一條順序執(zhí)行的,如果遇到#10延遲語句,延遲也是相對于上一條語句的延遲,這一點比較重要。

            相對于順序塊的就是并行塊,用fork…end語句表示,并行塊里的語句是同時執(zhí)行的。

            順序塊和并行塊可以嵌套使用。

            如果在begin或者fork語句后面加上名字,這個塊語句就成了命名塊,例如

            begin :xiaomo

            ……

            end

            命名塊有什么好處呢?有了命名塊,我們就可以用verilog提供的disable語句來隨時終止命名塊,例如disable xiaomo;這樣,當程序運行到此時,就會禁用命名塊,就會直接跳出塊語句,相當于C語言里面的break語句一樣,看下面這個例子:

            

          360桌面截圖20140308132040.jpg

           

            6、生成塊

            生成塊語句可以動態(tài)的生成代碼,這一聲明語句方面了參數化模塊的生成。黨對矢量中的多個位進行重復操作時,或者進行多個模塊的實力引用時,或者在根據參數的定義來確定程序中是否應該包括末端代碼的時候,使用生成語句能夠大大簡化程序的編寫過程。

            生成語句可以控制變量的聲明、任務或函數的調用,還能對實力引用進行全面的控制。編寫代碼時必須在模塊中說明生成塊的實例范圍,關鍵字 generate…endgenerate用來指定該范圍。

            Verilog中有三種生成語句的方法,分別是循環(huán)生成,條件生成和case生成。

            (1)循環(huán)生成

            

          360桌面截圖20140308142337.jpg

           

            

          360桌面截圖20140308142446.jpg

           

            注:genvar 是關鍵詞,用于生成生成變量,生成變量只存在于生成塊中,在確立后的方針代碼中,生成變量是不存在的。

            xor_loop是賦予生成語句的名字,目的在于溝通它對循環(huán)生成語句之中的變量進行層次化引用。因此循環(huán)生成語句中的各個異或門的相對層次為:xor_loop[0].gl,xor_loop[1].gl…,xor_loop[31] 這句話什么意思啊

            這個例子中的 xor gl (out [ j ] , i0 [ j ], i1 [ j ] );什么意思??求大神指點

            當然這個異或門還可用always塊實現

            生成塊程序

            generate

            for (j=0;j

            begin :xiaomo

            always @(i0[ j ] or i1[ j ]) out [ j ]=i0[ j ]^i1[ j ];

            end

            endgenerate

            (2)條件生成

            

          360桌面截圖20140308145303.jpg

           

            下面是一段生成語句

            

          360桌面截圖20140308145416.jpg

           

            (3)case生成

            

          360桌面截圖20140308150117.jpg

           

            下面是一個例子使用case語句生成N位的加法器

            

          360桌面截圖20140308150759.jpg

           

            

          360桌面截圖20140308150809.jpg

           

            說實話上面這些東西我自己也是看的模模糊糊,好多地方不懂,只能先截個圖放這兒了。唉...基礎還是不行啊...

          fpga相關文章:fpga是什么


          c語言相關文章:c語言教程




          關鍵詞: FPGA Verilog

          評論


          相關推薦

          技術專區(qū)

          關閉
          看屁屁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); })();