mirror of
https://github.com/YosysHQ/yosys
synced 2025-06-07 06:33:24 +00:00
tests: add tests for task/function argument input/output copying
This commit is contained in:
parent
45e8ff476e
commit
97f51bb4b7
1 changed files with 132 additions and 0 deletions
132
tests/verilog/func_task_arg_copying.ys
Normal file
132
tests/verilog/func_task_arg_copying.ys
Normal file
|
@ -0,0 +1,132 @@
|
|||
# https://github.com/YosysHQ/yosys/issues/5157
|
||||
read_verilog -sv <<EOT
|
||||
module stmt_if_task (
|
||||
output logic [7:0] out_val_m6,
|
||||
input logic [7:0] in_val_m6,
|
||||
input bit condition_m6
|
||||
);
|
||||
logic [7:0] var_m6;
|
||||
task automatic update_conditional_m6(input bit cond, inout logic [7:0] val);
|
||||
if (cond) begin
|
||||
val++;
|
||||
end else begin
|
||||
--val;
|
||||
end
|
||||
endtask
|
||||
always_comb begin
|
||||
var_m6 = in_val_m6;
|
||||
update_conditional_m6(condition_m6, var_m6);
|
||||
out_val_m6 = var_m6;
|
||||
end
|
||||
|
||||
wire [7:0] m6_inc = in_val_m6 + 1;
|
||||
wire [7:0] m6_dec = in_val_m6 - 1;
|
||||
always_comb assert(out_val_m6 == (condition_m6 ? m6_inc : m6_dec));
|
||||
endmodule
|
||||
EOT
|
||||
|
||||
prep
|
||||
chformal -lower
|
||||
sat -prove-asserts -verify
|
||||
|
||||
design -reset
|
||||
|
||||
read_verilog -sv <<EOT
|
||||
module top (
|
||||
output logic [7:0] out
|
||||
);
|
||||
task automatic set_to_5(inout logic [7:0] val);
|
||||
val = 5;
|
||||
endtask
|
||||
|
||||
always_comb begin
|
||||
out = 0;
|
||||
set_to_5(out);
|
||||
end
|
||||
|
||||
always_comb assert(out == 5);
|
||||
endmodule
|
||||
EOT
|
||||
|
||||
prep
|
||||
chformal -lower
|
||||
sat -prove-asserts -verify
|
||||
|
||||
design -reset
|
||||
|
||||
read_verilog -sv <<EOT
|
||||
module top (
|
||||
output logic [7:0] a,
|
||||
output logic [7:0] b,
|
||||
output logic [7:0] c
|
||||
);
|
||||
task automatic modify(
|
||||
input logic [7:0] t_in,
|
||||
output logic [7:0] t_out,
|
||||
inout logic [7:0] t_inout
|
||||
);
|
||||
assert(t_in == 5);
|
||||
t_in = 6;
|
||||
t_out = 7;
|
||||
assert(t_inout == 8);
|
||||
t_inout = 9;
|
||||
endtask
|
||||
|
||||
always_comb begin
|
||||
a = 5;
|
||||
b = 4;
|
||||
c = 8;
|
||||
|
||||
modify(a, b, c);
|
||||
|
||||
assert(a == 5);
|
||||
assert(b == 7);
|
||||
assert(c == 9);
|
||||
end
|
||||
endmodule
|
||||
EOT
|
||||
|
||||
prep
|
||||
chformal -lower
|
||||
sat -prove-asserts -verify
|
||||
|
||||
design -reset
|
||||
|
||||
read_verilog -sv <<EOT
|
||||
module top (
|
||||
output logic [7:0] a,
|
||||
output logic [7:0] b,
|
||||
output logic [7:0] c
|
||||
);
|
||||
function logic [7:0] modify(
|
||||
input logic [7:0] t_in,
|
||||
output logic [7:0] t_out,
|
||||
inout logic [7:0] t_inout
|
||||
);
|
||||
assert(t_in == 5);
|
||||
t_in = 6;
|
||||
t_out = 7;
|
||||
assert(t_inout == 8);
|
||||
t_inout = 9;
|
||||
modify = 10;
|
||||
endfunction
|
||||
|
||||
logic [7:0] result;
|
||||
always_comb begin
|
||||
a = 5;
|
||||
b = 4;
|
||||
c = 8;
|
||||
|
||||
result = modify(a, b, c);
|
||||
|
||||
assert(a == 5);
|
||||
assert(b == 7);
|
||||
assert(c == 9);
|
||||
assert(result == 10);
|
||||
end
|
||||
endmodule
|
||||
EOT
|
||||
|
||||
prep
|
||||
chformal -lower
|
||||
sat -prove-asserts -verify
|
Loading…
Add table
Add a link
Reference in a new issue