色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

Vivado 2023.2版本的新增功能

FPGA開源工坊 ? 來源:FPGA開源工坊 ? 2024-01-02 09:39 ? 次閱讀

Vivado在前一段時間更新了2023.2版本,經過一段時間的使用這個版本還是很絲滑的,用起來挺舒服。

特別是增加了一個Lint檢查的按鈕,可以讓我們提前知道RTL設計有什么風險。做數字IC設計的時候寫完代碼之后可能不是直接就去仿真,而是先拿Spyglass做一次檢查,消除掉lint錯誤之后再拿去仿真,Vivado增加了這個功能,讓我們能夠更好的去掌控自己的代碼。

3d482ac4-a87f-11ee-8b88-92fbcf53809c.png

這個lint檢查有什么作用呢,先來看一小段代碼。

`timescale 1ns / 1ps
module top(
    input  [7:0] a  ,
    input        b  ,
    output [7:0] c  
    );


always @(*) begin
    if(b == 1'b1)begin
        c = a;
    end
end


endmodule

沒有幾行代碼,直接一看有兩處問題,第一是c在always begin end里面進行賦值的,應該用reg類型,第二會產生一個latch。

代碼比較少,可以一眼發現問題,如果代碼比較多呢,還能一眼發現問題嗎?之前版本沒有lint檢查的時候,我們會拿去直接綜合,也許會給我們報一個警告出來,但是又有多少次我們會去一個一個的看這個警告報的什么問題呢?

現在增加了Lint功能,直接點擊run一下看看。

3d614c48-a87f-11ee-8b88-92fbcf53809c.png

vivado直接報錯了,告訴我們c不是reg類型的。

把c改成reg類型的,代碼如下

`timescale 1ns / 1ps
module top(
    input      [7:0] a  ,
    input            b  ,
    output reg [7:0] c  
    );


always @(*) begin
    if(b == 1'b1)begin
        c = a;
    end
end


endmodule

先來綜合一下看看,下面是報告。

3d71ed64-a87f-11ee-8b88-92fbcf53809c.png

看起來一點問題都沒有,報了一大堆信息,也許你仔細看還能看到其中一條警告說c被綜合成一個latch了,要是信息更多的話還會看到他不。

而運行lint之后,會幫我們生成一個表,可以很清晰的看到這些信息:

3d8fbc22-a87f-11ee-8b88-92fbcf53809c.png

再來看另外一個典型的多驅動問題:

`timescale 1ns / 1ps
module top(
    input            clk,
    input      [7:0] a1 ,
    input      [7:0] a2 ,
    input            b  ,
    output reg [7:0] c  
    );


always @(posedge clk) begin
    if(b == 1'b1)begin
        c <= a1;
    end
end


always @(posedge clk) begin
    c <= a2;
end


endmodule

在綜合后會有一個關鍵警告產生,但也不會報錯,這個會在之后的布局布線的時候報錯。

3e01d65e-a87f-11ee-8b88-92fbcf53809c.png

同樣lint也會把這個問題給暴露出來:

3e1ab962-a87f-11ee-8b88-92fbcf53809c.png

還有一些小問題比如位寬不匹配的問題,lint也能幫我們查出來

`timescale 1ns / 1ps
module top(
    input            clk,
    input      [7:0] a  ,
    input            b  ,
    output reg [6:0] c  
    );


always @(posedge clk) begin
    if(b == 3'b101)begin
        c <= a;
    end
end


submodule submodule_inst(
    .a (kkk)
)


endmodule


module submodule (
    output [3:0] a
);
    assign a = 3'b111;
endmodule

不知道大家能一眼看出來這個代碼的問題不。

先看看綜合的結果:

3e31a064-a87f-11ee-8b88-92fbcf53809c.png

看著似乎沒啥問題。

3e4e22c0-a87f-11ee-8b88-92fbcf53809c.png

lint報了一堆位寬不匹配的問題。

先看看第一個kkk的位寬不匹配,可以看到在在submodule這個模塊里面輸出了一個4bit的變量,但是我們在例化這個模塊的時候kkk忘記定義了,這個時候kkk就被隱式推斷為了一個1bit的wire類型的變量,這樣就出現了潛在的bug。其他幾個位寬不匹配也是一樣的,當然不是所有的位寬不匹配都是bug,這個就需要我們明確知道哪些是我們故意這樣設計的。

通過觀察lint報告,可以讓我們更加了解自己的設計,讓問題發現在最開始的地方,而不是等到最后布局布線了甚至更晚,才發現這種低級的問題。

審核編輯:湯梓紅

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • IC設計
    +關注

    關注

    38

    文章

    1295

    瀏覽量

    103918
  • 仿真
    +關注

    關注

    50

    文章

    4070

    瀏覽量

    133552
  • RTL
    RTL
    +關注

    關注

    1

    文章

    385

    瀏覽量

    59760
  • 代碼
    +關注

    關注

    30

    文章

    4779

    瀏覽量

    68521
  • Vivado
    +關注

    關注

    19

    文章

    812

    瀏覽量

    66470

原文標題:Vivado2023.2的一個小功能

文章出處:【微信號:FPGA開源工坊,微信公眾號:FPGA開源工坊】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    Vitis2023.2使用之—— updata to Vitis Unified IDE

    上一章聊了一下vitis2023.2怎樣使用classic Vitis IDE,這章我們來說一說基于classic Vitis IDE的工程怎么樣更新到新版本的Vitis Unified IDE
    發表于 03-24 17:14

    Hanlp1.7版本新增功能一覽

    `Hanlp1.7版本在去年下半年的時候就隨大快的DKH1.6版本同時發布了,截至目前1.7大版本也更新到了1.7.1了。本篇分別就1.7.0和1.7.1中新增
    發表于 03-22 09:56

    怎么將vivado12.3更新到最新的15.4版本

    你好我有完整版的vivado 2012.3版本,我使用的是DVDalong和ZC 706 Board。我想將軟件更新到最新版本。請讓我知道這是可能的,免費的。
    發表于 04-14 06:48

    Xilinx 發布Vivado2013.3新增全新設計方法及功能

    中國北京- All Programmable 技術和器件的全球領先企業賽靈思公司(Xilinx, Inc. (NASDAQ:XLNX))今天發布Vivado Design Suite2013.3版本
    發表于 10-29 10:29 ?865次閱讀

    Xilinx發布Vivado 2013.3 新增全新設計方法及功能

    Xilinx發布Vivado Design Suite 2013.3版本新增最新UltraFast設計方法及新一代即插即用IP和部分重配置功能,豐富設計流程,實現前所未有的IP易用性
    發表于 12-24 17:51 ?1342次閱讀

    賽靈思Vivado設計套件推出2013.1版本,提供IP 集成器和高層次綜合功能

    關鍵詞:Vivado , 設計套件 賽靈思公司(Xilinx)今天宣布, 其業界首款可編程SoC級增強型Vivado設計套件的最新版本在生產力方面進行了兩大改進。Vivado設計套件2
    發表于 09-25 09:18 ?407次閱讀

    Vivado設計套件2017.3的新功能介紹

    視頻重點向您介紹了Vivado設計套件2017.3版本中的增強功能,包括操作系統和器件支持,高級增強功能,加速集成,實施和驗證的各種升級和
    的頭像 發表于 11-21 06:15 ?3638次閱讀
    <b class='flag-5'>Vivado</b>設計套件2017.3的新<b class='flag-5'>功能</b>介紹

    Vivado Design Suite 2015.3新增量編譯功能介紹

    了解Vivado實現中2015.3中的新增量編譯功能,包括更好地處理物理優化和自動增量編譯流程。
    的頭像 發表于 11-20 06:56 ?2852次閱讀

    Vivado Design Suite 2018.1設計套件中的新增功能介紹

    視頻重點介紹了Vivado設計套件2018.1版本中的新增功能,包括對操作系統以及器件的支持情況,還有高層次增強
    的頭像 發表于 11-20 06:28 ?2551次閱讀
    <b class='flag-5'>Vivado</b> Design Suite 2018.1設計套件中的<b class='flag-5'>新增</b><b class='flag-5'>功能</b>介紹

    Vivado 2015.3中的新增量編譯功能介紹

    了解Vivado實現中2015.3中的新增量編譯功能,包括更好地處理物理優化和自動增量編譯流程。
    的頭像 發表于 11-29 06:32 ?3661次閱讀

    Vivado 2015.3的新增量編譯功能

    了解Vivado實現中2015.3中的新增量編譯功能,包括更好地處理物理優化和自動增量編譯流程。
    的頭像 發表于 11-30 19:24 ?4527次閱讀

    Vivado? 設計套件 2023.2 版本:加速自適應 SoC 和 FPGA 產品設計

    很高興為大家詳細介紹 AMD 最新發布的 Vivado 設計套件2023.2 ,以及它的更多優勢——將幫助設計人員快速實現
    的頭像 發表于 11-02 08:10 ?1514次閱讀

    Vitis2023.2全新GUI的功能特性介紹

    Vitis2023.2之前就安裝過了,vivado 2023.2相比于2023.1區別不明顯,但嵌入式平臺vitis2023.2的變化很大,有種vscode的既視感,更符合軟件開發人員
    的頭像 發表于 01-05 09:42 ?1341次閱讀
    Vitis<b class='flag-5'>2023.2</b>全新GUI的<b class='flag-5'>功能</b>特性介紹

    Vivado 2024.1版本的新特性(1)

    Vivado 2024.1已正式發布,今天我們就來看看新版本帶來了哪些新特性。
    的頭像 發表于 09-18 10:30 ?1292次閱讀
    <b class='flag-5'>Vivado</b> 2024.1<b class='flag-5'>版本</b>的新特性(1)

    使用Vivado通過AXI Quad SPI實現XIP功能

    博客提供了基于2023.2 Vivado的參考工程,展示如何使用Microblaze 地執行(XIP)程序,并提供一個簡單的bootloader。
    的頭像 發表于 10-29 14:23 ?312次閱讀
    使用<b class='flag-5'>Vivado</b>通過AXI Quad SPI實現XIP<b class='flag-5'>功能</b>
    主站蜘蛛池模板: 无人区日本电影在线观看高清| 欧美精品3atv一区二区三区| 久久re视频这里精品青| 久久久久久免费高清电影| 酒色.com| 欧美黄色第一页| 青娱乐国产精品视频| 天天狠狠色综合图片区| 亚洲成人三级| 在线成年av动漫电影| 99热久久这里只有精品| 成人国产免费| 国模孕妇模特季玥之粉红| 久久黄色大片| 全文都是肉高h文| 亚洲 色 欧美 爱 视频 日韩| 一级特黄aa大片欧美| G国产精品无马| 国产免费69成人精品视频| 久久精品热在线观看30| 强奷乱码欧妇女中文字幕熟女| 日韩hd高清xxxⅹ| 亚洲欧美国产旡码专区| a级男女性高爱潮高清试看| 国产精品禁18久久久夂久| 久久AV国产麻豆HD真实| 青青草视频在线ac| 亚洲精品高清视频| 99RE8国产这里只有精品| 国产精品久久久久久久伊一| 久久久久久人精品免费费看| 日本熟妇乱妇熟色A片蜜桃亚洲| 亚洲AV久久久噜噜噜久久| 99精品视频在线| 国产午夜精品自在自线之la| 蜜臀AV久久国产午夜福利软件| 天天躁人人躁人人躁狂躁| 最新无码国产在线视频9299| 国产精品99久久久久久WWW| 美女被打开了屁股进去的视频| 四房播播最新地址|