当前位置: 首页 > article >正文

(15)CT137A- 按键消抖设计

(1)设计定义:设计一个按键消抖模块,实现消除按键机械抖动的影响, 并实现以下功能:

  • 按下S1,LED1、LED8点亮,否则熄灭
  • 按下S2,LED2、LED7点亮,否则熄灭
  • 按下S3,LED3、LED6点亮,否则熄灭
  • 按下S4,LED4、LED5点亮,否则熄灭

(2)代码设计:

        1.首先是20ms的计数器,一般来说,机械抖动的时间不会超过20ms。

        2.状态机的定义和设计

//状态机定义
always@(posedge clk or negedge reset_n)		
	if(!reset_n)begin
		state <= IDLE;
		en_cnt <= 1'd0;
	end
	else begin
		case(state)
			IDLE:begin
				if(key_in == 1'd0)begin
					state <= PRESS;
					en_cnt <= 1'd1;
				end
				else begin
					state <= state;
					en_cnt <= 1'd0;
				end			
			end
			PRESS:begin
				if(cnt == MCNT - 20'd1 && key_in == 1'd0)begin
					state <= DOWN;
					en_cnt <= 1'd0;
				end
				else if(key_in == 1'd1)begin
					state <= IDLE;
					en_cnt <= 1'd0;
				end
				else begin
					state <= state;
					en_cnt <= en_cnt;
				end
			end
			DOWN:begin
				if(key_in == 1'd1)begin
					state <= REPRESS;
					en_cnt <= 1'd1;
				end
				else begin
					state <= state;
					en_cnt <= 1'd0;
				end
			end
			REPRESS:begin
				if(cnt == MCNT - 20'd1 && key_in == 1'd1)begin
					state <= IDLE;
					en_cnt <= 1'd0;
				end
				else if(key_in == 1'd0)begin
					state <= DOWN;
					en_cnt <= 1'd0;
				end
				else begin
					state <= state;
					en_cnt <= en_cnt;
				end
			end
			default:begin
				state <=	IDLE;
				en_cnt <= 1'd0;
			end
		endcase
	end

附上顶层文件:

module key_filter_top
(
	input		wire				clk 		,
	input		wire				reset_n	,
	input		wire	[3:0]		key_in	,  //{S4,S3,S2,S1}
	
	output	wire	[7:0]		LED	
);

key_filter		key_filter_inst0
(
	.clk			(clk		),
	.reset_n		(reset_n	),
	.key_in		(key_in[0]),
	
	.key_out		(),
	.LED1			(LED[0]),
	.LED2			(LED[7])
);

key_filter		key_filter_inst1
(
	.clk			(clk		),
	.reset_n		(reset_n	),
	.key_in		(key_in[1]),
	
	.key_out		(),
	.LED1			(LED[1]),
	.LED2			(LED[6])
);

key_filter		key_filter_inst2
(
	.clk			(clk		),
	.reset_n		(reset_n	),
	.key_in		(key_in[2]),
	
	.key_out		(),
	.LED1			(LED[2]),
	.LED2			(LED[5])
);

key_filter		key_filter_inst3
(
	.clk			(clk		),
	.reset_n		(reset_n	),
	.key_in		(key_in[3]),
	
	.key_out		(),
	.LED1			(LED[3]),
	.LED2			(LED[4])
);

endmodule

(3)实验现象:

  • 按下S1

  • 按下S2

  • 按下S4

  • 同时按下S2,S3

  • 同时按下S1、S4


http://www.kler.cn/a/448989.html

相关文章:

  • 差分矩阵(Difference Matrix)与累计和矩阵(Running Sum Matrix)的概念与应用:中英双语
  • LAUNCHXL_F28379D_Workspace_CCS124
  • 鸿蒙Next之包体积极限优化
  • 门户系统需要压测吗?以及门户系统如何压力测试?
  • GOC编程 第2课 简单命令---直走和转弯命令
  • Docker环境下MySQL数据库持久化部署全攻略
  • Linux Shell 脚本编程基础
  • VIVO Android面试题及参考答案
  • Sigrity SystemSI仿真分析教程文件路径
  • B2HGraphicBufferProducer和H2BGraphicBufferProducer
  • 专题八:背包问题
  • Windows查看MD5
  • 跨越平台界限:探索Native AOT的交叉编译技术
  • Android 动画深度解析
  • 【Chrome Extension】二、导航栏快速查询
  • 探索CSDN博客数据:使用Python爬虫技术
  • 有没有检测吸烟的软件 ai视频检测分析厂区抽烟报警#Python
  • 自定义一个maven骨架 | 最佳实践
  • JavaScript中函数调用时的参数传递
  • 华为、华三交换机纯Web下如何创关键VLANIF、操作STP参数
  • etcd+京东hotkey探测使用
  • C++ 中的 Lambda 表达式:函数式编程的利器
  • 深入浅出:多功能 Copilot 智能助手如何借助 LLM 实现精准意图识别
  • 关于稀疏数据的模型选择
  • GESP2级2403 小杨的日字矩阵
  • ISP图像处理简介