mirror of
https://github.com/verilator/verilator.git
synced 2025-01-24 15:24:04 +00:00
ac09ad3ffd
- Allow arbitrary number of open array dimensions, not just 3. Note right now this only works with the array querying functions specified in IEEE 1800-2017 H.12.2 - Issue error when passing dynamic array or queue as DPI open array (currently unsupported) - Also tweaked AstVar::vlArgTypeRecurse, which should now error or fail for unsupported types.
315 lines
9.8 KiB
Systemverilog
315 lines
9.8 KiB
Systemverilog
// DESCRIPTION: Verilator: Verilog Test module
|
|
//
|
|
// Copyright 2020 by Geza Lore. 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-License-Identifier: LGPL-3.0-only OR Artistic-2.0
|
|
|
|
`define check(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 unless(cond,gotv,expv) do if (!(cond)) `check(gotv, expv); while(0)
|
|
|
|
`ifdef VERILATOR
|
|
`define NO_DYNAMIC
|
|
`define NO_QUEUE
|
|
`endif
|
|
|
|
`ifdef VCS
|
|
`define NO_QUEUE
|
|
`endif
|
|
|
|
`ifdef NC
|
|
`define NO_DYNAMIC
|
|
`define NO_QUEUE
|
|
`endif
|
|
|
|
`ifdef NC
|
|
`define ONNC 1
|
|
`else
|
|
`define ONNC 0
|
|
`endif
|
|
|
|
`ifdef MS
|
|
`define ONMS 1
|
|
`else
|
|
`define ONMS 0
|
|
`endif
|
|
|
|
module t;
|
|
|
|
// 1 open dimension
|
|
import "DPI-C" function int cSvLeft1( input bit h [], int d);
|
|
import "DPI-C" function int cSvRight1( input bit h [], int d);
|
|
import "DPI-C" function int cSvLow1( input bit h [], int d);
|
|
import "DPI-C" function int cSvHigh1( input bit h [], int d);
|
|
import "DPI-C" function int cSvIncrement1( input bit h [], int d);
|
|
import "DPI-C" function int cSvSize1( input bit h [], int d);
|
|
import "DPI-C" function int cSvDimensions1( input bit h []);
|
|
|
|
// 2 open dimensions
|
|
import "DPI-C" function int cSvLeft2( input bit h [][], int d);
|
|
import "DPI-C" function int cSvRight2( input bit h [][], int d);
|
|
import "DPI-C" function int cSvLow2( input bit h [][], int d);
|
|
import "DPI-C" function int cSvHigh2( input bit h [][], int d);
|
|
import "DPI-C" function int cSvIncrement2( input bit h [][], int d);
|
|
import "DPI-C" function int cSvSize2( input bit h [][], int d);
|
|
import "DPI-C" function int cSvDimensions2( input bit h [][]);
|
|
|
|
// 3 open dimensions
|
|
import "DPI-C" function int cSvLeft3( input bit h [][][], int d);
|
|
import "DPI-C" function int cSvRight3( input bit h [][][], int d);
|
|
import "DPI-C" function int cSvLow3( input bit h [][][], int d);
|
|
import "DPI-C" function int cSvHigh3( input bit h [][][], int d);
|
|
import "DPI-C" function int cSvIncrement3( input bit h [][][], int d);
|
|
import "DPI-C" function int cSvSize3( input bit h [][][], int d);
|
|
import "DPI-C" function int cSvDimensions3( input bit h [][][]);
|
|
|
|
// 4 open dimensions
|
|
import "DPI-C" function int cSvLeft4( input bit h [][][][], int d);
|
|
import "DPI-C" function int cSvRight4( input bit h [][][][], int d);
|
|
import "DPI-C" function int cSvLow4( input bit h [][][][], int d);
|
|
import "DPI-C" function int cSvHigh4( input bit h [][][][], int d);
|
|
import "DPI-C" function int cSvIncrement4( input bit h [][][][], int d);
|
|
import "DPI-C" function int cSvSize4( input bit h [][][][], int d);
|
|
import "DPI-C" function int cSvDimensions4( input bit h [][][][]);
|
|
|
|
// verilator lint_off UNDRIVEN
|
|
bit a1 [1:0];
|
|
bit a2 [1:0][2:0];
|
|
bit a3 [1:0][2:0][3:0];
|
|
bit a4 [1:0][2:0][3:0][4:0];
|
|
|
|
bit b1 [0:1];
|
|
bit b2 [0:1][0:2];
|
|
bit b3 [0:1][0:2][0:3];
|
|
bit b4 [0:1][0:2][0:3][0:4];
|
|
|
|
bit c1 [-1:1];
|
|
bit c2 [-1:1][-2:2];
|
|
bit c3 [-1:1][-2:2][-3:3];
|
|
bit c4 [-1:1][-2:2][-3:3][-4:4];
|
|
|
|
`ifndef NO_DYNAMIC
|
|
bit d1 [];
|
|
bit d2 [][-2:2];
|
|
bit d3 [][-2:2][-3:3];
|
|
bit d4 [][-2:2][-3:3][-4:4];
|
|
`endif
|
|
|
|
`ifndef NO_QUEUE
|
|
bit e1 [$];
|
|
`endif
|
|
// verilator lint_on UNDRIVEN
|
|
|
|
initial begin
|
|
`ifndef NO_DYNAMIC
|
|
d1 = new[3];
|
|
d2 = new[3];
|
|
d3 = new[3];
|
|
d4 = new[3];
|
|
`endif
|
|
|
|
`ifndef NO_QUEUE
|
|
e1.push_back(0);
|
|
e1.push_back(0);
|
|
e1.push_back(0);
|
|
`endif
|
|
|
|
// 1 open dimension
|
|
`check(cSvDimensions1(a1), 1);
|
|
`check(cSvDimensions1(b1), 1);
|
|
`check(cSvDimensions1(c1), 1);
|
|
`ifndef NO_DYNAMIC
|
|
`check(cSvDimensions1(d1), 1);
|
|
`endif
|
|
`ifndef NO_QUEUE
|
|
`check(cSvDimensions1(e1), 1);
|
|
`endif
|
|
for (int d = 0 ; d < 2 ; d++) begin
|
|
if (`ONNC && d == 0) continue;
|
|
|
|
`check(cSvLeft1(a1, d), d);
|
|
`check(cSvRight1(a1, d), 0);
|
|
`check(cSvLow1(a1, d), 0);
|
|
`check(cSvHigh1(a1, d), d);
|
|
`unless(`ONMS && d == 0, cSvIncrement1(a1, d), 1);
|
|
`check(cSvSize1(a1, d), d+1);
|
|
|
|
`check(cSvLeft1(b1, d), 0);
|
|
`check(cSvRight1(b1, d), d);
|
|
`check(cSvLow1(b1, d), 0);
|
|
`check(cSvHigh1(b1, d), d);
|
|
`ifndef NC
|
|
`unless(`ONMS && d == 0, cSvIncrement1(b1, d), d == 0 ? 1 : -1);
|
|
`endif
|
|
`check(cSvSize1(b1, d), d+1);
|
|
|
|
`check(cSvLeft1(c1, d), -d);
|
|
`check(cSvRight1(c1, d), d);
|
|
`check(cSvLow1(c1, d), -d);
|
|
`check(cSvHigh1(c1, d), d);
|
|
`ifndef NC
|
|
`unless(`ONMS && d == 0, cSvIncrement1(c1, d), d == 0 ? 1 : -1);
|
|
`endif
|
|
`check(cSvSize1(c1, d), 2*d+1);
|
|
|
|
`ifndef NO_DYNAMIC
|
|
`check(cSvLeft1(d1, d), d == 1 ? 0 : -d);
|
|
`check(cSvRight1(d1, d), d == 1 ? 2 : d);
|
|
`check(cSvLow1(d1, d), d == 1 ? 0 : -d);
|
|
`check(cSvHigh1(d1, d), d == 1 ? 2 : d);
|
|
`unless(`ONMS && d == 0, cSvIncrement1(d1, d), d == 0 ? 1 : -1);
|
|
`check(cSvSize1(d1, d), 2*d+1);
|
|
`endif
|
|
|
|
`ifndef NO_QUEUE
|
|
`check(cSvLeft1(e1, d), d == 1 ? 0 : -d);
|
|
`check(cSvRight1(e1, d), d == 1 ? 2 : d);
|
|
`check(cSvLow1(e1, d), d == 1 ? 0 : -d);
|
|
`check(cSvHigh1(e1, d), d == 1 ? 2 : d);
|
|
`unless(`ONMS && d == 0, cSvIncrement1(e1, d), d == 0 ? 1 : -1);
|
|
`check(cSvSize1(e1, d), 2*d+1);
|
|
`endif
|
|
end
|
|
|
|
// 2 open dimensions
|
|
`check(cSvDimensions2(a2), 2);
|
|
`check(cSvDimensions2(b2), 2);
|
|
`check(cSvDimensions2(c2), 2);
|
|
`ifndef NO_DYNAMIC
|
|
`check(cSvDimensions2(d2), 2);
|
|
`endif
|
|
for (int d = 0 ; d < 3 ; d++) begin
|
|
if (`ONNC && d == 0) continue;
|
|
|
|
`check(cSvLeft2(a2, d), d);
|
|
`check(cSvRight2(a2, d), 0);
|
|
`check(cSvLow2(a2, d), 0);
|
|
`check(cSvHigh2(a2, d), d);
|
|
`unless(`ONMS && d == 0, cSvIncrement2(a2, d), 1);
|
|
`check(cSvSize2(a2, d), d+1);
|
|
|
|
`check(cSvLeft2(b2, d), 0);
|
|
`check(cSvRight2(b2, d), d);
|
|
`check(cSvLow2(b2, d), 0);
|
|
`check(cSvHigh2(b2, d), d);
|
|
`ifndef NC
|
|
`unless(`ONMS && d == 0, cSvIncrement2(b2, d), d == 0 ? 1 : -1);
|
|
`endif
|
|
`check(cSvSize2(b2, d), d+1);
|
|
|
|
`check(cSvLeft2(c2, d), -d);
|
|
`check(cSvRight2(c2, d), d);
|
|
`check(cSvLow2(c2, d), -d);
|
|
`check(cSvHigh2(c2, d), d);
|
|
`ifndef NC
|
|
`unless(`ONMS && d == 0, cSvIncrement2(c2, d), d == 0 ? 1 : -1);
|
|
`endif
|
|
`check(cSvSize2(c2, d), 2*d+1);
|
|
|
|
`ifndef NO_DYNAMIC
|
|
`check(cSvLeft2(d2, d), d == 1 ? 0 : -d);
|
|
`check(cSvRight2(d2, d), d == 1 ? 2 : d);
|
|
`check(cSvLow2(d2, d), d == 1 ? 0 : -d);
|
|
`check(cSvHigh2(d2, d), d == 1 ? 2 : d);
|
|
`unless(`ONMS && d == 0, cSvIncrement2(d2, d), d == 0 ? 1 : -1);
|
|
`check(cSvSize2(d2, d), 2*d+1);
|
|
`endif
|
|
end
|
|
|
|
// 3 open dimensions
|
|
`check(cSvDimensions3(a3), 3);
|
|
`check(cSvDimensions3(b3), 3);
|
|
`check(cSvDimensions3(c3), 3);
|
|
`ifndef NO_DYNAMIC
|
|
`check(cSvDimensions3(d3), 3);
|
|
`endif
|
|
for (int d = 0 ; d < 4 ; d++) begin
|
|
if (`ONNC && d == 0) continue;
|
|
|
|
`check(cSvLeft3(a3, d), d);
|
|
`check(cSvRight3(a3, d), 0);
|
|
`check(cSvLow3(a3, d), 0);
|
|
`check(cSvHigh3(a3, d), d);
|
|
`unless(`ONMS && d == 0, cSvIncrement3(a3, d), 1);
|
|
`check(cSvSize3(a3, d), d+1);
|
|
|
|
`check(cSvLeft3(b3, d), 0);
|
|
`check(cSvRight3(b3, d), d);
|
|
`check(cSvLow3(b3, d), 0);
|
|
`check(cSvHigh3(b3, d), d);
|
|
`ifndef NC
|
|
`unless(`ONMS && d == 0, cSvIncrement3(b3, d), d == 0 ? 1 : -1);
|
|
`endif
|
|
`check(cSvSize3(b3, d), d+1);
|
|
|
|
`check(cSvLeft3(c3, d), -d);
|
|
`check(cSvRight3(c3, d), d);
|
|
`check(cSvLow3(c3, d), -d);
|
|
`check(cSvHigh3(c3, d), d);
|
|
`ifndef NC
|
|
`unless(`ONMS && d == 0, cSvIncrement3(c3, d), d == 0 ? 1 : -1);
|
|
`endif
|
|
`check(cSvSize3(c3, d), 2*d+1);
|
|
|
|
`ifndef NO_DYNAMIC
|
|
`check(cSvLeft3(d3, d), d == 1 ? 0 : -d);
|
|
`check(cSvRight3(d3, d), d == 1 ? 2 : d);
|
|
`check(cSvLow3(d3, d), d == 1 ? 0 : -d);
|
|
`check(cSvHigh3(d3, d), d == 1 ? 2 : d);
|
|
`unless(`ONMS && d == 0, cSvIncrement3(d3, d), d == 0 ? 1 : -1);
|
|
`check(cSvSize3(d3, d), 2*d+1);
|
|
`endif
|
|
end
|
|
|
|
// 4 open dimension
|
|
`check(cSvDimensions4(a4), 4);
|
|
`check(cSvDimensions4(b4), 4);
|
|
`check(cSvDimensions4(c4), 4);
|
|
`ifndef NO_DYNAMIC
|
|
`check(cSvDimensions4(d4), 4);
|
|
`endif
|
|
for (int d = 0 ; d < 5 ; d++) begin
|
|
if (`ONNC && d == 0) continue;
|
|
|
|
`check(cSvLeft4(a4, d), d);
|
|
`check(cSvRight4(a4, d), 0);
|
|
`check(cSvLow4(a4, d), 0);
|
|
`check(cSvHigh4(a4, d), d);
|
|
`unless(`ONMS && d == 0, cSvIncrement4(a4, d), 1);
|
|
`check(cSvSize4(a4, d), d+1);
|
|
|
|
`check(cSvLeft4(b4, d), 0);
|
|
`check(cSvRight4(b4, d), d);
|
|
`check(cSvLow4(b4, d), 0);
|
|
`check(cSvHigh4(b4, d), d);
|
|
`ifndef NC
|
|
`unless(`ONMS && d == 0, cSvIncrement4(b4, d), d == 0 ? 1 : -1);
|
|
`endif
|
|
`check(cSvSize4(b4, d), d+1);
|
|
|
|
`check(cSvLeft4(c4, d), -d);
|
|
`check(cSvRight4(c4, d), d);
|
|
`check(cSvLow4(c4, d), -d);
|
|
`check(cSvHigh4(c4, d), d);
|
|
`ifndef NC
|
|
`unless(`ONMS && d == 0, cSvIncrement4(c4, d), d == 0 ? 1 : -1);
|
|
`endif
|
|
`check(cSvSize4(c4, d), 2*d+1);
|
|
|
|
`ifndef NO_DYNAMIC
|
|
`check(cSvLeft4(d4, d), d == 1 ? 0 : -d);
|
|
`check(cSvRight4(d4, d), d == 1 ? 2 : d);
|
|
`check(cSvLow4(d4, d), d == 1 ? 0 : -d);
|
|
`check(cSvHigh4(d4, d), d == 1 ? 2 : d);
|
|
`unless(`ONMS && d == 0, cSvIncrement4(d4, d), d == 0 ? 1 : -1);
|
|
`check(cSvSize4(d4, d), 2*d+1);
|
|
`endif
|
|
end
|
|
|
|
$write("*-* All Finished *-*\n");
|
|
$finish;
|
|
end
|
|
|
|
endmodule
|