Add regression tests for single element unpacked array assignments

Check that continuous assignment of an assignment pattern to a single element
unpacked array is accepted. Check that assigning a scalar expression to the
whole unpacked array is rejected for both procedural and continuous
assignments.

Check that a selected element of a single element static unpacked array can be
used in a continuous l-value concatenation.

Signed-off-by: Lars-Peter Clausen <lars@metafoo.de>
This commit is contained in:
Lars-Peter Clausen 2026-05-16 19:53:36 -07:00
parent dea82c5a91
commit 74491cfe9f
15 changed files with 223 additions and 0 deletions

View File

@ -0,0 +1,27 @@
// Check that procedural assignment of unpacked array assignment patterns to
// single element arrays is supported.
module test;
reg failed;
integer a[0:0];
`define check(val, exp) \
if (val !== exp) begin \
$display("FAILED(%0d). '%s' expected %0d, got %0d", `__LINE__, \
`"val`", exp, val); \
failed = 1'b1; \
end
initial begin
failed = 1'b0;
a = '{42};
`check(a[0], 42);
if (!failed) begin
$display("PASSED");
end
end
endmodule

View File

@ -0,0 +1,28 @@
// Check that continuous assignment of unpacked array assignment patterns to
// single element arrays is supported.
module test;
reg failed;
integer a[0:0];
assign a = '{42};
`define check(val, exp) \
if (val !== exp) begin \
$display("FAILED(%0d). '%s' expected %0d, got %0d", `__LINE__, \
`"val`", exp, val); \
failed = 1'b1; \
end
initial begin
failed = 1'b0;
#1;
`check(a[0], 42);
if (!failed) begin
$display("PASSED");
end
end
endmodule

View File

@ -0,0 +1,13 @@
// Check that scalar expressions can not be procedurally assigned to single
// element unpacked arrays.
module test;
integer a[0:0];
initial begin
a = 1;
$display("FAILED");
end
endmodule

View File

@ -0,0 +1,30 @@
// Check that continuous array assignment to single element unpacked arrays is
// supported.
module test;
reg failed;
wire [31:0] a[0:0];
reg [31:0] b[0:0];
assign a = b;
`define check(val, exp) \
if (val !== exp) begin \
$display("FAILED(%0d). '%s' expected %0d, got %0d", `__LINE__, \
`"val`", exp, val); \
failed = 1'b1; \
end
initial begin
failed = 1'b0;
b[0] = 32'd42;
#1;
`check(a[0], 32'd42);
if (!failed) begin
$display("PASSED");
end
end
endmodule

View File

@ -0,0 +1,10 @@
// Check that scalar expressions can not be continuously assigned to single
// element unpacked arrays.
module test;
wire [31:0] a[0:0];
assign a = 1;
endmodule

View File

@ -0,0 +1,29 @@
// Check that single element static unpacked array elements can be used in
// procedural l-value concatenations.
module test;
reg failed;
reg [7:0] a[0:0];
reg [7:0] y;
`define check(val, exp) \
if (val !== exp) begin \
$display("FAILED(%0d). '%s' expected %h, got %h", `__LINE__, \
`"val`", exp, val); \
failed = 1'b1; \
end
initial begin
failed = 1'b0;
y = 8'h78;
{a[0]} = y;
`check(a[0], 8'h78);
if (!failed) begin
$display("PASSED");
end
end
endmodule

View File

@ -0,0 +1,30 @@
// Check that single element static unpacked array elements can be used in
// continuous l-value concatenations.
module test;
reg failed;
wire [7:0] a[0:0];
reg [7:0] y;
assign {a[0]} = y;
`define check(val, exp) \
if (val !== exp) begin \
$display("FAILED(%0d). '%s' expected %h, got %h", `__LINE__, \
`"val`", exp, val); \
failed = 1'b1; \
end
initial begin
failed = 1'b0;
y = 8'h78;
#1;
`check(a[0], 8'h78);
if (!failed) begin
$display("PASSED");
end
end
endmodule

View File

@ -233,12 +233,17 @@ sv_ap_uarray5 vvp_tests/sv_ap_uarray5.json
sv_ap_uarray6 vvp_tests/sv_ap_uarray6.json
sv_ap_uarray_fail1 vvp_tests/sv_ap_uarray_fail1.json
sv_ap_uarray_fail2 vvp_tests/sv_ap_uarray_fail2.json
sv_ap_uarray_single1 vvp_tests/sv_ap_uarray_single1.json
sv_ap_uarray_single2 vvp_tests/sv_ap_uarray_single2.json
sv_argumentless_func vvp_tests/sv_argumentless_func.json
sv_array_assign_fail1 vvp_tests/sv_array_assign_fail1.json
sv_array_assign_fail2 vvp_tests/sv_array_assign_fail2.json
sv_array_assign_single_fail1 vvp_tests/sv_array_assign_single_fail1.json
sv_array_cassign6 vvp_tests/sv_array_cassign6.json
sv_array_cassign7 vvp_tests/sv_array_cassign7.json
sv_array_cassign8 vvp_tests/sv_array_cassign8.json
sv_array_cassign_single vvp_tests/sv_array_cassign_single.json
sv_array_cassign_single_fail1 vvp_tests/sv_array_cassign_single_fail1.json
sv_automatic_2state vvp_tests/sv_automatic_2state.json
sv_byte_array_string1 vvp_tests/sv_byte_array_string1.json
sv_byte_array_string2 vvp_tests/sv_byte_array_string2.json
@ -321,6 +326,8 @@ sv_lval_concat_string_fail1 vvp_tests/sv_lval_concat_string_fail1.json
sv_lval_concat_string_fail2 vvp_tests/sv_lval_concat_string_fail2.json
sv_lval_concat_string_fail3 vvp_tests/sv_lval_concat_string_fail3.json
sv_lval_concat_string_fail4 vvp_tests/sv_lval_concat_string_fail4.json
sv_lval_concat_uarray1 vvp_tests/sv_lval_concat_uarray1.json
sv_lval_concat_uarray2 vvp_tests/sv_lval_concat_uarray2.json
sv_lval_concat_uarray_fail1 vvp_tests/sv_lval_concat_uarray_fail1.json
sv_lval_concat_uarray_fail2 vvp_tests/sv_lval_concat_uarray_fail2.json
sv_lval_concat_uarray_fail3 vvp_tests/sv_lval_concat_uarray_fail3.json

View File

@ -0,0 +1,9 @@
{
"type" : "normal",
"source" : "sv_ap_uarray_single1.v",
"iverilog-args" : [ "-g2005-sv" ],
"vlog95" : {
"__comment" : "Array nets are not supported",
"type" : "CE"
}
}

View File

@ -0,0 +1,9 @@
{
"type" : "normal",
"source" : "sv_ap_uarray_single2.v",
"iverilog-args" : [ "-g2005-sv" ],
"vlog95" : {
"__comment" : "Array nets are not supported",
"type" : "CE"
}
}

View File

@ -0,0 +1,5 @@
{
"type" : "CE",
"source" : "sv_array_assign_single_fail1.v",
"iverilog-args" : [ "-g2005-sv" ]
}

View File

@ -0,0 +1,9 @@
{
"type" : "normal",
"source" : "sv_array_cassign_single.v",
"iverilog-args" : [ "-g2005-sv" ],
"vlog95" : {
"__comment" : "Array nets are not supported",
"type" : "CE"
}
}

View File

@ -0,0 +1,5 @@
{
"type" : "CE",
"source" : "sv_array_cassign_single_fail1.v",
"iverilog-args" : [ "-g2005-sv" ]
}

View File

@ -0,0 +1,4 @@
{
"type" : "normal",
"source" : "sv_lval_concat_uarray1.v"
}

View File

@ -0,0 +1,8 @@
{
"type" : "normal",
"source" : "sv_lval_concat_uarray2.v",
"vlog95" : {
"__comment" : "Array nets are not supported",
"type" : "CE"
}
}