博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Verilog设计计数器(一)
阅读量:3914 次
发布时间:2019-05-23

本文共 915 字,大约阅读时间需要 3 分钟。

理解FPGA设计需要具体的流程框图,模块化设计。从最基础的计数器设计中,我们可以画个简要的模块。

这里写图片描述

这里的时钟是我们自己定义的,通过控制复位键,我们可以控制计数器模块的运作。我们需要了解哪些是输入输出端口,这是Verilog设计中的重中之重。通过模块我们可以知道,clk,rst_n这两个是输入端口,我们定义为input而输出的Q为输出端口,我们定义为output。举个例子,我们要设计一个计数到10自动清零的计数器,其Verilog代码如下:
module counter(         input clk,rst_n;         output [3:0] Q;         always@(posedge clk or negedge rst_n)       begin             if(!rst_n)                  Q<=0;             else begin                if(Q<=10)                     Q<=Q+1;                else                     Q<=0;             end       end

其testbeach测试代码如下:

`timescale 1ns/1nsmodule counter_tb();     reg clk,rst_n;     wire [3:0] Q;     initial begin     clk=0;     forever #10 clk=~clk;     end     initial begin     rst_n=0;     #10 rst_n=1;     end counter u1(      .clk(clk),      .rst_n(rst_n),      .Q(Q)); endmodule
笔者在起初学习Verilog数字系统设计时,也是很头痛这个计数器,自学了将近两周才明白了FPGA设计的深邃,一定要进行模块化设计,理清输入与输出端口,方能很轻松地设计出自己想要的模块。
你可能感兴趣的文章
项目开发中经常有一些被嫌弃的小数据,现在全丢给 FastDFS
查看>>
EntityFramework Core上下文实例池原理
查看>>
C# 8: 可变结构体中的只读实例成员
查看>>
11座城市,58个.NET最新岗位速览,内推直通面试官!
查看>>
【招聘(深圳)】华强方特文化科技集团 .NET工程师
查看>>
ASP.NETCore小技巧:使用测试用户中间件
查看>>
.NetCore HttpClient发送请求的时候为什么自动带上了一个RequestId头部?
查看>>
.NET 5 和 C#9 /F#5 一起到来, 向实现 .NET 统一迈出了一大步
查看>>
程序员过关斩将--从未停止过的系统架构设计步伐
查看>>
.NET Core 取消令牌:CancellationToken
查看>>
BCVP开发者说第一期:Destiny.Core.Flow
查看>>
行业思考 | 互联网对传统行业的降维打击
查看>>
简单聊聊C#中lock关键字
查看>>
.NET 5.0正式发布,有什么功能特性(翻译)
查看>>
asp.net core web api之异常
查看>>
部署Dotnet Core应用到Kubernetes(一)
查看>>
Net5 已经来临,让我来送你一个成功
查看>>
Magicodes.IE 3.0重磅设计畅谈
查看>>
一个 Task 不够,又来一个 ValueTask ,真的学懵了!
查看>>
如何在ASP.NetCore增加文件上传大小
查看>>