触摸按键控制LED

  1. 触摸按键: 电阻式,电容式(主流),红外感应式,表面声波式
  2. 代码
    input: sys_clk, sys_rst_n, key
    output: led

    FPGA判断上升沿是通过将原信号延迟,再对比获取上升沿

src/touch_led.v

bash 复制代码
module touch_led(
	input 						sys_clk,
	input 						sys_rst_n,
	input 					 	touch_key,

	output 		reg		led		
);

reg touch_key_d0;
reg touch_key_d1;

wire pos_touch_key;
assign pos_touch_key = ~touch_key_d1 & touch_key_d0;//采上升沿

//打两拍,采集上升沿
always @(posedge sys_clk or negedge sys_rst_n) begin
	if(!sys_rst_n) begin
		touch_key_d0 <= 1'd0;
		touch_key_d1 <= 1'd0;
	end
	else begin
		touch_key_d0 <= touch_key; //打两拍
		touch_key_d1 <= touch_key_d0 ;
	end
end

//led信号反转
always @(posedge sys_clk or negedge sys_rst_n) begin
	if(!sys_rst_n) 
		led <= 1'd1;
	else if(pos_touch_key)//上升沿
		led <= ~led;
	else
		led <= led;
end
endmodule

3.仿真代码

sim/tb/tb_touch_led.v

bash 复制代码
`timescale 1ns/1ns

module tb_touch_led();
parameter CLK_PERIOD = 20;//时钟周期

reg 				sys_clk;//需要被赋值,所以定义为reg类型
reg 				sys_rst_n;
reg 	 			touch_key;

wire  			led; //不会被赋值,所以定义为wire型。注意:如果是assign连续赋值,则是对wire类型赋值

initial begin
	sys_clk <= 1'b0;
	sys_rst_n <= 1'b0;
	touch_key <= 1'b0;
	#200  //延时200ns
	sys_rst_n <= 1'b1;

	//模拟按键按下/释放
	#2000
	touch_key <= 1'b1;
	#2000
	touch_key <= 1'b0;
end

always #(CLK_PERIOD/2) sys_clk = ~sys_clk; //每隔10ns取反一次,时间周期20ns

touch_led u_touch_led(
	.sys_clk 				(sys_clk),
	.sys_rst_n 			(sys_rst_n),
	.touch_key 			(touch_key),
	.led 					(led))
endmodule
相关推荐
乌恩大侠43 分钟前
【OAI】 USRP 在conf文件中的配置,RU选项
fpga开发
qq_小单车1 天前
xilinx-DNA
fpga开发·xilinx
Flamingˢ1 天前
FPGA中的嵌入式块存储器RAM:从原理到实现的完整指南
fpga开发
Flamingˢ1 天前
FPGA中的存储器模型:从IP核到ROM的深度解析与应用实例
网络协议·tcp/ip·fpga开发
FPGA小c鸡2 天前
【FPGA深度学习加速】RNN与LSTM硬件加速完全指南:从算法原理到硬件实现
rnn·深度学习·fpga开发
Aaron15882 天前
通信灵敏度计算与雷达灵敏度计算对比分析
网络·人工智能·深度学习·算法·fpga开发·信息与通信·信号处理
博览鸿蒙2 天前
IC 和 FPGA,到底区别在哪?
fpga开发
思尔芯S2C2 天前
FPGA原型验证实战:如何应对外设连接问题
fpga开发·risc-v·soc设计·prototyping·原型验证
Flamingˢ2 天前
FPGA实战:VGA成像原理、时序详解与Verilog控制器设计与验证
fpga开发
FPGA_小田老师2 天前
xilinx原语:OSERDES2(并串转换器)原语详解
fpga开发·lvds·xilinx原语·oserdese·并串转换