扫一扫,分享给好友
准备基于FPGA使用verilog HDL设计一个数字时钟,时间24小时、60分钟、60秒钟的计数;首先默认我们的板载有源晶振为50MHz的时钟,然后我们先设计一个秒钟的计数模块:
module sec_clock( input wire clk, input wire rst_n, output wire sec_full_flag, output reg [5:0] sec_data ); parameter SEC_1S_MAX = 26'd50_000_000; reg [25:0] count; //板载时钟转化为sec计数标志 always @(posedge clk or negedge rst_n) if( rst_n == 1'b0 ) count <= 26'b0; else if( count == SEC_1S_MAX - 1'b1 ) count <= 26'b0; else count <= count + 1'b1; //sec计数器 always @(posedge clk or negedge rst_n) if( rst_n == 1'b0 ) sec_data <= 6'b0; else if( (sec_data == 6'd59) && (count == SEC_1S_MAX - 1'b1) ) sec_data <= 6'b0; else if( count == SEC_1S_MAX - 1'b1 ) sec_data <= sec_data + 1'b1; else sec_data <= sec_data; //满60S对应的min进位标志 assign sec_full_flag = ( (sec_data == 6'd59) && (count == SEC_1S_MAX - 1'b1) ) ? 1'b1 : 1'b0; endmodule
发布
数字时钟设计FPGAfpga
【高云GW5AT-LV60 开发套件试用体验】串口通信回环
【高云GW5AT-LV60 开发套件试用体验】基于开发板进行深度学习实践,并尽量实现皮肤病理图片的识别
【高云GW5AT-LV60 开发套件试用体验】SC130GScmos模块与LVDS屏和HDMI输出例程测试报告图像显示部分细节补充
【高云GW5AT-LV60 开发套件试用体验】SC130GScmos模块与LVDS屏和HDMI输出例程测试报告
【高云GW5AT-LV60 开发套件试用体验】项目简介-带warp畸变的屏幕模组
拥抱开源!一起来做FPGA开发板啦!
【高云GW5AT-LV60 开发套件试用体验】代码解读-LVDS屏幕驱动
【高云GW5AT-LV60 开发套件试用体验】代码解读-串口通讯
【高云GW5AT-LV60 开发套件试用体验】代码解读-点灯实验
【高云GW5AT-LV60 开发套件试用体验】开箱报告
电子发烧友网
电子发烧友论坛