OpenEdv-开源电子网

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

在FPGA中,关于一段程序的不理解问题,为什么要加多一个暂存的寄存器

[复制链接]

4

主题

6

帖子

0

精华

新手上路

积分
21
金钱
21
注册时间
2019-4-7
在线时间
11 小时
发表于 2019-7-25 16:20:02 | 显示全部楼层 |阅读模式
10金钱
在第二十六章频率计实验之中,有一段代码,甚至以前也有相同的问题,就是弄不明白为什么。
原代码如下:

//门控时间内对被测时钟计数
always @(posedge clk_fx or negedge rst_n) begin
    if(!rst_n) begin
        fx_cnt_temp <= 32'd0;
        fx_cnt <= 32'd0;
    end
    else if(gate)
        fx_cnt_temp <= fx_cnt_temp + 1'b1;
    else if(neg_gate_fx) begin
        fx_cnt_temp <= 32'd0;
        fx_cnt   <= fx_cnt_temp;
    end
end


我的问题就是,为什么不能直接操作fx_cnt 加一不就好了吗?
always @(posedge clk_fx or negedge rst_n) begin
    if(!rst_n)
        fx_cnt <= 32'd0;
    else if(gate)
        fx_cnt <= fx_cnt + 1'b1;
    else
        fx_cnt <= fx_cnt;
end


为什么要加多一个fx_cnt_temp来缓存

最佳答案

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

fx_cnt 在程序的其他地方是要用的,而且在频率计计算中统计脉冲期间不能改变。你如果 一直对它进行累加的话,其他地方还怎么用呢
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

9

主题

202

帖子

0

精华

资深版主

Rank: 8Rank: 8

积分
839
金钱
839
注册时间
2018-7-29
在线时间
128 小时
发表于 2019-7-25 16:20:03 | 显示全部楼层
fx_cnt   在程序的其他地方是要用的,而且在频率计计算中统计脉冲期间不能改变。你如果 一直对它进行累加的话,其他地方还怎么用呢
回复

使用道具 举报

9

主题

202

帖子

0

精华

资深版主

Rank: 8Rank: 8

积分
839
金钱
839
注册时间
2018-7-29
在线时间
128 小时
发表于 2019-7-25 20:38:35 | 显示全部楼层
程序不理解的话,可以看看视频讲解
回复

使用道具 举报

4

主题

6

帖子

0

精华

新手上路

积分
21
金钱
21
注册时间
2019-4-7
在线时间
11 小时
 楼主| 发表于 2019-7-26 10:09:19 | 显示全部楼层
SunML 发表于 2019-7-25 20:38
程序不理解的话,可以看看视频讲解

你好,我看了后面的程序,只有在最后计算的时候使用到了
//计算被测信号频率
always @(posedge clk_fs or negedge rst_n) begin
    if(!rst_n) begin
        data_fx <= 20'd0;
    end
    else if(gate_fs == 1'b0)
        data_fx <= (CLK_FS / fs_cnt) * fx_cnt ;
end

在计算的时候,gate_fs已经是低电平了,这个时候应该不会一直累加了吧..
回复

使用道具 举报

9

主题

202

帖子

0

精华

资深版主

Rank: 8Rank: 8

积分
839
金钱
839
注册时间
2018-7-29
在线时间
128 小时
发表于 2019-7-29 09:17:03 | 显示全部楼层
JasonBread 发表于 2019-7-26 10:09
你好,我看了后面的程序,只有在最后计算的时候使用到了
//计算被测信号频率
always @(posedge clk_fs  ...

你仔细看下你那个不用寄存器缓存的写法,你没有对寄存器清零的操作
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2024-10-3 07:22

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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