FPGA搭积木之计数器

目录

1.前言

在使用FPGA设计硬件时经常会用到计数器,虽然很简单,但是每次都要反复去写计数器,显得很麻烦而且效率低。今天就分享一个之前自己设计的计数器,可以调整位宽,以及选择是向上或向下计数。

2.设计

不含输入计数值的:

verilog 复制代码
`timescale 1ns / 1ps

module counter #(parameter CNT_NUM = 4'd8,
				parameter	ADD = 1'b1)
(	
	input							clk			,
	input							rst_n		,
	input							En_cnt		,
	
	output	reg	[$clog2(CNT_NUM) - 1:0]	cnt		,
	output							cnt_last			
);

wire	end_cnt;

always @(posedge clk or negedge rst_n)begin
    if(!rst_n)begin
        cnt <= ADD ? 'd0 : CNT_NUM - 1;
    end
    else if(En_cnt)begin
        if(end_cnt)begin
            cnt <= ADD ? 'd0 : CNT_NUM - 1;
		end
        else begin
            cnt <= ADD ? cnt + 1'b1 : cnt - 1'b1;
		end
    end
end

assign end_cnt = ADD ? cnt == CNT_NUM - 1 : cnt == 0;
assign cnt_last = end_cnt ? 1'b1:1'b0;
endmodule

含最大计数值输入的:

verilog 复制代码
`timescale 1ns / 1ps

module counter_in #(parameter CNT_NUM = 4'd8,
				parameter	ADD = 1'b1)
(	
	input								clk			,
	input								rst_n		,
	input								En_cnt		,
	input		[$clog2(CNT_NUM) - 1:0]	cnt_din		,
	
	output	reg	[$clog2(CNT_NUM) - 1:0]	cnt			,
	output								cnt_last			
);

wire	end_cnt;

always @(posedge clk or negedge rst_n)begin
    if(!rst_n)begin
        cnt <= ADD ? 'd0 : cnt_din;
    end
    else if(En_cnt)begin
        if(end_cnt)begin
            cnt <= ADD ? 'd0 : cnt_din;
		end
        else begin
            cnt <= ADD ? cnt + 1'b1 : cnt - 1'b1;
		end
    end
end

assign end_cnt = ADD ? cnt == cnt_din : cnt == 0;
assign cnt_last = end_cnt ? 1'b1:1'b0;
endmodule

3仿真

verilog 复制代码
`timescale 1ns / 1ps
module counter_tb();
parameter CNT_NUM = 4'd8;
parameter	ADD = 1'b0;
parameter T = 10;
reg								clk		 	;
reg								rst_n	 	;
reg								En_cnt		;
reg		[$clog2(CNT_NUM) - 1:0]	cnt_din		;
wire	[$clog2(CNT_NUM) - 1:0]	cnt		 	;
wire							cnt_last	;

counter_in #(.CNT_NUM(CNT_NUM),
			.ADD(ADD))
counter_test(
.clk		(clk		),	
.rst_n		(rst_n		),
.En_cnt		(En_cnt		),
.cnt_din	(cnt_din	),         
.cnt		(cnt		),	
.cnt_last	(cnt_last	)
);		

always #(T/2) clk = ~clk;

initial begin
	clk = 1'b0;
	cnt_din = CNT_NUM -1;
	rst_n = 1'b0;
	#(10*T)
	rst_n = 1'b1;
	En_cnt = 1'b0;
	#(10*T)
	En_cnt = 1'b1;
	
end			 
endmodule

此合集持续分享一些笔者自己设计的可复用硬件模块:FPGA搭积木

相关推荐
尤老师FPGA16 小时前
HDMI数据的接收发送实验(十二)
fpga开发
坏孩子的诺亚方舟20 小时前
FPGA神经网络数学基础0
人工智能·神经网络·线性代数·fpga开发
熠速20 小时前
PolarBox高性能实时仿真系统
arm开发·fpga开发·嵌入式实时数据库·硬件在环半实物仿真
南檐巷上学21 小时前
基于Zynq-7020的带有正弦波发生器的8051软核设计
单片机·嵌入式硬件·fpga开发·fpga
思尔芯S2C21 小时前
FPGA原型验证中的内存模型应用:基于DDR5的Linux系统启动与测试
fpga开发·内存模型·ddr4·ddr5·memory model·hbm3·prototyping
hai3152475431 天前
RISC-V CVA6 AXI适配器+DMA桥蜂鸟E203处理器的总线接口单元(BIU)仲裁器
驱动开发·fpga开发·硬件架构·硬件工程·精益工程
高速上的乌龟1 天前
Lattice LFCPNX-100 HSB+Fpga开发详解:2.3 Hololink 顶层模块深度全解析
linux·fpga开发
ALINX技术博客2 天前
【FPGA 开发教程】基于 ALINX FPGA 开发板实现 USB3.2 高速通信(Z7-P+FL2010)
fpga开发·fpga·fmc子卡·usb3.2通信
Ricky05532 天前
搭载实时 FPGA 处理系统的航天器上用于海上监视的超分辨率YOLO目标检测技术(意大利2026年研究)
yolo·目标检测·fpga开发
kaizq2 天前
在线设计模仿平台StepFPGA应用实践
fpga开发·verilog编程·在线设计仿真·小脚丫stepfpga·图形化设计·risc-v_soc·ima-copilot-ds