2017-09-24 01:18:07 +00:00
|
|
|
// DESCRIPTION: Verilator: Verilog example module
|
|
|
|
//
|
2020-03-21 15:24:24 +00:00
|
|
|
// This file ONLY is placed under the Creative Commons Public Domain, for
|
|
|
|
// any use, without warranty, 2003 by Wilson Snyder.
|
|
|
|
// SPDX-License-Identifier: CC0-1.0
|
2017-09-24 01:18:07 +00:00
|
|
|
// ======================================================================
|
|
|
|
|
|
|
|
// This is intended to be a complex example of several features, please also
|
2019-10-06 14:32:49 +00:00
|
|
|
// see the simpler examples/make_hello_c.
|
2017-09-24 01:18:07 +00:00
|
|
|
|
|
|
|
module top
|
|
|
|
(
|
|
|
|
// Declare some signals so we can see how I/O works
|
2020-04-06 01:53:24 +00:00
|
|
|
input clk,
|
|
|
|
input fastclk,
|
|
|
|
input reset_l,
|
2017-09-24 01:18:07 +00:00
|
|
|
|
2019-06-22 16:32:13 +00:00
|
|
|
output wire [1:0] out_small,
|
|
|
|
output wire [39:0] out_quad,
|
|
|
|
output wire [69:0] out_wide,
|
2020-04-06 01:53:24 +00:00
|
|
|
input [1:0] in_small,
|
|
|
|
input [39:0] in_quad,
|
|
|
|
input [69:0] in_wide
|
2017-09-24 01:18:07 +00:00
|
|
|
);
|
|
|
|
|
|
|
|
// Connect up the outputs, using some trivial logic
|
2019-06-22 16:32:13 +00:00
|
|
|
assign out_small = ~reset_l ? '0 : (in_small + 2'b1);
|
|
|
|
assign out_quad = ~reset_l ? '0 : (in_quad + 40'b1);
|
|
|
|
assign out_wide = ~reset_l ? '0 : (in_wide + 70'b1);
|
2017-09-24 01:18:07 +00:00
|
|
|
|
|
|
|
// And an example sub module. The submodule will print stuff.
|
|
|
|
sub sub (/*AUTOINST*/
|
2017-10-10 11:18:01 +00:00
|
|
|
// Inputs
|
|
|
|
.clk (clk),
|
|
|
|
.fastclk (fastclk),
|
|
|
|
.reset_l (reset_l));
|
2017-09-24 01:18:07 +00:00
|
|
|
|
|
|
|
// Print some stuff as an example
|
|
|
|
initial begin
|
|
|
|
$display("[%0t] Model running...\n", $time);
|
|
|
|
end
|
|
|
|
|
|
|
|
endmodule
|