verilator/test_regress/t/t_bitsel_struct2.v
Wilson Snyder 8127a79cb1 Fix nested packed arrays and structs, bug600.
IMPORTANT: Packed arrays are now represented as a single linear vector in
Verilated models this may affect packed arrays that are public or accessed via the VPI.
2013-01-14 21:49:22 -05:00

37 lines
1.1 KiB
Verilog

// DESCRIPTION: Verilator: Verilog Test module
//
// This file ONLY is placed into the Public Domain, for any use,
// without warranty, 2013 by Wilson Snyder.
module t (/*AUTOARG*/);
typedef struct packed {
logic [3:2] a;
logic [5:4][3:2] b;
} ab_t;
typedef ab_t [7:6] c_t; // array of structs
typedef struct packed {
c_t [17:16] d;
} e_t;
`define check(got,expec) do if ((got) != (expec)) begin $display("Line%d: Got %b Exp %b\n", `__LINE__, (got), (expec)); $stop; end while(0);
initial begin
e_t e;
if ($bits(ab_t)!=6) $stop;
if ($bits(c_t)!=12) $stop;
if ($bits(e_t)!=24) $stop;
e = 24'b101101010111010110101010;
`check(e, 24'b101101010111010110101010);
e.d[17] = 12'b111110011011;
`check(e, 24'b111110011011010110101010);
e.d[16][6] = 6'b010101;
`check(e, 24'b111110011011010110010101);
e.d[16][6].b[5] = 2'b10;
`check(e, 24'b111110011011010110011001);
e.d[16][6].b[5][2] = 1'b1;
$write("*-* All Finished *-*\n");
$finish;
end
endmodule