OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 4884|回复: 1

[ALTERA] 新起点FPGA之top_key_beep学习

[复制链接]

14

主题

43

帖子

0

精华

初级会员

Rank: 2

积分
95
金钱
95
注册时间
2020-12-19
在线时间
18 小时
发表于 2021-8-21 23:07:42 | 显示全部楼层 |阅读模式
关于第二个always模块中
else if(delay_cnt == 20'd1) 的问题

例程是20’d1,图片写的是20‘d0,

写20’d0的问题:
不能正常按键控制蜂鸣器。

自己分析的原因:
(1)按键按下,delay_cnt开始递减到0,
(2)else if(delay_cnt == 20'd0)一直成立,则key_value <= key一直执行。
所以问题就在key那里!!!!!!
我们平时处理的消抖只是按键按下的消抖,按键松开后也是会有抖动的!
所以当程序刚好执行到key_value <= key时,key_value的值不确定,导致按键控制也不确定!

接下来我是对例程的自己想法!此时else if(delay_cnt == 20'd1)!!!:
按下一次按键:delay_cnt将会被两次赋值20‘d1_000_000,并递减到0
(1)按键按下,if(key_reg != key)成立,delay_cnt <= 20'd1_000_000并一直递减到1
(2)else if(delay_cnt == 20'd1)成立,key_value <= key;此时key是为按下的为(0),控制蜂鸣器
(3)delay_cnt 递减到0.
(4)else if(delay_cnt == 20'd1)不成立,不控制蜂鸣器
(5)按键松开,if(key_reg != key)成立,delay_cnt <= 20'd1_000_000并一直递减到1
(6)else if(delay_cnt == 20'd1)成立,key_value <= key;此时key是为松开的为(1),不控制蜂鸣器
(7)delay_cnt 递减到0.

写这么多就是想要对它控制的过程有一个完整的思想!
key_bounce.jpg
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

14

主题

43

帖子

0

精华

初级会员

Rank: 2

积分
95
金钱
95
注册时间
2020-12-19
在线时间
18 小时
 楼主| 发表于 2021-8-22 02:09:17 | 显示全部楼层
top_key_beep学习总结:
主要是自己写代码的思想:
我们要完成的任务是:按键控制蜂鸣器,流程图就是:
按键->蜂鸣器。
再细分:
消抖->按键->蜂鸣器
所以今天我自己重新写一遍代码流程是这样写的:
先写蜂鸣器模块:key_flag,key_value,beep;
再写按键传递蜂鸣器值模块:key_flag,key_value,delay_cnt,
再写按键消抖模块:key,key_reg,delay_cnt.
我觉得这样自上而下更容易写出来,而原子视频是反过来的
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2024-11-23 21:34

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表