FPGA低级建模---按键去抖动
FPGA低级建模,原则上一个模块一个功能,如按键去抖动建模中,有两个模块。
1、detect_module 这个是按键检测模块,主要检测按键的高低电平变化,现在按键是按下还是释放。
2、delay_module 这个是滤波去抖模块,主要是防止按键或外界的抖动干扰。
综合后如下RTL图:

3、以下是建模的Verilog代码:
顶层模块:debounce_module
module debounce_module(
input iCLK,
input iRST_n,
input iPIN_In,
output oPIN_Out
);
wire H2L_Sig_W;
wire L2H_Sig_W;
delay_module u_delay_module(
.iCLK( iCLK ),
.iRST_n( iRST_n ),
.iH2L_Sig( H2L_Sig_W ),
.iL2H_Sig( L2H_Sig_W ),
.oPIN_Out( oPIN_Out )
);
detect_module u_detect_module(
.iCLK( iCLK ),
.iRST_n( iRST_n ),
.iKEY_In( iPIN_In ),
.oH2L_Sig( H2L_Sig_W ),
.oL2H_Sig( L2H_Sig_W )
);
endmodule
延时模块:delay_module
module delay_module(
input iCLK,
input iRST_n,
input iH2L_Sig,
input iL2H_Sig,
output oPIN_Out
);
/************************************************************************/
//50M系统晶振 50M*0.001 -1 = 49_999
parameter T1MS = 16'd49999;
/************************************************************************/
reg [15:0] Count1;
reg isEn;
reg isCount; //是否计数
reg [3:0] Count_MS;
reg rPin_Out;
reg [1:0] i;
//1ms 计数
always @(posedge iCLK or negedge iRST_n)
begin
if( !iRST_n )
Count1 <= 16'd0;
else if( isCount && (Count1 == T1MS ))
Count1 <= 16'd0;
else if( isCount )
Count1 <= Count1 + 1'b1;
else if( !isCount )
Count1 <= 16'd0;
end
//16ms 计数
always @( posedge iCLK or negedge iRST_n)
begin
if( !iRST_n )
Count_MS <= 4'd0;
else if( isCount && ( Count1 == T1MS ))
Count_MS <= Count_MS + 1'b1;
else if( !isCount )
Count_MS <= 4'd0;
end
//
always @( posedge iCLK or negedge iRST_n)
begin
if( !iRST_n ) begin
isCount <= 1'b0;
rPin_Out <= 1'b0;
i <= 2'd0;
end
else
case( i )
2'd0:
begin
if( iH2L_Sig ) i <= 2'd1;
else if( iL2H_Sig ) i <= 2'd2;
end
2'd1:
begin
if( Count1 == T1MS ) begin
isCount <=1'b0;
rPin_Out <= 1'b1;
i <= 2'd0;
end
else
isCount <= 1'b1;
end
2'd2:
begin
if( Count1 == T1MS ) begin
isCount <= 1'b0;
rPin_Out <= 1'b0;
i <= 2'd0;
end
else
isCount <= 1'b1;
end
endcase
end
assign oPIN_Out = rPin_Out;
endmodule
按键检测模块: detect_module
module detect_module(
input iCLK,
input iRST_n,
input iKEY_In,
output oH2L_Sig,
output oL2H_Sig
);
/************************************************************************/
//50M系统晶振 50M*0.0001 -1 = 4_999
parameter T100US = 11'd4999;
/************************************************************************/
reg [10:0] Count1;
reg iSEn;
//100us 计数
always @(posedge iCLK or negedge iRST_n)
begin
if( !iRST_n ) begin
Count1 <= 11'h0;
iSEn <= 1'b0;
end
else begin
if( Count1 == T100US )
iSEn <= 1'b1;
else
Count1 <= Count1 + 1'b1;
end
end
reg H2L_F1;
reg H2L_F2;
reg L2H_F1;
reg L2H_F2;
//判断是否有按键按下或释放
always @( posedge iCLK or negedge iRST_n)
begin
if( !iRST_n ) begin
H2L_F1 <= 1'b1;
H2L_F2 <= 1'b1;
L2H_F1 <= 1'b0;
L2H_F2 <= 1'b0;
end
else begin
H2L_F1 <= iKEY_In;
H2L_F2 <= H2L_F1;
L2H_F1 <= iKEY_In;
L2H_F2 <= L2H_F1;
end
end
assign oH2L_Sig = iSEn? ( H2L_F2 & !H2L_F1 ):1'b0;
assign oL2H_Sig = iSEn? ( !L2H_F2 & L2H_F1 ):1'b0;
endmodule
FPGA低级建模---按键去抖动的更多相关文章
- FPGA按键去抖verilog代码
按键去抖的原因及其分类就不罗嗦了. 在这里解释一段代码,代码是网上找的,看了半天没懂,无奈查了半天想了半天,终于明白了... module sw_debounce(clk,rst_n,sw1,sw2, ...
- 【第一季】CH08_FPGA_Button 按钮去抖动实验
[第一季]CH08_FPGA_Button 按钮去抖动实验 按键的消抖,是指按键在闭合或松开的瞬间伴随着一连串的抖动,这样的抖动将直接影响设计系统的稳定性,降低响应灵敏度.因此,必须对抖动进行处理,即 ...
- verilog 建模笔记--低级建模
来源 <verilog HDL那些事--建模篇> 1.并行建模的思想. 2.每个模块最好只有一个功能.(便于修改和扩展,特别在大的项目中) 典型的 HDL 教科书中,才不会要读者了解“模 ...
- week05 06绑定滚动条 去抖动
像这种小代码 为了满足某种需求 可以直接上网搜 这些都是JS代码和react无关 我们下拉 就会触发事件从而调用loading more news 那个函数 react要求我们加个key key就是唯 ...
- Linux驱动之定时器在按键去抖中的应用
机械按键在按下的过程中会出现抖动的情况,如下图,这样就会导致本来按下一次按键的过程会出现多次中断,导致判断出错.在按键驱动程序中我们可以这么做: 在按键驱动程序中我们可以这么做来取消按键抖动的影响:当 ...
- FPGA按一下按键,对应端口输出单个脉冲
对于FPGA的verilog语言,,,规定一个变量不能在多个always中被赋值.但是可以在多个alway块中做判断--结合状态机思想 module state(key,led,clk); input ...
- 深入理解JS函数节流和去抖动
一.什么是节流和去抖? 1.节流 节流就是拧紧水龙头让水少流一点,但是不是不让水流了.想象一下在现实生活中有时候我们需要接一桶水,接水的同时不想一直站在那等着,可能要离开一会去干一点别的事请,让水差不 ...
- fpga Verilog hdl 按键消抖 部分程序讲解
module debounce(clk_in,rst_in,key_in,key_pulse,key_state); input clk_in;//system clock input rst_in; ...
- 【黑金ZYNQ7000系列原创视频教程】06.ZYNQ来自FPGA的中断——按键中断实验
黑金论坛地址: http://www.heijin.org/forum.php?mod=viewthread&tid=36640&extra=page%3D1 爱奇艺地址: http: ...
随机推荐
- HDU 5446 中国剩余定理+lucas
Unknown Treasure Time Limit: 1500/1000 MS (Java/Others) Memory Limit: 131072/131072 K (Java/Other ...
- /etc/default/grub 部分配置选项设置
GRUB_HIDDEN_TIMEOUT=0 此配置将影响菜单显示.若设置此选项,将在此时间内隐藏菜单而显示引导画面. 菜单将会被隐藏,除非在此行开头加上一个 # 符号.(# GRUB_HIDDEN_T ...
- Longest Increasing Subsequence
很久不写算法了== 写个东西练练手 最长上升子序列 输入n,然后是数组a[ ]的n个元素 输出最长上升子序列的长度 一.最简单的方法复杂度O(n * n) DP[ i ] 是以a[ i ] 为结尾的最 ...
- T-SQL - 访问远程数据库并对其数据表进行操作
一.概述 很多时候我们需要在.NET应用程序中使用一条SQL语句来访问来自不同服务器.不同数据库中的不同的表,实现方法有很多.我们可以在.NET应用程序中建立数据访问层,使用ADO.NET Entit ...
- WingIDE中文乱码问题解决方法
WingIDE中文乱码问题解决方法 安装完WingIDE后,首次运行python脚本时,若脚本中含有UTF-8中文,在Debug I/O输出框中,全部变成了乱码. 这时其实我们设置下WingIDE的编 ...
- Quartus II 增量编译
在开发阶段,经常需要改代码,而且往往只改局部代码,但是编译的时候,通常会全部重新编译,这会很浪费时间,使得开发效率大大降低.那么有没有一种方法能够降低不必要的编译时间呢?通过查询Quartus II ...
- mybatis——使用mapper代理开发方式
---------------------------------------------------------------generatorConfig.xml------------------ ...
- WEKA运行LIBSVM出现problem evaluating classifier:rand
原来这个实验已经做了的.也出现了些问题,但是上网找到了解决方法,那个时候是完成数据挖掘的课程论文,用WEKA运行LIBSVM,也没有很深入,简单跑出结果就算了. 这次想着研讨会就讲这个,想着深入进去, ...
- ExtJs 学习之开篇(-)之define
Ext.onReady(function(){ /** * test1,声明一个类,定义类中的方法 */ Ext.define("demo.Demo",{ ...
- Windows下面如何建立多个Django虚拟环境
Linux 安装请见另一篇博客 http://www.cnblogs.com/zhaoyingjie/p/6180758.html 1.安装 virtualenv 2.安装virtualenvwrap ...