2652|3

109

帖子

0

TA的资源

一粒金砂(中级)

楼主
 

使用状态机的按键消抖[源码分享] [复制链接]

  1. library ieee;
  2. use ieee.std_logic_1164.all;
  3. use ieee.std_logic_unsigned.all;

  4. entity debounce_FSM is
  5.         generic (fclk : integer :=50000000);
  6.         port(
  7.                 n_rst                : in std_logic;
  8.                 clk                        : in std_logic;
  9.                 key_in                : in std_logic;                --key is valid by low
  10.                 pulse                : out std_logic        --output single pulse
  11.                 );
  12. end debounce_FSM;

  13. architecture rtl of debounce_FSM is

  14. type m_state is(
  15.                 idle,
  16.                 delay,
  17.                 output,
  18.                 key_up
  19.                 );
  20. signal cs,ns: m_state;

  21. signal key_reg : std_logic;
  22. constant n : integer :=fclk/100;        --100Hz,means to delay 10 ms
  23. signal delay_cnt : integer range 0 to n-1;

  24. begin

  25. --three section FSM
  26. --timing sequence part of FSM
  27.         process(n_rst,clk)
  28.         begin
  29.         if(n_rst='0')then
  30.                 cs<=idle;
  31.         elsif(clk'event and clk='1')then               
  32.                 cs<=ns;
  33.         end if;
  34.         end process;

  35. --combination part of FSM
  36.         process(cs,key_in,delay_cnt)
  37.         begin
  38.         case (cs) is
  39.                 when idle                =>        if(key_in='0')then
  40.                                                                 ns<=delay;                --when key is down
  41.                                                         else
  42.                                                                 ns<=idle;
  43.                                                         end if;
  44.                 when delay                =>        if(delay_cnt=n-1)then
  45.                                                                 ns<=output;
  46.                                                         else
  47.                                                                 ns<=delay;
  48.                                                         end if;
  49.                 when output                =>         ns<=key_up;
  50.                 when key_up                =>         if(key_in='1')then        --waiting key being up
  51.                                                                 ns<=idle;
  52.                                                         else
  53.                                                                 ns<=key_up;
  54.                                                         end if;
  55.                 when others                =>        ns<=idle;
  56.         end case;
  57.         end process;
  58.        
  59. --register output part of FSM
  60.         process(n_rst,clk)
  61.         begin
  62.         if(n_rst='0')then
  63.                 key_reg <='0';
  64.                 delay_cnt<=0;
  65.         elsif(clk'event and clk='1')then
  66.                 case (ns) is
  67.                         when idle        =>        key_reg <='0';delay_cnt<=0;
  68.                         when delay        =>        key_reg <='0';delay_cnt<=delay_cnt+1;
  69.                         when output        =>        if(key_in='0')then
  70.                                                                 key_reg <='1';
  71.                                                         else
  72.                                                                 key_reg <='0';
  73.                                                         end if;
  74.                                                         delay_cnt<=delay_cnt;
  75.                         when key_up        =>        key_reg <='0';delay_cnt<=0;
  76.                         when others        =>        key_reg <='0';delay_cnt<=0;
  77.                 end case;
  78.         end if;
  79.         end process;
  80.         pulse<=key_reg;
  81.        
  82. end rtl;
复制代码


此帖出自FPGA/CPLD论坛

最新回复

Great! Thank for sharing.  详情 回复 发表于 2014-4-26 14:30
点赞 关注
 

回复
举报

330

帖子

907

TA的资源

一粒金砂(中级)

沙发
 
谢谢楼主分享 。看看

此帖出自FPGA/CPLD论坛

点评

一起学习,一起分享。  详情 回复 发表于 2014-3-18 13:48
 
 

回复

109

帖子

0

TA的资源

一粒金砂(中级)

板凳
 
john_wang 发表于 2014-3-18 11:42
谢谢楼主分享 。看看

一起学习,一起分享。
此帖出自FPGA/CPLD论坛
 
 
 

回复

128

帖子

0

TA的资源

一粒金砂(初级)

4
 
Great! Thank for sharing.
此帖出自FPGA/CPLD论坛
 
 
 

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

随便看看
查找数据手册?

EEWorld Datasheet 技术支持

相关文章 更多>>
关闭
站长推荐上一条 1/9 下一条

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

About Us 关于我们 客户服务 联系方式 器件索引 网站地图 最新更新 手机版

站点相关: 国产芯 安防电子 汽车电子 手机便携 工业控制 家用电子 医疗电子 测试测量 网络通信 物联网

北京市海淀区中关村大街18号B座15层1530室 电话:(010)82350740 邮编:100190

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2025 EEWORLD.com.cn, Inc. All rights reserved
快速回复 返回顶部 返回列表