芯路恒电子技术论坛

 找回密码
 立即注册
热搜: 合集
查看: 4379|回复: 0

【设计实例】CMOS摄像头帧率和PCLK频率测量逻辑设计

[复制链接]
  • TA的每日心情
    慵懒
    2021-2-24 10:16
  • 428

    主题

    811

    帖子

    1万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9

    积分
    16107
    QQ
    发表于 2022-8-27 22:29:26 | 显示全部楼层 |阅读模式

    本代码用来测量CMOS 摄像头的帧率和PCLK频率。
    将camera_param_get例化在工程顶层,连接复位、已知频率的一个时钟信号给Clk,并通过名为FCLK的parameter参数来告知该时钟的具体频率。把摄像头的PCLK、VSYNC信号连接到本模块。摄像头工作时就能读到Fps以及Fpclk的值了,Fps是帧率,Fpclk是PCLK频率。
    Fps和Fpclk的值,可以使用ISSP、VIO等JTAG工具在电脑端软件实时查看,也可以通过串口发送给电脑,也可以连接数码管显示驱动显示在数码管上。




    [C#] 纯文本查看 复制代码
    module camera_param_get(
            Clk,
            Rst_n,
            Pclk,
            VSync,
            
            Fps,
            Fpclk
    );
    
            input Clk;
            input Rst_n;
            input Pclk;
            input VSync;
             
            output reg [7:0] Fps;
            output reg[31:0]Fpclk;
            
            parameter FCLK = 50_000_000;
            
            reg [3:0] r_VSync;
            always@(posedge Clk)
                    r_VSync <= {r_VSync[2:0],VSync};
            
            
            reg [31:0]sec_cnt;
            //计时1秒
            always@(posedge Clk or negedge Rst_n)
            if(!Rst_n)
                    sec_cnt <= 0;
            else if(sec_cnt >= FCLK - 1)
                    sec_cnt <= 0;
            else
                    sec_cnt <= sec_cnt + 1'd1;
            
            //计数帧
            reg [7:0] Fps_cnt;
            always@(posedge Clk or negedge Rst_n)
            if(!Rst_n)
                    Fps_cnt <= 0;
            else if(sec_cnt == FCLK - 1)
                    Fps_cnt <= 0;
            else if(r_VSync[3:2] == 2'b01)
                    Fps_cnt <= Fps_cnt + 1'd1;
            else
                    Fps_cnt <= Fps_cnt;
            
            //输出帧统计结果
            always@(posedge Clk)
            if(sec_cnt == FCLK - 1)
                    Fps <= Fps_cnt ;
            else
                    Fps <= Fps;        
            
            //考虑到PCLK有可能高于FCLK,所以先预分频
            reg[7:0]pre_div_cnt;        
            always@(posedge Pclk or negedge Rst_n)
            if(!Rst_n)
                    pre_div_cnt <= 0;
            else
                    pre_div_cnt <= pre_div_cnt + 1'd1;
                    
            reg[3:0]r_pre256_pclk;        
            always@(posedge Clk)
                    r_pre256_pclk <= {r_pre256_pclk[2:0],pre_div_cnt[7]};
            
            reg [23:0]pre_pclk_cnt;
            always@(posedge Clk or negedge Rst_n)
            if(!Rst_n)
                    pre_pclk_cnt <= 0;
            else if(sec_cnt == FCLK - 1)
                    pre_pclk_cnt <= 0;
            else if(r_pre256_pclk[3:2] == 2'b01)
                    pre_pclk_cnt <= pre_pclk_cnt + 1'd1;
            else
                    pre_pclk_cnt <= pre_pclk_cnt;
                    
            always@(posedge Clk or negedge Rst_n)
            if(!Rst_n)        
                    Fpclk <= 0;
            else if(sec_cnt == FCLK - 1)
                    Fpclk <= {pre_pclk_cnt,8'd0};
            else
                    Fpclk <= Fpclk;
                    
    endmodule
    




    testbench

    [C#] 纯文本查看 复制代码
    `timescale 1ns/1ns
    
    module camera_param_get_tb;
    
            reg Clk;
            reg Rst_n;
            reg Pclk;
            reg Vsync;
            reg Href;
       reg [7:0]Data;
             
            wire [7:0] Fps;
            wire [31:0]Fpclk;
            
            camera_param_get camera_param_get(
                    Clk,
                    Rst_n,
                    Pclk,
                    Vsync,
                    
                    Fps,
                    Fpclk
            );
    
            initial Clk = 1;
       always#100 Clk = ~Clk;
            
            initial Pclk = 1;
       always#4 Pclk = ~Pclk;
        
        /*定义时序生成器输出图像的宽和高*/
        parameter WIDTH = 1200;
        parameter HIGHT = 720;
        
        integer i,j;
        
        initial begin
            Rst_n = 0;
            Vsync = 0;
            Href = 0;
            Data = 0;
            #805;
            Rst_n = 1;
            #400;
            repeat(15)begin
                Vsync = 1;
                #320;
                Vsync = 0;
                #800;
                for(i=0;i<HIGHT;i=i+1)begin
                    for(j=0;j<WIDTH*2;j=j+1)begin
                        Href = 1;
                        Data = Data  + 1;
                        #80;
                    end
                    Href = 0;
                    #800;
                end
            end
            $stop;  
        end
    
    
    endmodule
    




    camera_param_get.v (2.36 KB, 下载次数: 227) camera_param_get_tb.v (1.08 KB, 下载次数: 210)


    另外实测,大家使用我们给大家提供的初始化表,帧率设置30帧时候,PCLK为84M,15帧为42M,7.5帧为21M

    回复

    使用道具 举报

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

    本版积分规则

    QQ|小黑屋|Archiver|芯路恒电子技术论坛 |鄂ICP备2021003648号

    GMT+8, 2024-11-21 20:19 , Processed in 0.112566 second(s), 34 queries .

    Powered by Discuz! X3.4

    © 2001-2017 Comsenz Inc. Template By 【未来科技】【 www.wekei.cn 】

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