OV7670配置和调试小结

时间:2022-09-23 23:04:08

先上一下OV7670的框架图

OV7670配置和调试小结

OV7670常用寄存器设置说明

直接看OV7670 Implementation Guide (V1.0)等

OV7670配置和调试小结

资料我已经上传了

https://files.cnblogs.com/files/libra13179/OV7670%E5%AE%98%E6%96%B9%E6%96%87%E6%A1%A3.zip

我的寄存器配置

struct regval_list {
unsigned char reg_num;
unsigned char value;
};
 static struct regval_list ov7670_default_regs[] =
{
/**
*Frame Rate Adjustment for x Mhz input clock
*x fps, PCLK = xMhz
*/
{0x11, 0x00},// 内部时钟 CLKRC,对于拍照来说,值越大,越清楚,刷屏现像 越不重,摄像时,值过大 会造成跟不上
// 00 时,可能是对于 2.8的屏,对于 2.4屏 会出现 7格分屏现象
// 值越大时,摄头移动 图像拖尾就会越严重,反之OK
// 3值适中,2已有3分屏,0有7分屏,5拖尾重,10已花屏
// [7] 保留
// [6] 直接使用外部时钟(没有预分频)
// [5~0] 内部时钟分频 内部时钟 = 输入时钟/([5~0] + 1) [5~0] = 00000~11111
{0x6b, 0x40},//PLL*4
{0x2a, 0x00},//虚拟像素高位插入
{0x2b, 0x00},//虚拟像素低位插入
{0x92, 0x00},// DM_LNL 空行低8位
{0x93, 0x00},// DM_LNH 空行高8位
{0x3b, 0x02}, //Output format
{0x12, 0x14},//QVGA(320*240)、RGB输出 //RGB555/565 option(must set COM7[2] = 1 and COM7[0] = 0)
{0x40, 0x10},//RGB565,effective only when RGB444[1] is low
{0x8c, 0x00}, /**
*Special effects - 特效
*/
//normal
{0x3a, 0x04},
{0x67, 0xc0},
{0x68, 0x80}, /**
*Mirror/VFlip Enable - 水平镜像/竖直翻转使能
*/
{0x1e, 0x37},//修改配置值将产生图像显示上下或左右颠倒 {0x01, 0x80}, //蓝色通道增益
{0x02, 0x80}, //红色通道增益 /**
* Banding Filter Setting for 24Mhz Input Clock - 条纹滤波器
* 30fps for 60Hz light frequency
*/
{0x13, 0xe0},//banding filer enable
{0x9d, 0x4c},//50Hz banding filer
{0x9e, 0x3f},//60Hz banding filer
{0xa5, 0x05},//3 step for 50Hz
{0xab, 0x07},//4 step for 60Hz
{0x3b, 0x02},//select 60Hz banding filer //Simple White Balance - 白平衡
{0x13, 0xe0},//AWB、AGC、AGC Enable and ...
{0x6f, 0x9f},// AWBCTR0 AWB控制0 //AWBC - 自动白平衡控制(Automatic white balance control)
{0x43, 0x14},//用户手册里这些寄存器的值都是保留(Reserved),不用设置的呀?
{0x44, 0xf0},
{0x45, 0x34},
{0x46, 0x58},
{0x47, 0x28},
{0x48, 0x3a},
//AWB Control
{0x59, 0x88},//用户手册连寄存器都是保留,初始值都没提供
{0x5a, 0x88},
{0x5b, 0x44},
{0x5c, 0x67},
{0x5d, 0x49},
{0x5e, 0x0e},
//AWB Control
{0x6a, 0x40},// G通道 AWB增益
{0x6c, 0x0a},// AWBCTR3 AWB控制3
{0x6d, 0x55},// AWBCTR2 AWB控制2
{0x6e, 0x11},// AWBCTR1 AWB控制1
{0x6f, 0x9f},// AWBCTR0 AWB控制0 //AGC/AEC - Automatic Gain Control自动增益补偿/Automatic exposure Control自动曝光控制
{0x00, 0x00},// AGC 自动增益控制 (值越大 能有效控制 黑像时刷花屏现象)
{0x14, 0x20},//0x38, limit the max gain
{0x24, 0x75},// AEW AGC/AEC稳定运行区域上限
{0x25, 0x63},// AEB AGC/AEC稳定运行区域下限
{0x26, 0xA5},// VPT AGC/AEC快速运行区域 //AEC algorithm selection - AEC公式选择
{0xaa, 0x94},//基于平均值的AEC算法Average-based AEC algorithm/基于直方图的AEC算法Histogram-based AEC algorithm
//基于直方图的AGC/AEC的控制
{0x9f, 0x78},// HAECC1 基于直方图的AEC/AGC控制1
{0xa0, 0x68},// HAECC2 基于直方图的AEC/AGC控制2
{0xa6, 0xdf},// HAECC3 基于直方图的AEC/AGC控制3
{0xa7, 0xdf},// HAECC4 基于直方图的AEC/AGC控制4
{0xa8, 0xf0},// HAECC5 基于直方图的AEC/AGC控制5
{0xa9, 0x90},// HAECC6 基于直方图的AEC/AGC控制6 //Fix Gain Control - 固定增益控制
{0x69, 0x5d},//Fix gain for Gr channel/for Gb channel/for R channel/for B channel //Matrix Coefficient - 色彩矩阵系数
//Color saturation 颜色饱和度 + 0
{0x4f, 0x80},// MTX1 色彩矩阵系数1
{0x50, 0x80},// MTX2 色彩矩阵系数2
{0x51, 0x00},// MTX3 色彩矩阵系数3
{0x52, 0x22},// MTX4 色彩矩阵系数4
{0x53, 0x5e},// MTX5 色彩矩阵系数5
{0x54, 0x80},// MTX6 色彩矩阵系数6
{0x58, 0x9e},// MTXS 色彩矩阵系数5~0的符号 //Brightness - 亮度 + 0
{0x55, 0x00}, //亮度控制 //Contrast - 对比度 + 0
{0x56, 0x60},//对比度
{0x57, 0x80},//对比度中心 /*Gamma Curve - 伽马曲线*/
{0x7a, 0x20},
{0x7b, 0x1c},
{0x7c, 0x28},
{0x7d, 0x3c},
{0x7e, 0x55},
{0x7f, 0x68},
{0x80, 0x76},
{0x81, 0x80},
{0x82, 0x88},
{0x83, 0x8f},
{0x84, 0x96},
{0x85, 0xa3},
{0x86, 0xaf},
{0x87, 0xc4},
{0x88, 0xd7},
{0x89, 0xe8}, /**
*Lens Correction Option - 镜头补偿选项
*/
{0x62, 0x00};// LCC1 镜头补偿选项1
{0x63, 0x00};// LCC2 镜头补偿选项2
{0x64, 0x04},// LCC3 镜头补偿选项3
{0x65, 0x20},// LCC4 镜头补偿选项4
{0x66, 0x05},// LCC5 镜头补偿选项5
{0x94, 0x04},// LCC6 镜头校正选项(在LCC5[2]=1有效)
{0x95, 0x08},// LCC7 镜头校正选项(在LCC5[2]=1有效) //输出窗口设置
//注释这些配置的话,就倾斜显示,并显示多块,这到底是控制什么的?跟时序图有关?
{0x17, 0x16},// HSTART 行输出格式 行帧(HREF列)起始的高8位(低3位在HREF[2~0])
{0x18, 0x04},// HSTOP 行输出格式 行帧(HREF列)结束的高位(低3位在HREF[5~3])
{0x19, 0x02},// VSTRT 场输出格式 场帧(行)起始的高8位(低2位在VREF[1~0])
{0x1a, 0x7a},// VSTOP 场输出格式 场帧(行)结束的高8位(低2位在VREF[3~2]) {0x32, 0x80},// HREF 控制
{0x03, 0x0a},// VREF 场帧控制 //注释这个配置的话,就显示花屏了
{0x15, 0x00},//配置PCLK、HREF、VSYNC相关 //Automatic black Level Compensation - 自动黑电平校正
{0xb0, 0x84},//调试时注释这项配置时,颜色显示不正常了,红色练绿色,绿色变红色,但用户手册对这寄存器是保留RSVD {0xb1, 0x0c},// ABLC1
{0xb2, 0x0e},//保留 {0xb3, 0x82},//ABLC target
{0xb8, 0x0a},// 保留 //SCALING_xx寄存器
{0x70, 0x00},//SCALING_XSC,水平缩放系数
{0x71, 0x00},//SCALING_YSC,垂直缩放系数
{0x72, 0x11}, //SCALING_DCWCTR,DCW 控制
{0x73, 0x00},//SCALING_PC,旁路 DSP 缩放时钟分频控制
{0xa2, 0x02},//SCALING_PCLK_DELAY,像素始终延迟
{0x3e, 0x00},// COM14 通用控制14
// [7~5] 保留
// [4] DCW 和 PCLK 控制: 0 正常的 PCLK 1 DCW和PCLK由COM12[2~0]及SCALING_PCLK_DIV[3~0](0X73)控制
// [3] 手动缩放控制,应用于预定尺寸(CIF QCIF QVGA)时:0 禁止手动缩放 1 允许手动缩放
// [2~0] PCLK分频 (在COM14[4]为1时有效)
// 000 /1
// 001 /2
// 010 /4
// 011 /8
// 100 /16
// 101~111 不允许 //ADC
{0x37, 0x1d},//ADC控制ADC Control
{0x38, 0x71},//ADC和模拟共模控制ADC and Analog Common Mode Control
{0x39, 0x2a},//ADC偏移控制ADC Offset Control //零杂的寄存器 {0x0c, 0x0c},// COM3 通用控制3
// [7] 保留
// [6] 输出数据进行 MSB和LSB 交换
// [5] 掉电期间输出时钟的状态 0 三态时钟 1 非三态时钟
// [4] 掉电期音输出数据的状态 0 三态数据 1 非三态数据
// [3] 缩放 0 禁止 1 使能(若设置(COM7[5~3])成预定模式的像时,然后将COM14[3]设成1 即可手动调节)
// [2] DCW控制 0 禁止 1 使能(若设置(COM7[5~3])成预定模式的像时,然后将COM14[3]设成1 即可手动调节)
// [1~0] 保留 {0x10, 0x00},// AECH 曝光值 {0x0d, 0x00}, {0x0f, 0x4b}, {0x3c, 0x78},//COM12 通用控制12
// [7] HERF操作 0 在VSYNC为低时没有HREF 1 HREF总是存在
// [6~0] 保留 {0x74, 0x19}, //用户手册里这几个寄存器都是保留RSVD
{0x0e, 0x61},
{0x16, 0x02},
{0x21, 0x02},// ADCCTR1 保留
{0x22, 0x91},// ADCCTR2 保留
{0x29, 0x07},// ADCCTR3 保留
{0x33, 0x0b},// CHLF 感光阵列电流控制 保留
{0x35, 0x0b},
{0x4d, 0x40},
{0x4e, 0x20},
{0x8d, 0x4f},
{0x8e, 0x00},
{0x8f, 0x00},
{0x90, 0x00},
{0x91, 0x00},
{0x96, 0x00},
{0x9a, 0x80},
{0x97, 0x30},
{0x98, 0x20},
{0x99, 0x30},
{0x9b, 0x29},
{0x9c, 0x03},
};