热门标签 | HotTags
当前位置:  开发笔记 > 程序员 > 正文

Verilog——FPGA按键去抖操作

目标Verilog编程语言,实现按键去抖。模块:key_delay,模块可以输入按键去抖延迟时间参数。输入:时钟、复位、按键信号key_in输出:去抖后的按键信号key_out代码

目标



  • Verilog编程语言,实现按键去抖。

  • 模块:key_delay,模块可以输入按键去抖延迟时间参数。

  • 输入:时钟、复位、按键信号 key_in

  • 输出:去抖后的按键信号 key_out


代码



  • 实现代码

module key_delay
#(
parameter FREQ = 200 ,//MHz, 晶振频率
parameter DLY_TIME = 20_000 //us, 按键延迟时间
)
(
input sys_clk_p ,
input sys_clk_n ,
input rst_n ,
input key_in ,
output reg key_out
);
localparam MAX_TIME = FREQ * DLY_TIME;//延时时间对应计数值
wire clk200M ;
reg [31:0] cnt ;
wire max_flag ;//计数器达到最大值
reg key_in_r1 ;//按键key_in节拍
reg key_in_r2 ;
wire key_act ;//按键动作标志

IBUFDS
#(
.DIFF_TERM (
"FALSE" ),// Differential Termination
.IBUF_LOW_PWR ("TRUE" ),// Low power="TRUE", Highest performance="FALSE"
.IOSTANDARD ("DEFAULT" ) // Specify the input I/O standard
) IBUFDS_inst
(
.O (clk200M ),
// Buffer output
.I (sys_clk_p ),// Diff_p buffer input (connect directly to top-level port)
.IB (sys_clk_n ) // Diff_n buffer input (connect directly to top-level port)
);
//key_in_r1, key_in_r1
always @(posedge clk200M) begin
key_in_r1
<= key_in;
key_in_r2
<= key_in_r1;
end
//key_act, 按键有动作
assign key_act = key_in_r1 ^ key_in_r2;
//max_flag, 计数达到最大值
assign max_flag = (cnt == MAX_TIME) ? 1'b1 : 1'b0;
//cnt
always @(posedge clk200M) begin
case({key_act, max_flag})
2'b00://按键无动作, 且计数未达到最大值
cnt <= cnt + 'd1;
2'b01://按键无动作, 且计数达到最大值
cnt <= cnt;
default://按键有动作
cnt <= 'd0;
endcase
end
//key_out
always @(posedge clk200M or negedge rst_n) begin
if(~rst_n)
key_out
<= key_in_r2;
else if(cnt == MAX_TIME)
key_out
<= key_in_r2;
else
key_out
<= key_out;
end
endmodule


  • 仿真代码

`timescale 1ns / 1ps
module tb_key_delay;
reg sys_clk_p;
wire sys_clk_n;
reg rst_n;
reg key_in;
wire key_out;
//-----------------------------------------------
integer i;
key_delay
#(
.FREQ (
200 ),//MHz, 晶振频率
.DLY_TIME (1 ) //us, 按键延迟时间
)
inst_key_delay
(
.sys_clk_p (sys_clk_p ),
.sys_clk_n (sys_clk_n ),
.rst_n (rst_n ),
.key_in (key_in ),
.key_out (key_out )
);
initial begin
sys_clk_p
= 0;
rst_n
= 0;
key_in
= 0;
#
100;
rst_n
= 1;
#
100;
for(i = 0; i <= 10; i = i + 1) begin
key_in
= ~key_in;
#
30;
end
#
1500;
for(i = 0; i <= 10; i = i + 1) begin
key_in
= ~key_in;
#
30;
end

#
1500;
for(i = 0; i <= 10; i = i + 1) begin
key_in
= ~key_in;
#
30;
end
end
//时钟
always #2.5 sys_clk_p = ~sys_clk_p;
assign sys_clk_n = ~sys_clk_p;
endmodule


  • 仿真结果



  • VIVADO下的XDC文件代码

#LOCATION
set_property PACKAGE_PIN C8 [get_ports sys_clk_p]
set_property PACKAGE_PIN AF15 [get_ports rst_n]
set_property PACKAGE_PIN AF14 [get_ports key_in]
set_property PACKAGE_PIN AB15 [get_ports key_out]
#IOSTANDARD
set_property IOSTANDARD LVCMOS33 [get_ports key_in]
set_property IOSTANDARD LVCMOS33 [get_ports key_out]
set_property IOSTANDARD LVCMOS33 [get_ports rst_n]
set_property IOSTANDARD DIFF_SSTL15 [get_ports sys_clk_p]
#TIME CONSTRAINT
create_clock
-period 5.000 -waveform {0.000 2.500} [get_ports sys_clk_p]
#IOB

 



推荐阅读
  • 一、Hadoop来历Hadoop的思想来源于Google在做搜索引擎的时候出现一个很大的问题就是这么多网页我如何才能以最快的速度来搜索到,由于这个问题Google发明 ... [详细]
  • Monkey《大话移动——Android与iOS应用测试指南》的预购信息发布啦!
    Monkey《大话移动——Android与iOS应用测试指南》的预购信息已经发布,可以在京东和当当网进行预购。感谢几位大牛给出的书评,并呼吁大家的支持。明天京东的链接也将发布。 ... [详细]
  • Python实现变声器功能(萝莉音御姐音)的方法及步骤
    本文介绍了使用Python实现变声器功能(萝莉音御姐音)的方法及步骤。首先登录百度AL开发平台,选择语音合成,创建应用并填写应用信息,获取Appid、API Key和Secret Key。然后安装pythonsdk,可以通过pip install baidu-aip或python setup.py install进行安装。最后,书写代码实现变声器功能,使用AipSpeech库进行语音合成,可以设置音量等参数。 ... [详细]
  • 本文比较了eBPF和WebAssembly作为云原生VM的特点和应用领域。eBPF作为运行在Linux内核中的轻量级代码执行沙箱,适用于网络或安全相关的任务;而WebAssembly作为图灵完备的语言,在商业应用中具有优势。同时,介绍了WebAssembly在Linux内核中运行的尝试以及基于LLVM的云原生WebAssembly编译器WasmEdge Runtime的案例,展示了WebAssembly作为原生应用程序的潜力。 ... [详细]
  • 在Android开发中,使用Picasso库可以实现对网络图片的等比例缩放。本文介绍了使用Picasso库进行图片缩放的方法,并提供了具体的代码实现。通过获取图片的宽高,计算目标宽度和高度,并创建新图实现等比例缩放。 ... [详细]
  • 散列表的查找过程及优势与劣势
    散列表是一种存储和查找方法,通过散列函数计算记录的散列地址来存储和访问记录。与线性表、树、图等结构不同的是,散列技术的记录之间不存在逻辑关系,只与关键字有关联。散列表的优势在于快速的查找速度,但也存在劣势。散列表最适合解决查找与给问题。 ... [详细]
  • 云原生边缘计算之KubeEdge简介及功能特点
    本文介绍了云原生边缘计算中的KubeEdge系统,该系统是一个开源系统,用于将容器化应用程序编排功能扩展到Edge的主机。它基于Kubernetes构建,并为网络应用程序提供基础架构支持。同时,KubeEdge具有离线模式、基于Kubernetes的节点、群集、应用程序和设备管理、资源优化等特点。此外,KubeEdge还支持跨平台工作,在私有、公共和混合云中都可以运行。同时,KubeEdge还提供数据管理和数据分析管道引擎的支持。最后,本文还介绍了KubeEdge系统生成证书的方法。 ... [详细]
  • 如何去除Win7快捷方式的箭头
    本文介绍了如何去除Win7快捷方式的箭头的方法,通过生成一个透明的ico图标并将其命名为Empty.ico,将图标复制到windows目录下,并导入注册表,即可去除箭头。这样做可以改善默认快捷方式的外观,提升桌面整洁度。 ... [详细]
  • SpringBoot uri统一权限管理的实现方法及步骤详解
    本文详细介绍了SpringBoot中实现uri统一权限管理的方法,包括表结构定义、自动统计URI并自动删除脏数据、程序启动加载等步骤。通过该方法可以提高系统的安全性,实现对系统任意接口的权限拦截验证。 ... [详细]
  • IhaveconfiguredanactionforaremotenotificationwhenitarrivestomyiOsapp.Iwanttwodiff ... [详细]
  • 本文介绍了Redis的基础数据结构string的应用场景,并以面试的形式进行问答讲解,帮助读者更好地理解和应用Redis。同时,描述了一位面试者的心理状态和面试官的行为。 ... [详细]
  • Win10下游戏不能全屏的解决方法及兼容游戏列表
    本文介绍了Win10下游戏不能全屏的解决方法,包括修改注册表默认值和查看兼容游戏列表。同时提供了部分已经支持Win10的热门游戏列表,帮助玩家解决游戏不能全屏的问题。 ... [详细]
  • 本文介绍了使用Python根据字典中的值进行排序的方法,并给出了实验结果。通过将字典转化为记录项,可以按照字典中的值进行排序操作。实验结果显示,按照值进行排序后的记录项为[('b', 2), ('a', 3)]。 ... [详细]
  • 阿,里,云,物,联网,net,core,客户端,czgl,aliiotclient, ... [详细]
  • Mac OS 升级到11.2.2 Eclipse打不开了,报错Failed to create the Java Virtual Machine
    本文介绍了在Mac OS升级到11.2.2版本后,使用Eclipse打开时出现报错Failed to create the Java Virtual Machine的问题,并提供了解决方法。 ... [详细]
author-avatar
O臭煊儿O
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有