|
|
|
data:image/s3,"s3://crabby-images/24f38/24f38e26af18495c41b98c594418dcbc76342e1d" alt="space.gif"
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/24f38/24f38e26af18495c41b98c594418dcbc76342e1d" alt="space.gif"
|
|
data:image/s3,"s3://crabby-images/9b834/9b83485010ec42d7d2ba55a8afdf22000c8d999a" alt="../images/main/bulllet_4dots_orange.gif" |
Default argument values
|
|
|
To handle common cases or allow for unused arguments, SystemVerilog allows a task/function declaration to specify a default value for each singular argument. |
|
|
data:image/s3,"s3://crabby-images/24f38/24f38e26af18495c41b98c594418dcbc76342e1d" alt="space.gif"
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/24f38/24f38e26af18495c41b98c594418dcbc76342e1d" alt="space.gif"
|
|
data:image/s3,"s3://crabby-images/1bc6a/1bc6a260345a89e01ff782a31923ecb0428f74ca" alt="../images/main/bullet_star_pink.gif" |
Example - Default argument values
|
|
|
data:image/s3,"s3://crabby-images/24f38/24f38e26af18495c41b98c594418dcbc76342e1d" alt="space.gif"
|
|
|
1 module function_default_value ();
2
3 reg [7:0] data ;
4 reg parity_out;
5 time ltime;
6
7 function reg parity (reg [7:0] a, time b = 0, time c = 0);
8 parity = 0;
9 for (int i= 0; i < 8; i ++) begin
10 parity = parity ^ a[i];
11 end
12 endfunction
13
14 initial begin
15 parity_out = 0;
16 data = 0;
17 for (int i=250; i<256; i ++) begin
18 #5 data = i;
19 ltime = $time;
20 parity_out = parity (data);
21 parity_out = parity (data,,);
22 parity_out = parity (data,,10);
23 parity_out = parity (data,ltime,);
24 $display ("Data = %00000000b, Parity = %b", i, parity_out);
25 end
26 #10 $finish;
27 end
28
29 endmodule
You could download file function_default_value.sv here
|
|
|
data:image/s3,"s3://crabby-images/24f38/24f38e26af18495c41b98c594418dcbc76342e1d" alt="space.gif"
|
|
data:image/s3,"s3://crabby-images/1bc6a/1bc6a260345a89e01ff782a31923ecb0428f74ca" alt="../images/main/bullet_star_pink.gif" |
Simulation Output
|
|
|
data:image/s3,"s3://crabby-images/24f38/24f38e26af18495c41b98c594418dcbc76342e1d" alt="space.gif"
|
|
|
Data = 11111010, Parity = 0
Data = 11111011, Parity = 1
Data = 11111100, Parity = 0
Data = 11111101, Parity = 1
Data = 11111110, Parity = 1
Data = 11111111, Parity = 0
|
|
|
data:image/s3,"s3://crabby-images/24f38/24f38e26af18495c41b98c594418dcbc76342e1d" alt="space.gif"
|
|
|
data:image/s3,"s3://crabby-images/24f38/24f38e26af18495c41b98c594418dcbc76342e1d" alt="space.gif"
|
|
|
data:image/s3,"s3://crabby-images/24f38/24f38e26af18495c41b98c594418dcbc76342e1d" alt="space.gif"
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/24f38/24f38e26af18495c41b98c594418dcbc76342e1d" alt="space.gif"
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/726ff/726ff3b19415f2aff791975e94476916fe0130d2" alt=""
|
|
Copyright © 1998-2025 |
Deepak Kumar Tala - All rights reserved |
Do you have any Comment? mail me at:deepak@asic-world.com
|
|