在SV中可以使用結(jié)構(gòu)體作為模塊的輸入或輸出,這使得它可以更加清晰地傳遞更多的信號,以簡化RTL代碼,類似于interface。
typedef struct {
bit [7:0] intr = 'h AA;
logic [23:0] addr = 'h FF_FF_FF;
} ext;
module SU (
output ext extOut);
assign extOut = '{intr: 8'hFF, addr:24'haa_aa_aa};
initial begin
#1; $display($stime,,, "extOut = %p", extOut);
end
endmodule
module top;
ext extIn;
//connect extOut of 'SU' with extIn of 'top'
SU SUInst(.extOut(extIn));
initial begin
#2; $display($stime,,, "extIn = %p", extIn);
end
endmodule
仿真log:
1 extOut = '{intr:'hff, addr:'haaaaaa}
2 extIn = '{intr:'hff, addr:'haaaaaa}
V C S S i m u l a t i o n R e p o r t
在上面的例子中,我們首先定義了一個名為“ext”的unpacked struct,然后直接作為module的output。
再聲明一個moudle top,連接到這個struct。最后打印表明這個結(jié)構(gòu)體確實完成了連接,打印相同的信息。
struct可以作為參數(shù)傳遞給task或function,前提是這個struct需要先使用typedef聲明為用戶自定義類型
typedef struct {
logic [31:0] addr;
logic [63:0] data;
logic [3:0] BEnable;
} control;
function Dbus (input control ct1);
….
endfunction
審核編輯 :李倩
聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。
舉報投訴
-
模塊
+關(guān)注
關(guān)注
7文章
2837瀏覽量
53294 -
RTL
+關(guān)注
關(guān)注
1文章
394瀏覽量
62661 -
結(jié)構(gòu)體
+關(guān)注
關(guān)注
1文章
131瀏覽量
11372
發(fā)布評論請先 登錄
相關(guān)推薦
熱點推薦
RDMA設(shè)計35:基于 SV 的驗證平臺
設(shè)計。
FPGA IP(知識產(chǎn)權(quán)核)使用SystemVerilog(SV)進行驗證,主要基于其在驗證效率、代碼復(fù)用性和工程協(xié)作方面的顯著優(yōu)勢。本IP采用它進行驗證以確保其可靠性。
這里主要對RoCE
發(fā)表于 02-01 13:14
Dual Coupler Module skyworksinc
電子發(fā)燒友網(wǎng)為你提供()Dual Coupler Module相關(guān)產(chǎn)品參數(shù)、數(shù)據(jù)手冊,更有Dual Coupler Module的引腳圖、接線圖、封裝手冊、中文資料、英文資料,Dual
發(fā)表于 10-28 18:34
關(guān)于E203內(nèi)核高性能乘法器優(yōu)化(三)
4:2壓縮器優(yōu)化
一般的4:2壓縮器是由兩級3:2壓縮器串接起來的,而3:2壓縮器的實質(zhì)就是全加器,其結(jié)構(gòu)如下:
表達式如下:
代碼實現(xiàn):
module full_adder( input a
發(fā)表于 10-23 07:43
SV7102 低壓高速USB 2.0開關(guān)技術(shù)手冊
電子發(fā)燒友網(wǎng)站提供《SV7102 低壓高速USB 2.0開關(guān)技術(shù)手冊.pdf》資料免費下載
發(fā)表于 09-10 16:30
?0次下載
SV7321, SV7358, SV7324英文手冊
電子發(fā)燒友網(wǎng)站提供《SV7321, SV7358, SV7324英文手冊.pdf》資料免費下載
發(fā)表于 09-09 18:09
?0次下載
SV8541A、SV8542A、SV8544A 微功率低噪聲運算放大器技術(shù)手冊
電子發(fā)燒友網(wǎng)站提供《SV8541A、SV8542A、SV8544A 微功率低噪聲運算放大器技術(shù)手冊.pdf》資料免費下載
發(fā)表于 09-09 17:17
?0次下載
SV7102 低壓高速USB 2.0開關(guān)技術(shù)手冊
電子發(fā)燒友網(wǎng)站提供《SV7102 低壓高速USB 2.0開關(guān)技術(shù)手冊.pdf》資料免費下載
發(fā)表于 09-09 17:04
?0次下載
基于LockAI視覺識別模塊:手寫數(shù)字識別
結(jié)果可視化
lockzhiner_vision_module::vision::Visualize(input_mat, output_image, result);
參數(shù)說明:
inpu
發(fā)表于 06-30 16:45
基于LockAI視覺識別模塊:C++條碼識別
lockzhiner_vision_module::vision::Visualize(input_image, output_image,
results);
參數(shù)說明:
input
發(fā)表于 05-27 10:26
嵌入式學(xué)習(xí)-飛凌嵌入式ElfBoard ELF 1板卡-input子系統(tǒng)之基于input子系統(tǒng)的按鍵驅(qū)動
例程代碼路徑:ELF 1開發(fā)板資料包\\03-例程源碼\\03-2 驅(qū)動例程源碼\\08_input子系統(tǒng)\\keyboard下面以控制開發(fā)板上的K2為例進行講解。修改設(shè)備樹(一)查看原理圖和引腳
發(fā)表于 04-16 10:57
飛凌嵌入式ElfBoard ELF 1板卡-input子系統(tǒng)之基于input子系統(tǒng)的按鍵驅(qū)動
例程代碼路徑:ELF 1開發(fā)板資料包\\03-例程源碼\\03-2 驅(qū)動例程源碼\\08_input子系統(tǒng)\\keyboard下面以控制開發(fā)板上的K2為例進行講解。修改設(shè)備樹(一)查看原理圖和引腳
發(fā)表于 04-15 10:58
嵌入式學(xué)習(xí)-飛凌嵌入式ElfBoard ELF 1板卡-input子系統(tǒng)之input子系統(tǒng)簡單構(gòu)建流程
_device); input_free_device(input_device);
pr_info(\"Input device unregistered\\n\");}
module
發(fā)表于 04-15 10:54
飛凌嵌入式ElfBoard ELF 1板卡-input子系統(tǒng)之input子系統(tǒng)簡單構(gòu)建流程
_device); input_free_device(input_device);
pr_info(\"Input device unregistered\\n\");}
module
發(fā)表于 04-15 10:29
STM32CubeMX PA0、PA4、PA7、PB1等類似的端口不能作為普通的GPIO_Output和GPIO_Input口使用嗎?
用STM32G0B1RCT6芯片
用STM32CubeMX配置端口,有些端口沒有
GPIO_Output和GPIO_Input選項!比如PA0、PA4、PA7、PB1等類似的口。
這些口,不能作為
發(fā)表于 03-14 06:52
SV Structure作為module的input/output
評論