在絕大多數(shù)變成語言中,'*'都是表示包括所有可能,那么在Verilog中是不是也一樣呢?為此,我用modelsim做了一個實驗。
//被測試的電路
module
input
input
input
output
reg
always
end
endmodule
//測試電路,testbench
``timescale 10ps/1ps
module
reg
reg
reg
wire
initial begin
end
always
test test_top(in,en,rst_n,out);
endmodule
說明:這里,被測試的電路中,輸出out等于其本身加上輸入in,但要在'*'的激發(fā)下才能進行;在testbench
用modelsim仿真后的波形:
由仿真后的波形中可以看出:(1)當rst_n復位后,也就是從1變成0時,out變成0,而out賦值語句是包含在always @(*)中的,這就說明rst_n的變化激發(fā)了always模塊的執(zhí)行,則rst_n信號是包含在'*'中的。后面,rst_n每變一次值,out都加上in的值,也證明了'*'包括了rst_n信號。(2)之后,in每變一次值,always模塊都執(zhí)行一次,out都加上了此時的in值,則說明'*'也包括了in信號。(3)再往后,en不停的從0變成1再變成0,但out的值始終沒變,則說明'*'不包括en信號。
結(jié)論:在Verilog中,'*'只包括該模塊中的所有型號,沒在該模塊中出現(xiàn)的信號不包含于'*'。