⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 pac207.h

📁 Linux下面摄像头最新源代码:支持200多中摄像头
💻 H
字号:
#ifndef PAC207USB_H#define PAC207USB_H/****************************************************************************#	 	Pixart PAC207BCA library                                    ## 		Copyright (C) 2005 Thomas Kaiser thomas@kaiser-linux.li     ##               Copyleft (C) 2005 Michel Xhaard mxhaard@magic.fr            ##                                                                           ## This program is free software; you can redistribute it and/or modify      ## it under the terms of the GNU General Public License as published by      ## the Free Software Foundation; either version 2 of the License, or         ## (at your option) any later version.                                       ##                                                                           ## This program is distributed in the hope that it will be useful,           ## but WITHOUT ANY WARRANTY; without even the implied warranty of            ## MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the             ## GNU General Public License for more details.                              ##                                                                           ## You should have received a copy of the GNU General Public License         ## along with this program; if not, write to the Free Software               ## Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA ##                                                                           #****************************************************************************/static __u8 pac207_sensor_init[][8] = {    {0x10, 0x12, 0x0d, 0x12, 0x0c, 0x01, 0x29, 0xf0},	//2   //{0x10, 0x24, 0x06, 0x12, 0x0c, 0x01, 0x29, 0xf0},	//2 increase the times exposure decrease frame rate    {0x00, 0x64, 0x64, 0x64, 0x04, 0x10, 0xF0, 0x30},	//a reg_10 digital gain Red Green Blue Ggain    {0x00, 0x00, 0x00, 0x70, 0xA0, 0xF8, 0x00, 0x00},	//12    {0x00, 0x00, 0x32, 0x00, 0x96, 0x00, 0xA2, 0x02},	//40    {0x32, 0x00, 0x96, 0x00, 0xA2, 0x02, 0xAF, 0x00},	//42 reg_66 rate control};static __u8 PacReg72[] = { 0x00, 0x00, 0x36, 0x00 };	//48 reg_72 Rate Control end BalSize_4a =0x36/*******************     Camera Interface   ***********************/static __u16 pac207_getbrightness(struct usb_spca50x *spca50x);static __u16 pac207_getcontrast(struct usb_spca50x *spca50x);static __u16 pac207_getcolors(struct usb_spca50x *spca50x);static void pac207_setbrightness(struct usb_spca50x *spca50x);static void pac207_setcontrast(struct usb_spca50x *spca50x);static void pac207_setcolors(struct usb_spca50x *spca50x);static int pac207_init(struct usb_spca50x *spca50x);static void pac207_start(struct usb_spca50x *spca50x);static void pac207_stopN(struct usb_spca50x *spca50x);static void pac207_stop0(struct usb_spca50x *spca50x);static int pac207_config(struct usb_spca50x *spca50x);static void pac207_shutdown(struct usb_spca50x *spca50x);static void pac207_setAutobright(struct usb_spca50x *spca50x);static void pac207_setquality(struct usb_spca50x *spca50x);static int pac207_sofdetect(struct usb_spca50x *spca50x,struct spca50x_frame *frame, unsigned char *cdata,int *iPix, int seqnum, int *datalength);/*******************************************************************/static __u16 pac207_getcolors(struct usb_spca50x *spca50x){return 0 ;}static void pac207_setcolors(struct usb_spca50x *spca50x){ spca50x->colour = 0;}static void pac207_stop0(struct usb_spca50x *spca50x){}static void pac207_setquality(struct usb_spca50x *spca50x){}/*******************     Camera Private     ***********************/static void pac207_reg_write(struct usb_device *dev, __u16 index,			     __u16 value);static void pac207_reg_read(struct usb_device *dev, __u16 index,			    __u8 * buffer);/***************************** Implementation ****************************/static struct cam_operation fpac207 = { 	.initialize = pac207_init,	.configure = pac207_config,	.start = pac207_start,	.stopN = pac207_stopN,	.stop0 = pac207_stop0,	.get_bright = pac207_getbrightness,	.set_bright = pac207_setbrightness,	.get_contrast = pac207_getcontrast,	.set_contrast = pac207_setcontrast,	.get_colors = pac207_getcolors,	.set_colors = pac207_setcolors,	.set_autobright = pac207_setAutobright,	.set_quality = pac207_setquality,	.cam_shutdown = pac207_shutdown,	.sof_detect = pac207_sofdetect, };static void pac207_reg_read(struct usb_device *dev, __u16 index,			    __u8 * buffer){    pac207RegRead(dev, 0x00, 0x00, index, buffer, 1);    return;}static void pac207_reg_write(struct usb_device *dev, __u16 index,			     __u16 value){    pac207RegWrite(dev, 0x00, value, index, NULL, 0);    return;}static __u16 pac207_getbrightness(struct usb_spca50x *spca50x){    __u8 brightness = 0;    pac207_reg_read(spca50x->dev, 0x0008, &brightness);    spca50x->brightness = brightness << 8;    return spca50x->brightness;}static __u16 pac207_getcontrast(struct usb_spca50x *spca50x){    __u8 contrast = 0;    pac207_reg_read(spca50x->dev, 0x000e, &contrast);    spca50x->contrast = contrast << 11;    return spca50x->contrast;}static void pac207_setcontrast(struct usb_spca50x *spca50x){    __u8 contrast = spca50x->contrast >> 11;    pac207_reg_write(spca50x->dev, 0x000e, contrast);    pac207_reg_write(spca50x->dev, 0x13, 0x01);	//load registers to sensor (Bit 0, auto clear)    pac207_reg_write(spca50x->dev, 0x1c, 0x01);	//not documented}static void pac207_setbrightness(struct usb_spca50x *spca50x){    __u8 brightness = spca50x->brightness >> 8;    pac207_reg_write(spca50x->dev, 0x0008, brightness);    pac207_reg_write(spca50x->dev, 0x13, 0x01);	//load registers to sensor (Bit 0, auto clear)    pac207_reg_write(spca50x->dev, 0x1c, 0x01);	//not documented}static int pac207_init(struct usb_spca50x *spca50x){    __u8 id[] = { 0, 0 };    pac207_reg_write(spca50x->dev, 0x41, 0x00);	//Turn of LED    pac207_reg_read(spca50x->dev, 0x0000, &id[0]);    pac207_reg_read(spca50x->dev, 0x0001, &id[1]);    id[0] = ((id[0] & 0x0F) << 4) | ((id[1] & 0xf0) >> 4);    id[1] = id[1] & 0x0f;    PDEBUG(2, " Pixart Sensor ID 0x%02X Chips ID 0x%02X !!\n", id[0],	   id[1]);    if (id[0] != 0x27 || id[1] != 0x00)	return -ENODEV;    return 0;}static void set_pac207SIF(struct usb_spca50x *spca50x){    memset(spca50x->mode_cam, 0x00, TOTMODE * sizeof(struct mwebcam));    spca50x->mode_cam[SIF].width = 352;    spca50x->mode_cam[SIF].height = 288;    spca50x->mode_cam[SIF].t_palette =	P_RAW | P_YUV420 | P_RGB32 | P_RGB24 | P_RGB16;    spca50x->mode_cam[SIF].pipe = 1023;    spca50x->mode_cam[SIF].method = 0;    spca50x->mode_cam[SIF].mode = 0;    spca50x->mode_cam[CIF].width = 320;    spca50x->mode_cam[CIF].height = 240;    spca50x->mode_cam[CIF].t_palette =	P_YUV420 | P_RGB32 | P_RGB24 | P_RGB16;    spca50x->mode_cam[CIF].pipe = 1023;    spca50x->mode_cam[CIF].method = 1;    spca50x->mode_cam[CIF].mode = 0;    spca50x->mode_cam[QPAL].width = 192;    spca50x->mode_cam[QPAL].height = 144;    spca50x->mode_cam[QPAL].t_palette =	P_YUV420 | P_RGB32 | P_RGB24 | P_RGB16;    spca50x->mode_cam[QPAL].pipe = 1023;    spca50x->mode_cam[QPAL].method = 1;    spca50x->mode_cam[QPAL].mode = 1;    spca50x->mode_cam[QSIF].width = 176;    spca50x->mode_cam[QSIF].height = 144;    spca50x->mode_cam[QSIF].t_palette =	P_RAW | P_YUV420 | P_RGB32 | P_RGB24 | P_RGB16;    spca50x->mode_cam[QSIF].pipe = 1023;    spca50x->mode_cam[QSIF].method = 0;    spca50x->mode_cam[QSIF].mode = 1;    spca50x->mode_cam[QCIF].width = 160;    spca50x->mode_cam[QCIF].height = 120;    spca50x->mode_cam[QCIF].t_palette =	P_YUV420 | P_RGB32 | P_RGB24 | P_RGB16;    spca50x->mode_cam[QCIF].pipe = 1023;    spca50x->mode_cam[QCIF].method = 1;    spca50x->mode_cam[QCIF].mode = 1;    return;}static int pac207_config(struct usb_spca50x *spca50x){    PDEBUG(2, "Find Sensor PAC207");    spca50x->sensor = SENSOR_PAC207;    set_pac207SIF(spca50x);    pac207_reg_write(spca50x->dev, 0x41, 0x00);	//00 Bit_0=Image Format, Bit_1=LED, Bit_2=Compression test mode enable    pac207_reg_write(spca50x->dev, 0x0f, 0x00);	//Power Control    pac207_reg_write(spca50x->dev, 0x11, 0x30);	//Analog Bias    return 0;}static void pac207_start(struct usb_spca50x *spca50x){    __u8 buffer;    __u8 mode;    pac207_reg_write(spca50x->dev, 0x0f, 0x10);	//Power control (Bit 6-0)    pac207RegWrite(spca50x->dev, 0x01, 0, 0x0002, pac207_sensor_init[0],		   8);    pac207RegWrite(spca50x->dev, 0x01, 0, 0x000a, pac207_sensor_init[1],		   8);    pac207RegWrite(spca50x->dev, 0x01, 0, 0x0012, pac207_sensor_init[2],		   8);    pac207RegWrite(spca50x->dev, 0x01, 0, 0x0040, pac207_sensor_init[3],		   8);    pac207RegWrite(spca50x->dev, 0x01, 0, 0x0042, pac207_sensor_init[4],		   8);    pac207RegWrite(spca50x->dev, 0x01, 0, 0x0048, PacReg72, 4);    if (spca50x->compress) {	pac207_reg_write(spca50x->dev, 0x4a, 0x88);	//Compression Balance size 0x88    } else {	pac207_reg_write(spca50x->dev, 0x4a, 0xff);	//Compression Balance size    }    pac207_reg_write(spca50x->dev, 0x4b, 0x00);	//Sram test value    pac207_reg_write(spca50x->dev, 0x13, 0x01);	//load registers to sensor (Bit 0, auto clear)    pac207_reg_write(spca50x->dev, 0x1c, 0x01);	//not documented    pac207_reg_write(spca50x->dev, 0x41, 0x02);	//Image Format (Bit 0), LED (Bit 1), Compression test mode enable (Bit 2)    if (spca50x->mode) {	/* 176x144 */	pac207_reg_read(spca50x->dev, 0x41, &buffer);	mode = buffer | 0x01;	//mode = buffer | 0x00;	pac207_reg_write(spca50x->dev, 0x41, mode);	//Set mode	pac207_reg_write(spca50x->dev, 0x02, 0x04);	//PXCK = 12MHz /n	pac207_reg_write(spca50x->dev, 0x0e, 0x0f);	//PGA global gain (Bit 4-0)	pac207_reg_write(spca50x->dev, 0x13, 0x01);	//load registers to sensor (Bit 0, auto clear)	pac207_reg_write(spca50x->dev, 0x1c, 0x01);	//not documented	PDEBUG(1, "pac207_start mode 176x144, mode = %x", mode);    } else {	/* 352x288 */	pac207_reg_read(spca50x->dev, 0x41, &buffer);	mode = buffer & 0xfe;	pac207_reg_write(spca50x->dev, 0x41, mode);	//Set mode	if (spca50x->compress) {	    pac207_reg_write(spca50x->dev, 0x02, 0x04);	//PXCK = 12MHz / n 04	} else {	    pac207_reg_write(spca50x->dev, 0x02, 0x0a);	//PXCK = 12MHz / n	}	pac207_reg_write(spca50x->dev, 0x0e, 0x04);	//PGA global gain (Bit 4-0)	pac207_reg_write(spca50x->dev, 0x13, 0x01);	//load registers to sensor (Bit 0, auto clear)	pac207_reg_write(spca50x->dev, 0x1c, 0x01);	//not documented	PDEBUG(1, "pac207_start mode 352x288, mode = %x", mode);    }    udelay(1000);    pac207_reg_write(spca50x->dev, 0x40, 0x01);	//Start ISO pipe//      pac207_setbrightness(spca50x);    return;}static void pac207_stopN(struct usb_spca50x *spca50x){    pac207_reg_write(spca50x->dev, 0x40, 0x00);	//Stop ISO pipe    pac207_reg_write(spca50x->dev, 0x41, 0x00);	//Turn of LED    pac207_reg_write(spca50x->dev, 0x0f, 0x00);	//Power Control    return;}static void pac207_shutdown(struct usb_spca50x *spca50x){    pac207_reg_write(spca50x->dev, 0x41, 0x00);	//Turn of LED    pac207_reg_write(spca50x->dev, 0x0f, 0x00);	//Power Control    return;}#ifdef GSPCA_ENABLE_REGISTERPLAYstatic void pac207_RegRead(struct usb_spca50x *spca50x){    __u8 buffer;    RegAddress = RegAddress & 0xff;    pac207_reg_read(spca50x->dev, RegAddress, &buffer);    RegValue = buffer;    PDEBUG(0, "pac207_ReadReg, Reg 0x%02X value = %x", RegAddress,	   RegValue);    return;}static void pac207_RegWrite(struct usb_spca50x *spca50x){    __u8 buffer;    RegAddress = RegAddress & 0xff;    buffer = RegValue & 0xff;    pac207_reg_write(spca50x->dev, RegAddress, buffer);    pac207_reg_write(spca50x->dev, 0x13, 0x01);	//load registers to sensor (Bit 0, auto clear)    pac207_reg_write(spca50x->dev, 0x1c, 0x01);	//not documented    PDEBUG(0, "pac207_WriteReg,Reg 0x%02X value = %x", RegAddress, buffer);    return;}#endif	#define BLIMIT(bright) (__u8)((bright>0x1a)?0x1a:((bright < 4)? 4:bright))static void pac207_setAutobright(struct usb_spca50x *spca50x){    unsigned long flags;    __u8 luma = 0;    __u8 luma_mean = 128;    __u8 luma_delta = 20;    __u8 spring = 5;    __u8 Pxclk;    int Gbright = 0;            pac207_reg_read(spca50x->dev, 0x02, &Pxclk);    Gbright = Pxclk;    spin_lock_irqsave(&spca50x->v4l_lock, flags);    luma = spca50x->avg_lum;    spin_unlock_irqrestore(&spca50x->v4l_lock, flags);        PDEBUG(2, "Pac207 lumamean %d", luma);    if ((luma < (luma_mean - luma_delta)) ||	(luma > (luma_mean + luma_delta))) {	Gbright += ((luma_mean - luma) >> spring);	Gbright = BLIMIT(Gbright);	PDEBUG(2, "Pac207 Gbright %d", Gbright);	pac207_reg_write(spca50x->dev, 0x02,(__u8) Gbright);	pac207_reg_write(spca50x->dev, 0x13, 0x01);	//load registers to sensor (Bit 0, auto clear)	pac207_reg_write(spca50x->dev, 0x1c, 0x01);	//not documented    }}#undef BLIMITstatic int pac207_sofdetect(struct usb_spca50x *spca50x,struct spca50x_frame *frame, unsigned char *cdata,int *iPix, int seqnum, int *datalength){				int sof = 0;		int p = 0;		if (*datalength < 6)		    return -1;		else {		    for (p = 0; p < *datalength - 6; p++) {			if ((cdata[0 + p] == 0xFF)			    && (cdata[1 + p] == 0xFF)			    && (cdata[2 + p] == 0x00)			    && (cdata[3 + p] == 0xFF)			    && (cdata[4 + p] == 0x96)			    ) {			    sof = 1;			    break;			}		    }		    if (sof) {#if 1		spin_lock(&spca50x->v4l_lock);		spca50x->avg_lum = cdata[p+9] ;		spin_unlock(&spca50x->v4l_lock);		PDEBUG(5, "mean luma %d", spca50x->avg_lum);#endif			// copy the end of data to the current frame			memcpy(frame->highwater, cdata, p);			frame->highwater += p;			//totlen += p;			*iPix = p;	//copy to the nextframe start at p			*datalength -= *iPix;			PDEBUG(5,			       "Pixartcam header packet found, %d datalength %d !!",			       p, *datalength );			return 0;		    } else {		    *iPix = 0;			return (seqnum+1);		    }		}}			/* GSPCA_ENABLE_REGISTERPLAY */#endif				// PAC207USB_H

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -