// 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 typedef struct { int BAR_INT; bit BAR_BIT; byte BAR_ARRAY[0:3]; } foo_t; interface intf #( parameter foo_t FOO = '{4, 1'b1, '{8'd1, 8'd2, 8'd4, 8'd8}} ) (); endinterface module sub ( intf the_intf_port[4] ); localparam int intf_foo_bar_int = the_intf_port[0].FOO.BAR_INT; initial begin #1; if (intf_foo_bar_int != 4) $stop; end endmodule module t; intf the_intf[4] (); sub the_sub (.the_intf_port(the_intf)); initial begin #2; $write("*-* All Finished *-*\n"); $finish; end endmodule