用Verilog HDL实现按键消抖

上传人:沙** 文档编号:108432975 上传时间:2022-06-15 格式:DOC 页数:3 大小:36KB
收藏 版权申诉 举报 下载
用Verilog HDL实现按键消抖_第1页
第1页 / 共3页
用Verilog HDL实现按键消抖_第2页
第2页 / 共3页
用Verilog HDL实现按键消抖_第3页
第3页 / 共3页
资源描述:

《用Verilog HDL实现按键消抖》由会员分享,可在线阅读,更多相关《用Verilog HDL实现按键消抖(3页珍藏版)》请在装配图网上搜索。

1、按键消抖用按键控制一个数字,按键每按一次,这个数字加1,并通过数码管将这个数字显示出来(以16进制)。可能是悟性比较低,按键消抖都搞了1天才搞出来,下面这个程序是我经过参考别人的(有些地方没想明白),然后自己领会,写的一个程序,经过在开发板上实验,还是有一点小问题,但是我觉得,按键消抖的原理应该是这样的。希望本文能帮到需要的人,我也是一个初学者,可能程序中也有很多不足,还请能提出来,相互交流。QQ:1664619265module SW_debounce(rst_n,sy_clk,key,HEX0_D);input rst_n;/低电平复位input sy_clk;/系统时钟50Mhzinpu

2、t key; 按键output 6:0HEX0_D;数码管/*/reg key_rst;always(posedge sy_clk or negedge rst_n) beginif(!rst_n)key_rst=1b1;else每个时钟周期读一次按键的值key_rst=key;end 将按键的值存在key_rst中/*/reg key_rst_r;always(posedge sy_clk or negedge rst_n) beginif(!rst_n)key_rst_r=1b1;else 每个时钟周期将key_rst中的值存入key_rst_r中。key_rst_r=key_rst;这样

3、key_rst和key_rst_r中存放的是前后两个时钟周期,按键的值end/*/wire key_en,key_an;重点1:抖动时期的标志量,这两个标志量是用来给后面的计数器清零的assign key_en=key_rst&(key_rst_r);当按键由0变1时,key_en为1assign key_an=key_rst_r&(key_rst);当按键由1变0时,key_an为1;看下面的按键波形,俺觉得,抖动期间,这两个标志量都有可能为1/*/reg18:0 count; 计数,是为了延时10ms左右always(posedge sy_clk or negedge rst_n) beg

4、inif(!rst_n)count=19d0;else if(key_en | key_an)count=19d0;出现抖动就将count 清零,使其计不满,因为后面是每10ms读一次按键的值else if(count=19h7ffff)/10mscount=19d0;elsecount=count+1b1;end/*/reg low_sw;always(posedge sy_clk or negedge rst_n) beginif(!rst_n)low_sw=1b1;else if(count=19h7ffff)low_sw=key;每10ms读一次按键的值,因为抖动期间,count的值是

5、到不了7ffff的,所以抖动期间是不会读按键的值的,因此能消除抖动。end/*/reg low_sw_r;always(posedge sy_clk or negedge rst_n) beginif(!rst_n)low_sw_r=1b1;else low_sw_r=low_sw;low_sw和low_sw_r存放的是前后10ms,按键的值,这个值中,是按键稳定时的值end/*/wire ctr;assign ctr=low_sw&(low_sw_r);按键松手时,ctr会出现一个系统周期的高电平/reg3:0control;always(posedge sy_clk or negedge

6、rst_n) beginif(!rst_n)control=4b0;else if(ctr) 如何用通过按键产生的这个信号 ctrcontrol=control+1b1;enddisplay dis1(control,HEX0_D);endmodulemodule display(d,dis_data);input3:0d;output6:0dis_data;reg6:0dis_data;always(d) begincase(d)4b0000: dis_data=7b1000000;/display 04b0001: dis_data=7b1111001;/display 14b0010:

7、dis_data=7b0100100;/display 24b0011: dis_data=7b0110000;/display 34b0100: dis_data=7b0011001;/display 44b0101: dis_data=7b0010010;/display 54b0110: dis_data=7b0000010;/display 64b0111: dis_data=7b1111000;/display 74b1000: dis_data=7b0000000;/display 84b1001: dis_data=7b0011000;/display 94b1010: dis_data=7b0100011; /display a;4b1011: dis_data=7b0000011;/display b;4b1100: dis_data=7b1000110;/display c;4b1101: dis_data=7b0011100;/display d;4b1110: dis_data=7b0000110;/display E;4B1111: dis_data=7b0001110;/display F;endcaseendendmodule

展开阅读全文
温馨提示:
1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
2: 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
3.本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!