2020-03-07 15:24:27 +00:00
// DESCRIPTION: Verilator: Verilog Test module
//
2020-03-21 15:24:24 +00:00
// This file ONLY is placed under the Creative Commons Public Domain, for
// any use, without warranty, 2020 by Wilson Snyder.
// SPDX-License-Identifier: CC0-1.0
2020-03-07 15:24:27 +00:00
`define stop $stop
`define checkh(gotv,expv) do if ((gotv) !== (expv)) begin $write("%%Error: %s:%0d: got='h%x exp='h%x\n", `__FILE__,`__LINE__, (gotv), (expv)); `stop; end while(0);
`define checks(gotv,expv) do if ((gotv) !== (expv)) begin $write("%%Error: %s:%0d: got='%s' exp='%s'\n", `__FILE__,`__LINE__, (gotv), (expv)); `stop; end while(0);
module t ( /*AUTOARG*/
// Inputs
clk
) ;
input clk ;
integer cyc = 0 ;
integer i ;
string v ;
// verilator lint_off UNUSED
integer unused [ ] ;
// verilator lint_on UNUSED
typedef bit [ 7 : 0 ] byte_t ;
byte_t a [ ] ;
byte_t b [ ] ;
2020-05-24 01:58:45 +00:00
// wide data array
typedef struct packed {
logic [ 15 : 0 ] header ;
logic [ 223 : 0 ] payload ;
logic [ 15 : 0 ] checksum ;
} pck256_t ;
pck256_t p256 [ ] ;
2020-03-07 15:24:27 +00:00
always @ ( posedge clk ) begin
cyc < = cyc + 1 ;
begin
`checkh ( a . size , 0 ) ;
v = $sformatf ( " %p " , a ) ; `checks ( v , " '{} " ) ;
a = new [ 3 ] ;
`checkh ( a . size , 3 ) ;
a [ 0 ] = 10 ;
a [ 1 ] = 11 ;
a [ 2 ] = 12 ;
`checkh ( a [ 0 ] , 10 ) ;
`checkh ( a [ 1 ] , 11 ) ;
`checkh ( a [ 2 ] , 12 ) ;
v = $sformatf ( " %p " , a ) ; `checks ( v , " '{'ha, 'hb, 'hc} " ) ;
a . delete ;
`checkh ( a . size , 0 ) ;
a = new [ 2 ] ;
`ifdef verilator // Unsupported pattern assignment
a [ 0 ] = 15 ; a [ 1 ] = 16 ;
`else
a = ' { 15 , 16 } ;
`endif
`checkh ( a . size , 2 ) ;
`checkh ( a [ 0 ] , 15 ) ;
`checkh ( a [ 1 ] , 16 )
`ifdef verilator // Unsupported pattern assignment
a = new [ 1 ] ;
a [ 0 ] = 17 ;
`else
a = ' { 17 } ;
`endif
`checkh ( a . size , 1 ) ; // IEEE says resizes to smallest that fits pattern
`checkh ( a [ 0 ] , 17 ) ;
a = new [ 2 ] ;
a [ 0 ] = 5 ;
a [ 1 ] = 6 ;
`checkh ( a [ 0 ] , 5 ) ;
`checkh ( a [ 1 ] , 6 ) ;
a = new [ 2 ] ;
`checkh ( a [ 0 ] , 0 ) ;
`checkh ( a [ 1 ] , 0 ) ;
a [ 0 ] = 5 ;
a [ 1 ] = 6 ;
`checkh ( a [ 0 ] , 5 ) ;
`checkh ( a [ 1 ] , 6 ) ;
b = new [ 4 ] ( a ) ;
`checkh ( b . size , 4 ) ;
`checkh ( b [ 0 ] , 5 ) ;
`checkh ( b [ 1 ] , 6 ) ;
`checkh ( b [ 2 ] , 0 ) ;
`checkh ( b [ 3 ] , 0 ) ;
a = b ;
`checkh ( a . size , 4 ) ;
`checkh ( a [ 0 ] , 5 ) ;
`checkh ( a [ 1 ] , 6 ) ;
`checkh ( a [ 2 ] , 0 ) ;
`checkh ( a [ 3 ] , 0 ) ;
a = new [ 0 ] ;
`checkh ( a . size , 0 ) ;
b = new [ 4 ] ( a ) ;
`checkh ( b . size , 4 ) ;
`checkh ( b [ 0 ] , 0 ) ;
`checkh ( b [ 1 ] , 0 ) ;
`checkh ( b [ 2 ] , 0 ) ;
`checkh ( b [ 4 ] , 0 ) ;
2020-05-24 01:58:45 +00:00
// test wide dynamic array
p256 = new [ 11 ] ;
`checkh ( p256 . size , 11 ) ;
`checkh ( p256 . size ( ) , 11 ) ;
p256 [ 1 ] . header = 16 'hcafe ;
p256 [ 1 ] . payload = { 14 { 16 'hbabe } } ;
p256 [ 1 ] . checksum = 16 'hdead ;
`checkh ( p256 [ 1 ] . header , 16 'hcafe ) ;
`checkh ( p256 [ 1 ] , { 16 'hcafe , { 14 { 16 'hbabe } } , 16 'hdead } ) ;
`checkh ( p256 [ 0 ] , '0 ) ;
p256 [ 5 ] = '1 ;
`checkh ( p256 [ 5 ] , { 32 { 8 'hff } } ) ;
p256 [ 5 ] . header = 16 'h2 ;
`checkh ( p256 [ 5 ] , { 16 'h2 , { 30 { 8 'hff } } } ) ;
p256 [ 2 ] = ( p256 [ 5 ] . header = = 2 ) ? p256 [ 1 ] : p256 [ 5 ] ;
`checkh ( p256 [ 2 ] , { 16 'hcafe , { 14 { 16 'hbabe } } , 16 'hdead } ) ;
p256 . delete ( ) ;
`checkh ( p256 . size , 0 ) ;
2020-03-07 15:24:27 +00:00
end
$write ( " *-* All Finished *-* \n " ) ;
$finish ;
end
endmodule