基于Verilog HDL的数字秒表与VGA显示

一、实验目的

1、复习EDA的设计方法及原理;

2、学习Verilog HDL的设计方法,会使用Verilog HDL进行较复杂数字系统的设计。

二、数字秒表实验内容

用Verilog HDL设计一个数字跑表,所需引脚和功能如下所示:

在这里插入图片描述

在这里插入图片描述

三、数字秒表实验步骤

1.新建工程

  • 点击【File】→【New Project Wizard…】
    在这里插入图片描述
  • 点击【Next >】,选择工程保存路径及工程名
    在这里插入图片描述
  • 一直点next,知道见到如下界面,【Family】选择 Cyclone IV E,芯片选择 EP4CE115F29C7,然后点击【Next >】
    在这里插入图片描述
  • 点击finish

在这里插入图片描述

2.添加 Verilog 文件

  • 点击【File】→【New…】
    在这里插入图片描述
  • 选择【Verilog HDL File】,再点击【OK】
    在这里插入图片描述
    写入如下代码
module stop_watch(
	clk,
	reset,
	pause,
	msh,
	msl,
	sh,
	sl,
	minh,
	minl);
	
	input clk, reset, pause;
	output [3:0] msh, msl, sh, sl, minh, minl;
	reg [3:0] msh, msl, sh, sl, minh, minl;
	reg count1, count2;
	
	always@(posedge clk or posedge reset) begin
		if(reset) begin
			{
   msh, msl} <= 0;
			count1 <= 0;
		end
		else if(!pause) begin
			if(msl == 9) begin
				msl <= 0;
				if(msh == 9) begin
					msh <= 0;
					count1 <= 1;
				end
				else
					msh <= msh + 1;
			end
			else begin
				msl <= msl + 1;
				count1 <= 0;
			end;
		end
	end
	
	always@(posedge count1 or posedge reset) begin
		if(reset) begin
			{
   sh, sl} <= 0;
			count2 <= 0;
		end
		else if(sl == 9) begin
			sl <= 0;
			if(sh == 5) begin
				sh <= 0;
				count2 <= 1;
			end
			else
				sh <= sh + 1;
		end
		else begin
			sl <= sl + 1;
			count2 <= 0;
		end
	end
	
	always@(posedge count2 or posedge reset) begin
		if(reset) begin
			minh <= 0;
			minl <= 0;
		end
		else if(minl == 9) begin
			minl <= 0
  • 2
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值