触摸按键控制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
相关推荐
小眼睛FPGA9 小时前
【紫光HiYou开源入门轻量级PCIE开发板PG2L25G】实验例程1-基于紫光FPGA 的LED 流水灯
fpga开发
不会武功的火柴9 小时前
SystemVerilog语法(8)-有限状态机(FSM)
嵌入式硬件·fpga开发·自动化·ic验证·rtl·uvm方法学
Kent Gu10 小时前
Lattice FPGA选型
fpga开发
Terasic友晶科技14 小时前
答疑解惑|为DE25-Nano开发板配置Linux kernel时.config文件没有起作用是什么原因?
linux·服务器·fpga开发·linux kernel·de25-nano
8K超高清16 小时前
CCBN展会多图回顾
人工智能·算法·fpga开发·接口隔离原则·智能硬件
小眼睛FPGA17 小时前
【紫光HiYou开源入门轻量级PCIE开发板PG2L25G】实验例程5-DDR3 读写实验例程
fpga开发
unicrom_深圳市由你创科技17 小时前
如何做FPGA的功耗优化?动态功耗管理怎么实现?
fpga开发
不会武功的火柴17 小时前
SystemVerilog语法(9)-验证基础与简单Testbench
嵌入式硬件·fpga开发·fpga·systemverilog·硬件描述语言·rtl·uvm验证
kaizq17 小时前
MuleRun助力MakerChip-FPGA在线编程模拟仿真操练
fpga开发·verilog·龙虾机器人·mulerun·makerchip·在线模拟仿真
c-u-r-ry3017 小时前
vivado处理硬件设计差分对布线极性翻转的问题
经验分享·fpga开发