Skip to content

Commit

Permalink
added clock divider
Browse files Browse the repository at this point in the history
  • Loading branch information
KaseyHDL committed Apr 18, 2024
1 parent b77bc0f commit c6663ef
Show file tree
Hide file tree
Showing 3 changed files with 58 additions and 0 deletions.
1 change: 1 addition & 0 deletions info.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,7 @@ project:
- "controller.v"
- "rng.v"
- "timer.v"
- "clk_div.v"

# The pinout of your project. Leave unused pins blank. DO NOT delete or add any pins.
pinout:
Expand Down
46 changes: 46 additions & 0 deletions src/clk_div.v
Original file line number Diff line number Diff line change
@@ -0,0 +1,46 @@
/*
* Copyright (c) 2023 Iron Violet LLC
* SPDX-License-Identifier: Apache-2.0
*/

//============================================================================//
// Clock Divider
//============================================================================//

`define default_netname none

module clk_div #(
parameter FREQ_IN = 50_000_000,
parameter FREQ_OUT = 10_000
)(
input CLK,
input RST_N,
output reg CLK_OUT
);
parameter DIV = FREQ_IN / FREQ_OUT;

reg [$clog2(DIV)-1:0] cntr;

// clock counter
always @(posedge CLK or negedge RST_N) begin
if (!RST_N) begin
cntr <= 0;
end else if (cntr >= (DIV-1)) begin
cntr <= 0;
end else begin
cntr <= cntr + 1;
end
end

// divided clock
always @(posedge CLK or negedge RST_N) begin
if (!RST_N) begin
CLK_OUT <= 0;
end else if (cntr < DIV/2) begin
CLK_OUT <= 1;
end else begin
CLK_OUT <= 0;
end
end

endmodule : clk_div
11 changes: 11 additions & 0 deletions src/project.v
Original file line number Diff line number Diff line change
Expand Up @@ -39,6 +39,17 @@ module tt_um_iron_violet_simon (
assign uo_out[3] = lamp_ena & lamp_out[1] & lamp_out[0];

wire timer_go;

wire clk_10khz;

clk_div #(
.FREQ_IN (50_000_000),
.FREQ_OUT (10_000)
) clk_div_u1 (
.CLK (clk),
.RST_N (rst_n),
.CLK_OUT (clk_10khz)
);

io_sync io_sync_u1 (
.CLK (clk),
Expand Down

0 comments on commit c6663ef

Please sign in to comment.