mirror of
https://github.com/verilator/verilator.git
synced 2025-01-10 08:37:35 +00:00
e5b1fdf668
Squashed commit of the following: commit c1eeda7d472fc14a0ffd5c1712ae7f7c614073a1 Author: Iztok Jeras <iztok.jeras@gmail.com> Date: Tue Mar 20 16:39:44 2012 +0100 - fixed assignment operator in t_array_packed_write_read.v from = to <= - added tests for enumerations (existing tests do not use methods like next(), num(), ...) - added t_sv_bus_mux_demux test, with packed arrays, structures and unions
144 lines
10 KiB
Verilog
144 lines
10 KiB
Verilog
// DESCRIPTION: Verilator: Verilog Test module
|
|
//
|
|
// This file ONLY is placed into the Public Domain, for any use,
|
|
// without warranty, 2012 by Iztok Jeras.
|
|
|
|
module t (/*AUTOARG*/
|
|
// Inputs
|
|
clk
|
|
);
|
|
|
|
input clk;
|
|
|
|
// parameters for array sizes
|
|
localparam WA = 8; // address dimension size
|
|
localparam WB = 8; // bit dimension size
|
|
|
|
localparam NO = 10; // number of access events
|
|
|
|
// 2D packed arrays
|
|
logic [WA-1:0] [WB-1:0] array_bg; // big endian array
|
|
/* verilator lint_off LITENDIAN */
|
|
logic [0:WA-1] [0:WB-1] array_lt; // little endian array
|
|
/* verilator lint_on LITENDIAN */
|
|
|
|
integer cnt = 0;
|
|
|
|
// event counter
|
|
always @ (posedge clk) begin
|
|
cnt <= cnt + 1;
|
|
end
|
|
|
|
// finish report
|
|
always @ (posedge clk)
|
|
if ((cnt[30:2]==NO) && (cnt[1:0]==2'd0)) begin
|
|
$write("*-* All Finished *-*\n");
|
|
$finish;
|
|
end
|
|
|
|
// big endian
|
|
always @ (posedge clk)
|
|
if (cnt[1:0]==2'd0) begin
|
|
// initialize to defaaults (all bits to x)
|
|
if (cnt[30:2]==0) array_bg <= {WA *WB{1'bx} };
|
|
else if (cnt[30:2]==1) array_bg <= {WA{ {WB{1'bx}} }};
|
|
else if (cnt[30:2]==2) array_bg <= {WA{ {WB{1'bx}} }};
|
|
else if (cnt[30:2]==3) array_bg <= {WA{ {WB{1'bx}} }};
|
|
else if (cnt[30:2]==4) array_bg <= {WA{ {WB{1'bx}} }};
|
|
else if (cnt[30:2]==5) array_bg <= {WA{ {WB{1'bx}} }};
|
|
else if (cnt[30:2]==6) array_bg <= {WA{ {WB{1'bx}} }};
|
|
else if (cnt[30:2]==7) array_bg <= {WA{ {WB{1'bx}} }};
|
|
else if (cnt[30:2]==8) array_bg <= {WA{ {WB{1'bx}} }};
|
|
else if (cnt[30:2]==9) array_bg <= {WA{ {WB{1'bx}} }};
|
|
end else if (cnt[1:0]==2'd1) begin
|
|
// write value to array
|
|
if (cnt[30:2]==0) begin end
|
|
else if (cnt[30:2]==1) array_bg <= {WA *WB +0{1'b1}};
|
|
else if (cnt[30:2]==2) array_bg [WA/2-1:0 ] <= {WA/2*WB +0{1'b1}};
|
|
else if (cnt[30:2]==3) array_bg [WA -1:WA/2] <= {WA/2*WB +0{1'b1}};
|
|
else if (cnt[30:2]==4) array_bg [ 0 ] <= {1 *WB +0{1'b1}};
|
|
else if (cnt[30:2]==5) array_bg [WA -1 ] <= {1 *WB +0{1'b1}};
|
|
else if (cnt[30:2]==6) array_bg [ 0 ][WB/2-1:0 ] <= {1 *WB/2+0{1'b1}};
|
|
else if (cnt[30:2]==7) array_bg [WA -1 ][WB -1:WB/2] <= {1 *WB/2+0{1'b1}};
|
|
else if (cnt[30:2]==8) array_bg [ 0 ][ 0 ] <= {1 *1 +0{1'b1}};
|
|
else if (cnt[30:2]==9) array_bg [WA -1 ][WB -1 ] <= {1 *1 +0{1'b1}};
|
|
end else if (cnt[1:0]==2'd2) begin
|
|
// check array value
|
|
if (cnt[30:2]==0) begin if (array_bg !== 64'bxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx) begin $display("%b", array_bg); $stop(); end end
|
|
else if (cnt[30:2]==1) begin if (array_bg !== 64'b1111111111111111111111111111111111111111111111111111111111111111) begin $display("%b", array_bg); $stop(); end end
|
|
else if (cnt[30:2]==2) begin if (array_bg !== 64'bxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx11111111111111111111111111111111) begin $display("%b", array_bg); $stop(); end end
|
|
else if (cnt[30:2]==3) begin if (array_bg !== 64'b11111111111111111111111111111111xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx) begin $display("%b", array_bg); $stop(); end end
|
|
else if (cnt[30:2]==4) begin if (array_bg !== 64'bxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx11111111) begin $display("%b", array_bg); $stop(); end end
|
|
else if (cnt[30:2]==5) begin if (array_bg !== 64'b11111111xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx) begin $display("%b", array_bg); $stop(); end end
|
|
else if (cnt[30:2]==6) begin if (array_bg !== 64'bxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx1111) begin $display("%b", array_bg); $stop(); end end
|
|
else if (cnt[30:2]==7) begin if (array_bg !== 64'b1111xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx) begin $display("%b", array_bg); $stop(); end end
|
|
else if (cnt[30:2]==8) begin if (array_bg !== 64'bxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx1) begin $display("%b", array_bg); $stop(); end end
|
|
else if (cnt[30:2]==9) begin if (array_bg !== 64'b1xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx) begin $display("%b", array_bg); $stop(); end end
|
|
end else if (cnt[1:0]==2'd3) begin
|
|
// read value from array (not a very good test for now)
|
|
if (cnt[30:2]==0) begin if (array_bg !== {WA *WB {1'bx}}) $stop(); end
|
|
else if (cnt[30:2]==1) begin if (array_bg !== {WA *WB +0{1'b1}}) $stop(); end
|
|
else if (cnt[30:2]==2) begin if (array_bg [WA/2-1:0 ] !== {WA/2*WB +0{1'b1}}) $stop(); end
|
|
else if (cnt[30:2]==3) begin if (array_bg [WA -1:WA/2] !== {WA/2*WB +0{1'b1}}) $stop(); end
|
|
else if (cnt[30:2]==4) begin if (array_bg [ 0 ] !== {1 *WB +0{1'b1}}) $stop(); end
|
|
else if (cnt[30:2]==5) begin if (array_bg [WA -1 ] !== {1 *WB +0{1'b1}}) $stop(); end
|
|
else if (cnt[30:2]==6) begin if (array_bg [ 0 ][WB/2-1:0 ] !== {1 *WB/2+0{1'b1}}) $stop(); end
|
|
else if (cnt[30:2]==7) begin if (array_bg [WA -1 ][WB -1:WB/2] !== {1 *WB/2+0{1'b1}}) $stop(); end
|
|
else if (cnt[30:2]==8) begin if (array_bg [ 0 ][ 0 ] !== {1 *1 +0{1'b1}}) $stop(); end
|
|
else if (cnt[30:2]==9) begin if (array_bg [WA -1 ][WB -1 ] !== {1 *1 +0{1'b1}}) $stop(); end
|
|
end
|
|
|
|
// little endian
|
|
always @ (posedge clk)
|
|
if (cnt[1:0]==2'd0) begin
|
|
// initialize to defaaults (all bits to x)
|
|
if (cnt[30:2]==0) array_lt <= {WA *WB{1'bx} };
|
|
else if (cnt[30:2]==1) array_lt <= {WA{ {WB{1'bx}} }};
|
|
else if (cnt[30:2]==2) array_lt <= {WA{ {WB{1'bx}} }};
|
|
else if (cnt[30:2]==3) array_lt <= {WA{ {WB{1'bx}} }};
|
|
else if (cnt[30:2]==4) array_lt <= {WA{ {WB{1'bx}} }};
|
|
else if (cnt[30:2]==5) array_lt <= {WA{ {WB{1'bx}} }};
|
|
else if (cnt[30:2]==6) array_lt <= {WA{ {WB{1'bx}} }};
|
|
else if (cnt[30:2]==7) array_lt <= {WA{ {WB{1'bx}} }};
|
|
else if (cnt[30:2]==8) array_lt <= {WA{ {WB{1'bx}} }};
|
|
else if (cnt[30:2]==9) array_lt <= {WA{ {WB{1'bx}} }};
|
|
end else if (cnt[1:0]==2'd1) begin
|
|
// write value to array
|
|
if (cnt[30:2]==0) begin end
|
|
else if (cnt[30:2]==1) array_lt <= {WA *WB +0{1'b1}};
|
|
else if (cnt[30:2]==2) array_lt [0 :WA/2-1] <= {WA/2*WB +0{1'b1}};
|
|
else if (cnt[30:2]==3) array_lt [WA/2:WA -1] <= {WA/2*WB +0{1'b1}};
|
|
else if (cnt[30:2]==4) array_lt [0 ] <= {1 *WB +0{1'b1}};
|
|
else if (cnt[30:2]==5) array_lt [ WA -1] <= {1 *WB +0{1'b1}};
|
|
else if (cnt[30:2]==6) array_lt [0 ][0 :WB/2-1] <= {1 *WB/2+0{1'b1}};
|
|
else if (cnt[30:2]==7) array_lt [ WA -1][WB/2:WB -1] <= {1 *WB/2+0{1'b1}};
|
|
else if (cnt[30:2]==8) array_lt [0 ][0 ] <= {1 *1 +0{1'b1}};
|
|
else if (cnt[30:2]==9) array_lt [ WA -1][ WB -1] <= {1 *1 +0{1'b1}};
|
|
end else if (cnt[1:0]==2'd2) begin
|
|
// check array value
|
|
if (cnt[30:2]==0) begin if (array_lt !== 64'bxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx) begin $display("%b", array_lt); $stop(); end end
|
|
else if (cnt[30:2]==1) begin if (array_lt !== 64'b1111111111111111111111111111111111111111111111111111111111111111) begin $display("%b", array_lt); $stop(); end end
|
|
else if (cnt[30:2]==2) begin if (array_lt !== 64'b11111111111111111111111111111111xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx) begin $display("%b", array_lt); $stop(); end end
|
|
else if (cnt[30:2]==3) begin if (array_lt !== 64'bxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx11111111111111111111111111111111) begin $display("%b", array_lt); $stop(); end end
|
|
else if (cnt[30:2]==4) begin if (array_lt !== 64'b11111111xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx) begin $display("%b", array_lt); $stop(); end end
|
|
else if (cnt[30:2]==5) begin if (array_lt !== 64'bxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx11111111) begin $display("%b", array_lt); $stop(); end end
|
|
else if (cnt[30:2]==6) begin if (array_lt !== 64'b1111xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx) begin $display("%b", array_lt); $stop(); end end
|
|
else if (cnt[30:2]==7) begin if (array_lt !== 64'bxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx1111) begin $display("%b", array_lt); $stop(); end end
|
|
else if (cnt[30:2]==8) begin if (array_lt !== 64'b1xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx) begin $display("%b", array_lt); $stop(); end end
|
|
else if (cnt[30:2]==9) begin if (array_lt !== 64'bxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx1) begin $display("%b", array_lt); $stop(); end end
|
|
end else if (cnt[1:0]==2'd3) begin
|
|
// read value from array (not a very good test for now)
|
|
if (cnt[30:2]==0) begin if (array_lt !== {WA *WB {1'bx}}) $stop(); end
|
|
else if (cnt[30:2]==1) begin if (array_lt !== {WA *WB +0{1'b1}}) $stop(); end
|
|
else if (cnt[30:2]==2) begin if (array_lt [0 :WA/2-1] !== {WA/2*WB +0{1'b1}}) $stop(); end
|
|
else if (cnt[30:2]==3) begin if (array_lt [WA/2:WA -1] !== {WA/2*WB +0{1'b1}}) $stop(); end
|
|
else if (cnt[30:2]==4) begin if (array_lt [0 ] !== {1 *WB +0{1'b1}}) $stop(); end
|
|
else if (cnt[30:2]==5) begin if (array_lt [ WA -1] !== {1 *WB +0{1'b1}}) $stop(); end
|
|
else if (cnt[30:2]==6) begin if (array_lt [0 ][0 :WB/2-1] !== {1 *WB/2+0{1'b1}}) $stop(); end
|
|
else if (cnt[30:2]==7) begin if (array_lt [ WA -1][WB/2:WB -1] !== {1 *WB/2+0{1'b1}}) $stop(); end
|
|
else if (cnt[30:2]==8) begin if (array_lt [0 ][0 ] !== {1 *1 +0{1'b1}}) $stop(); end
|
|
else if (cnt[30:2]==9) begin if (array_lt [ WA -1][ WB -1] !== {1 *1 +0{1'b1}}) $stop(); end
|
|
end
|
|
|
|
endmodule
|