forked from github/verilator
48 lines
1.1 KiB
Systemverilog
48 lines
1.1 KiB
Systemverilog
|
// DESCRIPTION: Verilator: Verilog Test module
|
||
|
//
|
||
|
// A test that a package import declaration can preceed a parameter port list
|
||
|
// in an interface declaration. See 25.3 of the 1800-2017 LRM.
|
||
|
//
|
||
|
// This file ONLY is placed into the Public Domain, for any use,
|
||
|
// without warranty, 2013 by Jeremy Bennett.
|
||
|
// SPDX-License-Identifier: CC0-1.0
|
||
|
|
||
|
package bus_pkg;
|
||
|
parameter WIDTH = 8;
|
||
|
endpackage
|
||
|
|
||
|
interface simple_bus
|
||
|
import bus_pkg::*; // Import preceding parameters.
|
||
|
#(p_width = WIDTH)
|
||
|
(input logic clk);
|
||
|
|
||
|
logic req, gnt;
|
||
|
logic [p_width-1:0] addr;
|
||
|
logic [p_width-1:0] data;
|
||
|
|
||
|
modport slave(input req, addr, clk,
|
||
|
output gnt,
|
||
|
input data);
|
||
|
|
||
|
modport master(input gnt, clk,
|
||
|
output req, addr,
|
||
|
output data);
|
||
|
|
||
|
endinterface
|
||
|
|
||
|
module mem(simple_bus a);
|
||
|
logic avail;
|
||
|
always @(posedge a.clk)
|
||
|
a.gnt <= a.req & avail;
|
||
|
initial begin
|
||
|
if ($bits(a.data) != 8) $stop;
|
||
|
$write("*-* All Finished *-*\n");
|
||
|
$finish;
|
||
|
end
|
||
|
endmodule
|
||
|
|
||
|
module t (input clk);
|
||
|
simple_bus sb(clk);
|
||
|
mem mem(sb.slave);
|
||
|
endmodule
|