EDA365欢迎您登录!
您需要 登录 才可以下载或查看,没有帐号?注册
x
1 M. L4 p6 m5 F【Espier FPGA VHDL学习帖】第17帖 按键消抖
5 N$ d" L( s/ x/ b9 H6 }. F) D8 @* `
8 {! Q) Z( C% y3 q6 Q按键消抖程序的思路都是来源于特权同学的按键消抖,特权同学采用的是VHDL改编了他的程序。 ! ]: G; N2 P; G: R+ y& b
( W/ U) h! {2 {$ l, a9 P3 ^% ~) l4 c
6 C% Q4 Z0 c8 J; E20ms就会读取键值,把这个键值放到寄存器low_sw的值锁存到low_sw wire [2:0] led_ctrl = low_sw_r[2:0] &( ~low_sw[2:0]); 这是特权同学
5 P$ n% c! d* Q' T! t5 m* ^4 h; s, R0 P' t5 j
[) b A& E$ \( x8 S M& DKey_an是检测第一次按下,同时也是cnt计数,本开发板用的大概为48M晶振,并没有进行分频操作,所以 (1110101001100000000)2 这里我们直接用全1 * C$ p; P% R6 T5 j% c2 P! n
初始值 1 1 0 0 1 1 -> key_rst 0 0 1 1 0 0 ->取反 1 1 0 0 1 ->key_rst_r 0 1 0 0 0 key_an # }9 E" F# N$ T8 S. a6 q' t/ C1 \
, q8 [ D% n: ]/ A/ {
7 d: A, T; `/ [1 i s4 b把1跳变到led_ctrl拉高。回顾前面的20ms内如果出现按键被按下,
% A' \7 y( Y( _' h6 q# e; i: }; y那么有一个时钟周期里led_ctrl的置高就使得相应的LED灯的亮灭做一次改变,这就达到了目的。 - c) p. G6 V+ V* |! m% F
|