基于Roebi EDA实现I2C通讯之(二)按键控制数据读/写(key_filter)

一、前置分析

我们使用按键控制数据读/写,首先需要编写按键模块,由于按键的物理特性,按下会发生抖动,需要软件消抖。常用软件方法去抖,即检测出按键闭合后执行一个延时程序,根据抖动的时间为5ms~10ms,我们产生一个20ms的延时,让前沿抖动消失后再一次检测键的状态,如果仍保持闭合状态电平,则确认为真正有键按下。

当有20ms的时间内都没有抖动就说明按键已经处于稳定状态了。

接下来我们定义一个计数器cnt_20ms,用于计数20ms。假如输入时钟信号为50Mhz,计数器只需计数到999_999,就计数了20ms。reg [19:0]cnt_20ms

①只要在时钟上升沿检测到key_in为高电平,则计数值清零

②在稳定态,使得cnt_20ms计数到999_999,停止计数,发现cnt_20ms计数器计数到999_998的次数只有一个,而且最接近999_999,在既保证去抖动时间的前提下使key_flag信号只产生一个脉冲信号

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值