当前位置:首页 > FPGA > 正文内容

Verilog实现时钟分频(奇数分频,偶数分频)二分频 三分频 四分频 五分频

chanra1n3年前 (2022-04-21)FPGA6474

完整工程文件:clkdiv.zip

//------------------------------------------------------

// File Name        : clkdiv.v
// Author           : ChanRa1n
// Description      : clk divider
// Called by        : TopModule
// Revision History : 2022-04-21
// Revision         : 1.0
// Email            : [email protected]
// Copyright(c) 2018-Now, MYFPGA.CN, All right reserved.
//------------------------------------------------------

module clkdiv (
    input   wire   [0:0]   Sys_clk
    ,input   wire   [0:0]   Sys_rst_n
    ,output  wire   [0:0]   Sig_clk_div2
    ,output  wire   [0:0]   Sig_clk_div3
    ,output  wire   [0:0]   Sig_clk_div4
    ,output  wire   [0:0]   Sig_clk_div5
);
//------------------------------------------------------
    function integer log2;
        input integer number;
        begin
            log2=0;
            while(2**log2<number) begin
                log2=log2+1;
            end
        end
    endfunction
//------------------------------------------------------
//Divided by 2
    reg    [0:0]   Sig_clk_div2_reg;
    assign Sig_clk_div2 = Sig_clk_div2_reg ;

    always@(posedge Sys_clk or negedge Sys_rst_n)begin
        if(~Sys_rst_n)begin
            Sig_clk_div2_reg <= 0;
        end
        else begin
            Sig_clk_div2_reg <= ~Sig_clk_div2_reg;
        end
    end
//------------------------------------------------------
//Divided by 3
    `define CLK_DIV_3 3
    reg    [0:0]   Sig_clk_div3_p;
    reg    [0:0]   Sig_clk_div3_n;
    reg    [log2(`CLK_DIV_3-1):0]   Sig_clk_div3_p_cnt;
    reg    [log2(`CLK_DIV_3-1):0]   Sig_clk_div3_n_cnt;

    assign Sig_clk_div3 = Sig_clk_div3_p && Sig_clk_div3_n ;

    always@(posedge Sys_clk or negedge Sys_rst_n)begin
        if(~Sys_rst_n)begin
            Sig_clk_div3_p     <= 1;
            Sig_clk_div3_p_cnt <= 0;
        end
        else begin      
            if(Sig_clk_div3_p_cnt < ( `CLK_DIV_3>>1 ))
                Sig_clk_div3_p <= 0;
            else
                Sig_clk_div3_p <= 1;

            if(Sig_clk_div3_p_cnt < `CLK_DIV_3-1)
                Sig_clk_div3_p_cnt <= Sig_clk_div3_p_cnt + 1;
            else
                Sig_clk_div3_p_cnt <= 0;
        end
    end

    always@(negedge Sys_clk or negedge Sys_rst_n)begin
        if(~Sys_rst_n)begin
            Sig_clk_div3_n     <= 1;
            Sig_clk_div3_n_cnt <= 0;
        end
        else begin
            if(Sig_clk_div3_n_cnt < ( `CLK_DIV_3>>1 ))
                Sig_clk_div3_n <= 0;
            else
                Sig_clk_div3_n <= 1;

            if(Sig_clk_div3_n_cnt < `CLK_DIV_3-1)
                Sig_clk_div3_n_cnt <= Sig_clk_div3_n_cnt + 1;
            else
                Sig_clk_div3_n_cnt <= 0;
        end
    end
//------------------------------------------------------
//Divided by 4
    reg    [0:0]   Sig_clk_div4_reg;
    reg    [0:0]   Sig_clk_div4_reg1;
    assign Sig_clk_div4 = Sig_clk_div4_reg ;

    always@(posedge Sys_clk or negedge Sys_rst_n)begin
        if(~Sys_rst_n)begin
            Sig_clk_div4_reg <= 0;
            Sig_clk_div4_reg1 <= 1;
        end
        else begin
            Sig_clk_div4_reg <= Sig_clk_div4_reg1;
            Sig_clk_div4_reg1 <= ~Sig_clk_div4_reg;
        end
    end
//------------------------------------------------------
//Divided by 5
    `define CLK_DIV_5 5
    reg    [0:0]   Sig_clk_div5_p;
    reg    [0:0]   Sig_clk_div5_n;
    reg    [log2(`CLK_DIV_5-1):0]   Sig_clk_div5_p_cnt;
    reg    [log2(`CLK_DIV_5-1):0]   Sig_clk_div5_n_cnt;

    assign Sig_clk_div5 = Sig_clk_div5_p && Sig_clk_div5_n ;

    always@(posedge Sys_clk or negedge Sys_rst_n)begin
        if(~Sys_rst_n)begin
            Sig_clk_div5_p     <= 1;
            Sig_clk_div5_p_cnt <= 0;
        end
        else begin      
            if(Sig_clk_div5_p_cnt < ( `CLK_DIV_5>>1 ))
                Sig_clk_div5_p <= 0;
            else
                Sig_clk_div5_p <= 1;

            if(Sig_clk_div5_p_cnt < `CLK_DIV_5-1)
                Sig_clk_div5_p_cnt <= Sig_clk_div5_p_cnt + 1;
            else
                Sig_clk_div5_p_cnt <= 0;
        end
    end

    always@(negedge Sys_clk or negedge Sys_rst_n)begin
        if(~Sys_rst_n)begin
            Sig_clk_div5_n     <= 1;
            Sig_clk_div5_n_cnt <= 0;
        end
        else begin
            if(Sig_clk_div5_n_cnt < ( `CLK_DIV_5>>1 ))
                Sig_clk_div5_n <= 0;
            else
                Sig_clk_div5_n <= 1;

            if(Sig_clk_div5_n_cnt < `CLK_DIV_5-1)
                Sig_clk_div5_n_cnt <= Sig_clk_div5_n_cnt + 1;
            else
                Sig_clk_div5_n_cnt <= 0;
        end
    end

endmodule


image.png


//------------------------------------------------------
// File Name        : clkdiv_tb.v
// Author           : ChanRa1n
// Description      : Testbench file for clkdiv_tb
// Called by        : Simulation
// Revision History : 2022-04-21
// Revision         : 1.0
// Email            : [email protected]
// Copyright(c) 2018-Now, MYFPGA.CN, All right reserved.
//------------------------------------------------------

`default_nettype wire
`timescale 1ns/1ns

module clkdiv_tb ();
    reg Sys_clk;
    reg Sys_rst_n;
    localparam CLK_PERIOD = 10;

    always #(CLK_PERIOD/2) Sys_clk=~Sys_clk;

    clkdiv clkdiv(
        .Sys_clk(Sys_clk),
        .Sys_rst_n(Sys_rst_n)
    );

    initial begin
        #1 Sys_rst_n<=1'b0;Sys_clk<=1'b0;
        #(CLK_PERIOD*3) Sys_rst_n<=1;
        #(CLK_PERIOD*3000);
        $stop;
    end

endmodule

 image.png


扫描二维码推送至手机访问。

版权声明:本文由我的FPGA发布,如需转载请注明出处。

本文链接:https://world.myfpga.cn/index.php/post/241.html

分享给朋友:

“Verilog实现时钟分频(奇数分频,偶数分频)二分频 三分频 四分频 五分频” 的相关文章

FPGA ALARM FPGA多功能闹钟 完整项目 内含上位机

FPGA ALARM FPGA多功能闹钟 完整项目 内含上位机

一、项目简述本项目使用苏州硬禾信息科技有限公司设计的小脚丫FPGA开发板设计了一个完成定时、测温、报警、控制的小项目,并通过上位机显示、下发音乐配置数据。本项目B站介绍:https://www.bilibili.com/video/BV1Vh411k7QV/二、研究进展(一)研究内容:l ...

Intel FPGA初级考试模拟试题 四套含答案

Intel FPGA初级考试模拟试题 四套含答案

*1.下列对异步信号进行同步的描述错误的是(使用锁存器)。采用保持寄存器加握手信号的方法特殊的具体应用电路结构,根据应用的不同而不同使用锁存器异步 FIFO *2.FPGA 的可编程是主要基于什么结构(查找表(LUT))。查找表(LUT)ROM 可编程PAL 可编程与或阵列可编程解析:FP...

ALGO C4MB V11引脚参照表(持续更新)

ALGO C4MB V11引脚参照表(持续更新)

功能:常用引脚CLKPIN_E1LED0PIN_G15LED1PIN_F16LED2PIN_F15LED3PIN_D16KEY1PIN_E15KEY2PIN_E16KEY3PIN_M15KEY4PIN_M16RXDPIN_M2TXDPIN_G1功能:VGA引脚VGA_BLUE[0]PIN_C15VG...

SOC 在线修改设备树和FPGA配置文件 并在线配置FPGA

SOC 在线修改设备树和FPGA配置文件 并在线配置FPGA

测试过的平台:     1、DE-10 Cyclone V开发板              ...

Xilinx FIFO和ILA学习

Xilinx FIFO和ILA学习

`timescale 1ns / 1ps//-------------------------------------------------------//Filename       ﹕ FIFO_TOP.v//Author      ...