verilator/test_regress/t/t_paramgraph_iface_cfg_zero.v

54 lines
1.5 KiB
Systemverilog

// 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: 2026 Wilson Snyder
// SPDX-License-Identifier: LGPL-3.0-only OR Artistic-2.0
// DESCRIPTION:
// Minimal testcase for depgraph interface typedef resolution
// Derived from aicc_types_if/axis_if ASCRANGE warnings
//
// verilog_format: off
`define stop $stop
`define checkd(gotv,expv) do if ((gotv) !== (expv)) begin $write("%%Error: %s:%0d: got=%0d exp=%0d (%s !== %s)\n", `__FILE__,`__LINE__, (gotv), (expv), `"gotv`", `"expv`"); `stop; end while(0);
// verilog_format: on
package aerial;
typedef struct packed {
int NumCc;
int CCNumWaves;
int CCNumIds;
} cfg_t;
endpackage
interface aicc_types_if #(
parameter aerial::cfg_t cfg = '0
) ();
typedef logic [$clog2(cfg.NumCc)-1:0] cc_index_t;
typedef logic [$clog2(cfg.CCNumIds)-1:0] trans_id_t;
endinterface
module child (
aicc_types_if types
);
localparam type cc_index_t = types.cc_index_t;
localparam type trans_id_t = types.trans_id_t;
cc_index_t cc_idx;
trans_id_t tr_id;
endmodule
module top;
localparam aerial::cfg_t aer_cfg = '{NumCc: 4, CCNumWaves: 2, CCNumIds: 8};
aicc_types_if #(.cfg(aer_cfg)) types ();
child u_child (.types(types));
initial begin
#2;
`checkd($bits(types.cc_index_t), 2);
`checkd($bits(types.trans_id_t), 3);
$write("*-* All Finished *-*\n");
$finish;
end
endmodule