完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
最近看了一段例程,关于ov7670摄像头显示的。他里面 PCLK是摄像头输出程序的时钟,用来作为采集图像数据的时钟;然后程序又定义了 28mhz的XCLK时钟通过接线输出给ov7670摄像头。我想知道这个XCLK是不是等于PCLK? 也就是说程序定义了28mhz的时钟给XCLK,然后XCLK=PCLK,PCLK时钟控制图像数据的采集???是不是这样 ??求解释?
`timescale 1ns/1ns module CMOS_Capture ( //Global Clock input iCLK, //28MHz input iRST_N, //I2C Initilize Done input Init_Done, //Init Done //Sensor Interface 传感器接口 output CMOS_RST_N, //cmos work state(5ms delay for sccb config) output CMOS_PWDN, //cmos power on output CMOS_XCLK, //28MHz 一般是24mhz 因为图像是800X480 input CMOS_PCLK, //28MHz 数据采集时钟 input [7:0] CMOS_iDATA, //CMOS Data input CMOS_VSYNC, //L: Vaild input CMOS_HREF, //H: Vaild // output Frame_valid_r; //Ouput Sensor Data output reg CMOS_oCLK, //1/2 PCLK output reg [15:0] CMOS_oDATA, //16Bits RGB output reg CMOS_VALID, //Data Enable output reg [7:0] CMOS_FPS_DATA //cmos fps 每秒帧数 ); assign CMOS_RST_N = 1'b1; //cmos work state(5ms delay for sccb config) assign CMOS_PWDN = 1'b0; //cmos power on assign CMOS_XCLK = iCLK; //28MHz XCLK //---------------------------------------------- reg mCMOS_VSYNC; always@(posedge CMOS_PCLK or negedge iRST_N) begin if(!iRST_N) mCMOS_VSYNC <= 1; else mCMOS_VSYNC <= CMOS_VSYNC; //场同步:低电平有效 end wire CMOS_VSYNC_over = ({mCMOS_VSYNC,CMOS_VSYNC} == 2'b01) ? 1'b1 : 1'b0; //VSYNC上升沿结束 //----------------------------------------------------- //Change the sensor data from 8 bits to 16 bits. reg byte_state; //byte state count reg [7:0] Pre_CMOS_iDATA; always@(posedge CMOS_PCLK or negedge iRST_N) begin if(!iRST_N) begin byte_state <= 0; Pre_CMOS_iDATA <= 8'd0; CMOS_oDATA <= 16'd0; end else begin if(~CMOS_VSYNC & CMOS_HREF) //行场有效,{first_byte, second_byte} begin byte_state <= byte_state + 1'b1; //(RGB565 = {first_byte, second_byte}) case(byte_state) 1'b0 : Pre_CMOS_iDATA[7:0] <= CMOS_iDATA; 1'b1 : CMOS_oDATA[15:0] <= {Pre_CMOS_iDATA[7:0], CMOS_iDATA[7:0]}; endcase end else begin byte_state <= 0; Pre_CMOS_iDATA <= 8'd0; CMOS_oDATA <= CMOS_oDATA; end end end //-------------------------------------------- //Wait for Sensor output Data valid, 10 Franme 等待输出数据有效 reg [3:0] Frame_Cont; reg Frame_valid; always@(posedge CMOS_PCLK or negedge iRST_N) begin if(!iRST_N) begin Frame_Cont <= 0; Frame_valid <= 0; end else if(Init_Done) //CMOS I2C初始化完毕 begin if(CMOS_VSYNC_over == 1'b1) //VS上升沿,1帧写入完毕 begin if(Frame_Cont < 10) begin Frame_Cont <= Frame_Cont + 1'b1; Frame_valid <= 1'b0; end else begin Frame_Cont <= Frame_Cont; Frame_valid <= 1'b1; //数据输出有效 end end end end //assign Frame_valid_r = Frame_valid; //----------------------------------------------------- //CMOS_DATA数据同步输出使能时钟 输出给fifo 是1/2 pclk always@(posedge CMOS_PCLK or negedge iRST_N) begin if(!iRST_N) CMOS_oCLK <= 0; else if(Frame_valid == 1'b1 && byte_state)//(X_Cont >= 12'd1 && X_Cont <= H_DISP)) CMOS_oCLK <= ~CMOS_oCLK; else CMOS_oCLK <= 0; end //---------------------------------------------------- //数据输出有效 CMOS_VALID always@(posedge CMOS_PCLK or negedge iRST_N) begin if(!iRST_N) CMOS_VALID <= 0; else if(Frame_valid == 1'b1) CMOS_VALID <= ~CMOS_VSYNC; else CMOS_VALID <= 0; end endmodule |
|
相关推荐
1个回答
|
|
PCLK是像素时钟输出,XCLK是主时钟输入
|
|
|
|
你正在撰写答案
如果你是对答案或其他答案精选点评或询问,请使用“评论”功能。
1415 浏览 1 评论
助力AIoT应用:在米尔FPGA开发板上实现Tiny YOLO V4
1055 浏览 0 评论
2491 浏览 1 评论
2190 浏览 0 评论
矩阵4x4个按键,如何把识别结果按编号01-16(十进制)显示在两个七段数码管上?
2457 浏览 0 评论
1920 浏览 52 评论
6020 浏览 113 评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2024-12-25 01:56 , Processed in 0.583356 second(s), Total 71, Slave 55 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号