verilator/test_regress/t/t_vpi_var2.v

250 lines
6.1 KiB
Systemverilog

// DESCRIPTION: Verilator: Verilog Test module
//
// This program is free software; you can redistribute it and/or modify it
// under the terms of either the GNU Lesser General Public License Version 3
// or the Perl Artistic License Version 2.0.
// SPDX-FileCopyrightText: 2023 Wilson Snyder
// SPDX-License-Identifier: LGPL-3.0-only OR Artistic-2.0
`ifdef USE_VPI_NOT_DPI
//We call it via $c so we can verify DPI isn't required - see bug572
`else
import "DPI-C" context function int mon_check();
`endif
module t
/* verilator public_flat_on */
#(
parameter int visibleParam1 = 0,
/* verilator public_off */
parameter int invisibleParam1 = 1,
/* verilator public_on */
parameter int visibleParam2 = 2
/* verilator public_off */
)
(/*AUTOARG*/
// Outputs
x,
// Inputs
clk, a
);
`ifdef VERILATOR
`systemc_header
extern "C" int mon_check();
`verilog
`endif
input clk;
input [7:0] a /* verilator public_flat_rw */;
output reg [7:0] x /* verilator public_flat_rw */;
/*verilator public_flat_rw_on @(posedge clk)*/
reg onebit;
reg [2:1] twoone;
reg [2:1] fourthreetwoone[4:3];
reg LONGSTART_a_very_long_name_which_will_get_hashed_a_very_long_name_which_will_get_hashed_a_very_long_name_which_will_get_hashed_a_very_long_name_which_will_get_hashed_LONGEND;
// verilator lint_off ASCRANGE
reg [0:61] quads[2:3] /*verilator public_flat_rw @(posedge clk)*/;
reg [8:19] rev /*verilator public_flat_rw @(posedge clk) */;
/*verilator public_off*/
reg invisible1;
// verilator lint_on ASCRANGE
/*verilator public_flat_on*/
reg [31:0] count;
reg [31:0] half_count = 0;
/*verilator public_off*/
/*verilator public_flat_rw_on*/
reg [31:0] delayed;
reg [31:0] delayed_mem [16];
reg [7:0] \escaped_with_brackets[3] ;
reg [7:0] mem_2d[3:0][7:0]; // Descending indices
// verilator lint_off ASCRANGE
reg [0:95] mem_3d[0:1][1:0][0:1]; // Mixed: asc, desc, asc
// Signal with multiple packed dimensions
reg [0:15][0:3][7:0] multi_packed[2:0];
reg [8:-7] [3:-4] negative_multi_packed[0:-2];
// verilator lint_on ASCRANGE
reg unpacked_only[7:0];
/*verilator public_off*/
reg invisible2;
/*verilator public_flat_rw_on @(posedge clk)*/
reg [7:0] text_byte;
reg [15:0] text_half;
reg [31:0] text_word;
reg [63:0] text_long;
reg [511:0] text;
reg [2047:0] too_big;
/*verilator public_off*/
integer status;
/*verilator public_flat_rw_on*/
bit bit1;
integer integer1;
byte byte1;
shortint short1;
int int1;
longint long1;
real real1;
string str1;
localparam int nullptr = 123;
logic [31:0] some_mem [4] = {0, 0, 0, 432};
/*verilator public_off*/
generate
for (genvar i = 0; i < 1; i++) begin : gen
wire [7:0] gen_sig /*verilator public_flat_rw*/ = 8'hAB;
end
endgenerate
sub sub();
// Test loop
initial begin
count = 0;
delayed = 0;
onebit = 1'b0;
fourthreetwoone[3] = 0; // stop icarus optimizing away
text_byte = "B";
text_half = "Hf";
text_word = "Word";
text_long = "Long64b";
text = "Verilog Test module";
too_big = "some text";
bit1 = 1;
integer1 = 123;
byte1 = 123;
short1 = 123;
int1 = 123;
long1 = 123;
real1 = 1.0;
str1 = "hello";
\escaped_with_brackets[3] = 8'h5a;
rev = 12'habc;
for (int i = 0; i < 4; i++) begin
for (int j = 0; j < 8; j++) begin
mem_2d[i][j] = 8'(((i * 8) + j));
end
end
for (int i = 0; i < 2; i++) begin
for (int j = 0; j < 2; j++) begin
for (int k = 0; k < 2; k++) begin
mem_3d[i][j][k] = 96'(((i * 4) + (j * 2) + k));
end
end
end
for (int i = 0; i < 3; i++) begin
for (int j = 0; j < 16; j++) begin
for (int k = 0; k < 4; k++) begin
multi_packed[i][j][k] = 8'(((i * 64) + (j * 4) + k));
end
end
end
for (int i = -2; i <= 0; i++) begin
for (int j = -7; j <= 8; j++) begin
negative_multi_packed[i][j] = 8'(((i + 2) * 4) + (j + 2));
end
end
`ifdef VERILATOR
status = $c32("mon_check()");
`endif
`ifdef IVERILOG
status = $mon_check();
`endif
`ifndef USE_VPI_NOT_DPI
status = mon_check();
`endif
if (status!=0) begin
$write("%%Error: t_vpi_var.cpp:%0d: C Test failed\n", status);
$stop;
end
$write("%%Info: Checking results\n");
if (onebit != 1'b1) $stop;
if (quads[2] != 62'h12819213_abd31a1c) $stop;
if (quads[3] != 62'h1c77bb9b_3784ea09) $stop;
if (text_byte != "A") $stop;
if (text_half != "T2") $stop;
if (text_word != "Tree") $stop;
if (text_long != "44Four44") $stop;
if (text != "lorem ipsum") $stop;
if (str1 != "something a lot longer than hello") $stop;
if (real1 > 123456.7895 || real1 < 123456.7885 ) $stop;
end
always @(posedge clk) begin
count <= count + 2;
if (count[1])
half_count <= half_count + 2;
if (count == 1000) begin
if (delayed != 123) $stop;
if (delayed_mem[7] != 456) $stop;
$write("*-* All Finished *-*\n");
$finish;
end
end
genvar i;
generate
for (i=1; i<=6; i=i+1) begin : arr
arr #(.LENGTH(i)) arr();
end
endgenerate
genvar k;
generate
for (k=1; k<=6; k=k+1) begin : subs
sub subsub();
end
endgenerate
arr #(.LENGTH(8)) \escaped.inst[0] ();
endmodule : t
module sub;
reg subsig1 /*verilator public_flat_rw*/;
reg subsig2 /*verilator public_flat_rd*/;
`ifdef IVERILOG
// stop icarus optimizing signals away
wire redundant = subsig1 | subsig2;
`endif
endmodule : sub
module arr;
parameter LENGTH = 1;
/*verilator public_flat_rw_on*/
reg [LENGTH-1:0] sig;
reg [LENGTH-1:0] rfr;
reg [LENGTH-1:0] \escaped_sig[1] /*verilator public_flat_rw*/;
reg check;
reg verbose;
/*verilator public_off*/
initial begin
sig = {LENGTH{1'b0}};
rfr = {LENGTH{1'b0}};
end
always @(posedge check) begin
if (verbose) $display("%m : %x %x", sig, rfr);
if (check && sig != rfr) $stop;
check <= 0;
end
endmodule : arr