我是靠谱客的博主 活力眼神,最近开发中收集的这篇文章主要介绍hdlbits题目Count clock,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

       本来只是一直做题,觉得题目比较基础,直到做到这道题,这道题大概写了2个小时,特意记录一下。

 这个是题目,让做一个计时的时钟。一开始没审好题,直接加法,结果答案是10的地方我的是a,

一看是用2位bcd码来写,没办法,重写了。

 下面是我的代码:

module top_module(
    input clk,
    input reset,
    input ena,
    output pm,
    output [7:0] hh,
    output [7:0] mm,
    output [7:0] ss);
    
    
    reg [7:0] h;
    reg [7:0] m;
    reg [7:0] s;
    
    assign hh=h;
    assign mm=m;
    assign ss=s;
            
    
    always@(posedge clk)
        if(reset)
            pm<=0;
    else if(h==8'b0001_0001&&(m[7:4]==4'd5)&&(m[3:0]==4'd9)&&(s[7:4]==4'd5)&&(s[3:0]==4'd9)&&ena)
        pm<=!pm;


        
    ///
    always@(posedge clk)//小时由于是12进制,不想写两段,所以直接用case跳转了
        if(reset)
            h<=8'b0001_0010;

    else if((m[7:4]==4'd5)&&(m[3:0]==4'd9)&&(s[7:4]==4'd5)&&(s[3:0]==4'd9)&&ena)
        case(h)
            
            8'b0000_0001:h=8'b0000_0010;
            8'b0000_0010:h=8'b0000_0011;
            8'b0000_0011:h=8'b0000_0100;
            8'b0000_0100:h=8'b0000_0101;
            8'b0000_0101:h=8'b0000_0110;
            8'b0000_0110:h=8'b0000_0111;
            8'b0000_0111:h=8'b0000_1000;
            8'b0000_1000:h=8'b0000_1001;
            8'b0000_1001:h=8'b0001_0000;         
            8'b0001_0000:h=8'b0001_0001;
            8'b0001_0001:h=8'b0001_0010;
            8'b0001_0010:h=8'b0000_0001;
        endcase
        

    
    ///
  
    
    always@(posedge clk)//分的高位
        if(reset)
            m[7:4]<=0;
    else if((~(m[7:4]==4'd5))&&(m[3:0]==4'd9)&&(s[7:4]==4'd5)&&(s[3:0]==4'd9)&&ena)
        m[7:4]<=m[7:4]+4'd1;
    else if((m[7:4]==4'd5)&&(m[3:0]==4'd9)&&(s[7:4]==4'd5)&&(s[3:0]==4'd9)&&ena)
            m[7:4]<=0;
    
        always@(posedge clk)//分的低位
        if(reset)
            m[3:0]<=0;
    else if((~(m[3:0]==4'd9))&&(s[7:4]==4'd5)&&(s[3:0]==4'd9)&&ena)
        m[3:0]<=m[3:0]+4'd1;
    else if((m[3:0]==4'd9)&&(s[7:4]==4'd5)&&(s[3:0]==4'd9)&&ena)
        m[3:0]<=0;
    
    ///
    
    
    always@(posedge clk)//秒的高位
        if(reset)
            s[7:4]<=0;
    else if((~(s[7:4]==4'd5))&&(s[3:0]==4'd9)&&ena)
        s[7:4]<=s[7:4]+4'd1;
    else if((s[7:4]==4'd5)&&(s[3:0]==4'd9)&&ena)
            s[7:4]<=0;
    
        always@(posedge clk)//秒的低位
        if(reset)
            s[3:0]<=0;
    else if((~(s[3:0]==4'd9))&&ena)
        s[3:0]<=s[3:0]+4'd1;
    else if((s[3:0]==4'd9)&&ena)
        s[3:0]<=0;
endmodule


 

最后

以上就是活力眼神为你收集整理的hdlbits题目Count clock的全部内容,希望文章能够帮你解决hdlbits题目Count clock所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(61)

评论列表共有 0 条评论

立即
投稿
返回
顶部