"); //-->
零错误零警告的:verilog键盘扫描程序
`TImescale 1ns/1ns
module keyscan(
clk,
rst_n,
sw1_n,
sw2_n,
sw3_n,
//output
led_d3,
led_d4,
led_d5
);
input clk; //主时钟信号,48MHz
input rst_n; //复位信号,低有效
input sw1_n,sw2_n,sw3_n; //三个独立按键,低表示按下
output led_d3,led_d4,led_d5; //发光二极管,分别由按键控制
// ---------------------------------------------------------------------------
reg [19:0] cnt; //计数寄存器
always @ (posedge clk or negedge rst_n)
if (!rst_n) //异步复位
cnt <= 20'd0;
else
cnt <= cnt + 1'b1;
reg [2:0] low_sw;
always @(posedge clk or negedge rst_n)
if (!rst_n)
low_sw <= 3'b111;
else if (cnt == 20'hfffff) //满20ms,将按键值锁存到寄存器low_sw中
low_sw <= {sw3_n,sw2_n,sw1_n};
// ---------------------------------------------------------------------------
reg [2:0] low_sw_r; //每个时钟周期的上升沿将low_sw信号锁存到low_sw_r中
always @ ( posedge clk or negedge rst_n )
if (!rst_n)
low_sw_r <= 3'b111;
else
low_sw_r <= low_sw;
//当寄存器low_sw由1变为0时,led_ctrl的值变为高,维持一个时钟周期
wire [2:0] led_ctrl = low_sw_r[2:0] & ( ~low_sw[2:0]);
reg d1;
reg d2;
reg d3;
always @ (posedge clk or negedge rst_n)
if (!rst_n)
begin
d1 <= 1'b0;
d2 <= 1'b0;
d3 <= 1'b0;
end
else
begin //某个按键值变化时,LED将做亮灭翻转
if ( led_ctrl[0] ) d1 <= ~d1;
if ( led_ctrl[1] ) d2 <= ~d2;
if ( led_ctrl[2] ) d3 <= ~d3;
end
assign led_d5 = d1 ? 1'b1 : 1'b0; //LED翻转输出
assign led_d3 = d2 ? 1'b1 : 1'b0;
assign led_d4 = d3 ? 1'b1 : 1'b0;
endmodule
专栏文章内容及配图由作者撰写发布,仅供工程师学习之用,如有侵权或者其他违规问题,请联系本站处理。 联系我们
相关推荐
铠侠开源软件推动 AI RAG 的发展
欧洲RISC-V处理器开发商Codasip即将出售
恩智浦将目光投向本地代工合作伙伴,以促进中国的全面芯片制造
第十三届全国电源技术年会论文集锦(全系列)
电风扇遥控调速电路
哈佛结构
DSP芯片开发和产品应用(转载)2
exiao_流水灯
SEMI成立先进封装制造联盟
赛灵思Kintex-7收发器操作演示
ceajin_继电器滴答时钟
EDA工具:中国半导体复兴的催化剂
电磁兼容技术培训(杨济深教授讲课稿)
电风扇感应制动开关
台积电无预警退出GaN市场 纳微有望接手美国订单
电风扇控制电路(长城FS11-40)
电磁兼容技术培训
第四届全国电源技术年会论文集
电风扇接近断电保护器
利用赛灵思FPGA解决方案攻克28nm产品设计最大挑战
谈一点学dsp的心得
allan0403_点阵测试、点阵倒计时、花样流水灯
台积电将逐步淘汰其氮化镓业务
大家讨论一下做一个DSP设计的流程吧
电磁兼容基础课程 培训与范例
小米引发的芯片热潮:智能手机和电动汽车芯片大战的新战线
DSP芯片开发和产品应用(转载)1
电风扇控制电路(长城FS7-40)
小米YU7显示器由华星光电和华游集团提供
格拉斯哥市地区获得新的“先进半导体封装和集成中心”的重大胜利