一、前置分析
我们使用按键控制数据读/写,首先需要编写按键模块,由于按键的物理特性,按下会发生抖动,需要软件消抖。常用软件方法去抖,即检测出按键闭合后执行一个延时程序,根据抖动的时间为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信号只产生一个脉冲信号。