省流:不同的公司風格不同,都會使用。
數字電路設計主要就是,選擇器、全加器、比較器,乘法器,幾個常用邏輯門,再加個D觸發器,電路基本都能實現了。
切換到具體語法System Verilog本來就是Verilog的語法擴展,所以Verilog支持的SV都支持。
組合邏輯用assign是同樣的,用always_comb代替always @*。
時序邏輯用always_ff @(posedge clk or negedge rst_n)代替always @(posedge clk or negedge rst_n)
信號聲明logic代替wire/reg。不用再繁瑣的區分數據類型。
端口聲明可以用多維數組。一些處理用generate for不要太爽。
以上這幾條改變不大,可以無縫適應。
接口Interface
SystemVerilog提供了一個新的、高層抽象的模塊連接,這個連接被稱為接口(Interface)。它可以將常用的比較規范的端口定義出來,方便集成連接。
舉個例子,首先定義一組interface,文件為interface.vh
interface chip_bus (input logic clock, resetn); logic interrupt_req, grant, ready; logic [31:0] address; wire [63:0] data; modport master (input interrupt_req, input address, output grant, ready, inout data, input clock, resetn); modport slave (output interrupt_req, output address, input grant, ready, inout data, input clock, resetn); endinterface然后在子模塊中就可以include使用這一組定義。
`include "interface.vh" module primary( chip_bus.mater local_bus, chip_bus.slave primary_local_bus, input clock, input resetn ); endmodule `include "interface.vh" module secondary( chip_bus.slave local_bus, chip_bus.master secondary_local_bus, `ifdef FPGA input fpga_clk, `endif input clock, input resetn ); endmodule
最后在top中例化兩個子模塊,top上也可以定義interface,直接連接到子模塊,兩個子模塊之間的interface連接在頂層定義一個用于連線的interface。
`include "interface.vh" module top ( chip_bus.master secondary_local_bus, chip_bus.slave primary_local_bus, `ifdef FPGA input fpga_clk, `endif input clock, input resetn ); chip_bus local_bus(); primary u_primary(/*autoinst*/ .local_bus (local_bus.master ), //interface//ahb_bus.mater .primary_local_bus (primary_local_bus ), //interface//axi_bus.slave .clock (clock ), //input .resetn (resetn ) //input ); secondary u_secondary(/*autoinst*/ .local_bus (local_bus.slave ), //interface//ahb_bus.slave .secondary_local_bus (secondary_local_bus ), //interface//axi_bus.master `ifdef FPGA .fpga_clk (fpga_clk ), //input `endif .clock (clock ), //input .resetn (resetn ) //input ); endmodule使用interface可以提高集成的效率,不容易出錯,方便檢視。 當然要是問我推薦用SV還是Verilog,我建議是遵守公司代碼規范,公司讓用啥就用啥。
審核編輯:劉清
-
比較器
+關注
關注
14文章
1656瀏覽量
107329 -
Verilog
+關注
關注
28文章
1351瀏覽量
110189 -
D觸發器
+關注
關注
3文章
164瀏覽量
47972 -
數字電路
+關注
關注
193文章
1610瀏覽量
80712
原文標題:現在公司里做設計用SV還是Verilog?
文章出處:【微信號:IP與SoC設計,微信公眾號:IP與SoC設計】歡迎添加關注!文章轉載請注明出處。
發布評論請先 登錄
相關推薦
評論