mirror of https://github.com/YosysHQ/yosys.git
48 lines
1.6 KiB
Verilog
48 lines
1.6 KiB
Verilog
|
//-----------------------------------------------------
|
||
|
// This is my second Verilog Design
|
||
|
// Design Name : first_counter
|
||
|
// File Name : first_counter.v
|
||
|
// Function : This is a 4 bit up-counter with
|
||
|
// Synchronous active high reset and
|
||
|
// with active high enable signal
|
||
|
//-----------------------------------------------------
|
||
|
module first_counter (
|
||
|
clock , // Clock input of the design
|
||
|
reset , // active high, synchronous Reset input
|
||
|
enable , // Active high enable signal for counter
|
||
|
counter_out // 4 bit vector output of the counter
|
||
|
); // End of port list
|
||
|
//-------------Input Ports-----------------------------
|
||
|
input clock ;
|
||
|
input reset ;
|
||
|
input enable ;
|
||
|
//-------------Output Ports----------------------------
|
||
|
output [3:0] counter_out ;
|
||
|
//-------------Input ports Data Type-------------------
|
||
|
// By rule all the input ports should be wires
|
||
|
wire clock ;
|
||
|
wire reset ;
|
||
|
wire enable ;
|
||
|
//-------------Output Ports Data Type------------------
|
||
|
// Output port can be a storage element (reg) or a wire
|
||
|
reg [3:0] counter_out ;
|
||
|
|
||
|
//------------Code Starts Here-------------------------
|
||
|
// Since this counter is a positive edge trigged one,
|
||
|
// We trigger the below block with respect to positive
|
||
|
// edge of the clock.
|
||
|
always @ (posedge clock)
|
||
|
begin : COUNTER // Block Name
|
||
|
// At every rising edge of clock we check if reset is active
|
||
|
// If active, we load the counter output with 4'b0000
|
||
|
if (reset == 1'b1) begin
|
||
|
counter_out <= 4'b0000;
|
||
|
end
|
||
|
// If enable is active, then we increment the counter
|
||
|
else if (enable == 1'b1) begin
|
||
|
counter_out <= counter_out + 1;
|
||
|
end
|
||
|
end // End of Block COUNTER
|
||
|
|
||
|
endmodule // End of Module counter
|