• FPGA计数器边界问题解析


    FPGA计数器边界问题解析
    一次作者在处理AMBE2000数据接收过程中,遇到一个问题,对该计数器边界总是模糊不清。现在予以说明,以警示以后工作时书写错误代码。

    AMBE2000数据一旦准备好后,一次会输出24个字,其中第1个字0x13ec是同步头,连上同步头的前12个字为控制字,后12个字为数据字,我们需要提前数据字,抛弃控制字。作者的解决思路是:当捕获到0x13ec同步头后拉高一个flag,然后计数23次,完成整个接收过程。这其中需要拉个另一个flag,将后12个数据字表示出来。

    问题:除去帧头标志外,还需要去掉11个字。计数器边界到底是卡在10还是11?模棱两可的。

    always @(posedge clk or posedge rst) begin
    	if (rst==1'b1) begin
    		vld_frame_flag<=1'b0;		
    	end
    	else if ( frame_flag==1'b1 && frame_cnt>='d11 ) begin
    		vld_frame_flag<=1'b1;	
    	end
    	else begin
    		vld_frame_flag<=1'b0;	
    	end
    end
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11

    分析:需要去掉11字,那么计数器的边界肯定是11。以上代码验证是拉高时刻是正确的,frame_cnt是在data_vld条件下增加的,所以去掉前11个字,那么cnt11后立即拉高是可以的。也可以如下文所述:上一个时刻frame_cnt10,data_vld又再一次有效,也表示第11个数。

    always @(posedge clk or posedge rst) begin
    	if (rst==1'b1) begin
    		vld_frame_flag<=1'b0;		
    	end
    	else if ( frame_flag==1'b1 && data_lvd==1'b1 && frame_cnt>='d10 ) begin
    		vld_frame_flag<=1'b1;	
    	end
    	else begin
    		vld_frame_flag<=1'b0;	
    	end
    end
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11

    在这里插入图片描述

    结论:为统一期间,计数器的边界判断都需要带上计数条件,要判断n个数,判断条件就是: 条件 && n-1。

  • 相关阅读:
    使用Java统计gitlab代码行数
    【ESP-IDF环境搭建,下载编译第一个程序】
    Python——比 Seaborn 更好的相关性热力图:Biokit Corrplot
    Tomcat的Engine容器
    win7常见问题
    FLASK 模板,渲染变量
    羧基/羟基/氨基/巯基/环氧基/磺酸/胺基/苯基官能团化二氧化硅微球制备研究过程
    HashMap源码解析
    Java:学习Java的最好方法
    机器人、控制领域顶级期刊
  • 原文地址:https://blog.csdn.net/qq_35318223/article/details/132879407