2014-11-28 20:01:50 +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, 2014 by Wilson Snyder.
// SPDX-License-Identifier: CC0-1.0
2014-11-28 20:01:50 +00:00
`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);
2020-01-26 21:38:22 +00:00
`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);
2014-11-28 20:01:50 +00:00
module t ( /*AUTOARG*/
// Inputs
clk
) ;
input clk ;
integer cyc = 0 ;
reg [ 4 * 8 : 1 ] vstr ;
const string s = " a " ; // Check static assignment
string s2 ;
string s3 ;
reg eq ;
2020-01-26 16:23:52 +00:00
byte unpack1 [ 0 : 4 ] ;
2014-11-28 20:01:50 +00:00
// Operators == != < <= > >= {a,b} {a{b}} a[b]
// a.len, a.putc, a.getc, a.toupper, a.tolower, a.compare, a.icompare, a.substr
// a.atoi, a.atohex, a.atooct, a.atobin, a.atoreal,
// a.itoa, a.hextoa, a.octoa, a.bintoa, a.realtoa
initial begin
$sformat ( vstr , " s=%s " , s ) ;
`checks ( vstr , " s=a " ) ;
`checks ( s , " a " ) ;
`checks ( { s , s , s } , " aaa " ) ;
`checks ( { 4 { s } } , " aaaa " ) ;
// Constification
`checkh ( s = = " a " , 1 'b1 ) ;
`checkh ( s = = " b " , 1 'b0 ) ;
`checkh ( s ! = " a " , 1 'b0 ) ;
`checkh ( s ! = " b " , 1 'b1 ) ;
`checkh ( s > " " , 1 'b1 ) ;
`checkh ( s > " a " , 1 'b0 ) ;
`checkh ( s > = " a " , 1 'b1 ) ;
`checkh ( s > = " b " , 1 'b0 ) ;
`checkh ( s < " a " , 1 'b0 ) ;
`checkh ( s < " b " , 1 'b1 ) ;
`checkh ( s < = " " , 1 'b0 ) ;
`checkh ( s < = " a " , 1 'b1 ) ;
2020-01-26 16:23:52 +00:00
`ifndef VCS
`ifndef VERILATOR
`ifndef NC
// IEEE 1800-2017 5.9 assignment to byte array
unpack1 = " five " ;
`checkh ( unpack1 [ 0 ] , " f " ) ;
`checkh ( unpack1 [ 1 ] , " i " ) ;
`checkh ( unpack1 [ 2 ] , " v " ) ;
`checkh ( unpack1 [ 3 ] , " e " ) ;
`checkh ( unpack1 [ 4 ] , 8 'h0 ) ;
`endif
`endif
`endif
2014-11-28 20:01:50 +00:00
end
// Test loop
always @ ( posedge clk ) begin
cyc < = cyc + 1 ;
if ( cyc = = 0 ) begin
// Setup
s2 = " c0 " ;
end
else if ( cyc = = 1 ) begin
$sformat ( vstr , " s2%s " , s2 ) ;
`checks ( vstr , " s2c0 " ) ;
end
else if ( cyc = = 2 ) begin
s3 = s2 ;
$sformat ( vstr , " s2%s " , s3 ) ;
`checks ( vstr , " s2c0 " ) ;
end
else if ( cyc = = 3 ) begin
s2 = " a " ;
s3 = " b " ;
end
else if ( cyc = = 4 ) begin
`checks ( { s2 , s3 } , " ab " ) ;
`checks ( { 3 { s3 } } , " bbb " ) ;
`checkh ( s = = " a " , 1 'b1 ) ;
`checkh ( s = = " b " , 1 'b0 ) ;
`checkh ( s ! = " a " , 1 'b0 ) ;
`checkh ( s ! = " b " , 1 'b1 ) ;
`checkh ( s > " " , 1 'b1 ) ;
`checkh ( s > " a " , 1 'b0 ) ;
`checkh ( s > = " a " , 1 'b1 ) ;
`checkh ( s > = " b " , 1 'b0 ) ;
`checkh ( s < " a " , 1 'b0 ) ;
`checkh ( s < " b " , 1 'b1 ) ;
`checkh ( s < = " " , 1 'b0 ) ;
`checkh ( s < = " a " , 1 'b1 ) ;
end
2020-01-26 21:38:22 +00:00
// String character references
else if ( cyc = = 10 ) begin
s2 = " astring " ;
end
else if ( cyc = = 11 ) begin
`checks ( s2 , " astring " ) ;
`checkh ( s2 . len ( ) , 7 ) ;
`checkh ( s2 [ 1 ] , " s " ) ;
s2 [ 0 ] = " 0 " ;
s2 [ 3 ] = " 3 " ;
`checks ( s2 , " 0st3ing " ) ;
end
//
2014-11-28 20:01:50 +00:00
else if ( cyc = = 99 ) begin
$write ( " *-* All Finished *-* \n " ) ;
$finish ;
end
end
endmodule