OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 7718|回复: 5

[ALTERA] vreilog采集下降沿的问题!!!

[复制链接]

7

主题

40

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
267
金钱
267
注册时间
2019-6-2
在线时间
63 小时
发表于 2020-2-14 21:36:19 | 显示全部楼层 |阅读模式
5金钱
本帖最后由 Shari 于 2020-2-17 10:55 编辑

下面是采集按键下降沿部分程序,请问assign语句中的neg_sap变量值什么时候更新?
先执行always语句 key_dy0和key_dy1更新后再更新么?

assign neg_sap  = (~key_dy0 & key_dy1);   // 按键按下时,得到一个周期的高电平信号
always @(posedge clk or negedge rst_n) begin
    if(!rst_n) begin
        key_dy0  <= 1'b1;
        key_dy1  <= 1'b1;
    end
    else begin
        key_dy0 <= key_value;
        key_dy1 <= key_dy0  ;
    end
end

最佳答案

查看完整内容[请看2#楼]

前两天我也在看有关边沿检测的有关资料,开始没搞懂,很多的资料讲得也不是很清楚。如楼上说的,自子画下波形图,去体会下,是能更好理解的。 key_value从1变到0时,neg_sap 会从0更新为1. neg_sap = (~key_dy0 & key_dy1) 1 =( ~ 0 & 1 ) ----->你这样上下对着看下,就明白了。0:key_dy0是当前clk上边沿时刻的值;1:key_dy1是前一clk上边沿是的值(因为是“0所以是下边沿检测了!同时neg_sap ...
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

8

主题

55

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
314
金钱
314
注册时间
2017-1-14
在线时间
48 小时
发表于 2020-2-14 21:36:20 | 显示全部楼层
前两天我也在看有关边沿检测的有关资料,开始没搞懂,很多的资料讲得也不是很清楚。如楼上说的,自子画下波形图,去体会下,是能更好理解的。 key_value从1变到0时,neg_sap 会从0更新为1.
neg_sap  = (~key_dy0 & key_dy1)
        1     =(   ~ 0       &      1     ) ----->你这样上下对着看下,就明白了。0:key_dy0是当前clk上边沿时刻的值;1:key_dy1是前一clk上边沿是的值(因为是“<=”非阻塞赋值)。所以key_value值(   ~ 0       &      1     )从右往左看,就是从先前时刻到当前时刻的变化,即:1--->0所以是下边沿检测了!同时neg_sap的值也就会发生0---->1的更新了。不知这样讲,你理解了吗?我也是小白,刚接触fpga,希望一起提高。
回复

使用道具 举报

7

主题

40

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
267
金钱
267
注册时间
2019-6-2
在线时间
63 小时
 楼主| 发表于 2020-2-17 09:02:55 | 显示全部楼层
有前辈了解的么?求指导 谢谢
回复

使用道具 举报

3

主题

1979

帖子

0

精华

资深版主

Rank: 8Rank: 8

积分
5520
金钱
5520
注册时间
2018-10-21
在线时间
1561 小时
发表于 2020-2-17 10:06:48 | 显示全部楼层
这是个典型的边缘检测电路,你画一下neg_sap、key_dy0和key_dy1的时序图就明白了
回复

使用道具 举报

7

主题

40

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
267
金钱
267
注册时间
2019-6-2
在线时间
63 小时
 楼主| 发表于 2020-2-20 18:09:39 | 显示全部楼层
RAYINGPX 发表于 2020-2-14 21:36
前两天我也在看有关边沿检测的有关资料,开始没搞懂,很多的资料讲得也不是很清楚。如楼上说的,自子画下波 ...

谢谢 确实画一下波形图更好理解 刚接触FPGA 并行的概念还不是太理解 多交流
回复

使用道具 举报

1

主题

21

帖子

0

精华

新手上路

积分
35
金钱
35
注册时间
2019-5-3
在线时间
7 小时
发表于 2020-3-4 12:41:26 | 显示全部楼层
同时进行,然后key_value被延了两拍,上一拍是体现在key_dy0 后一拍体现在 key_dy1,如果有下降沿那说明上一排为负,后一拍为正。so easy!注意时钟能不能采到这个沿的问底。低频时钟不能采高频,会有误差。
回复

使用道具 举报

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

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2024-10-3 09:25

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表