亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? ov511.c

?? ov511.c是linux下的wabcam的驅動
?? C
?? 第 1 頁 / 共 5 頁
字號:
/* Matches the sensor's internal frame rate to the lighting frequency. * Valid frequencies are: *	50 - 50Hz, for European and Asian lighting *	60 - 60Hz, for American lighting * * Tested with: OV7610, OV7620, OV76BE, OV6620 * Unsupported: KS0127, KS0127B, SAA7111A * Returns: 0 for success */static intsensor_set_light_freq(struct usb_ov511 *ov, int freq){	int sixty;	PDEBUG(4, "%d Hz", freq);	if (freq == 60)		sixty = 1;	else if (freq == 50)		sixty = 0;	else {		err("Invalid light freq (%d Hz)", freq);		return -EINVAL;	}	switch (ov->sensor) {	case SEN_OV7610:		i2c_w_mask(ov, 0x2a, sixty?0x00:0x80, 0x80);		i2c_w(ov, 0x2b, sixty?0x00:0xac);		i2c_w_mask(ov, 0x13, 0x10, 0x10);		i2c_w_mask(ov, 0x13, 0x00, 0x10);		break;	case SEN_OV7620:	case SEN_OV76BE:	case SEN_OV8600:		i2c_w_mask(ov, 0x2a, sixty?0x00:0x80, 0x80);		i2c_w(ov, 0x2b, sixty?0x00:0xac);		i2c_w_mask(ov, 0x76, 0x01, 0x01);		break;	case SEN_OV6620:	case SEN_OV6630:		i2c_w(ov, 0x2b, sixty?0xa8:0x28);		i2c_w(ov, 0x2a, sixty?0x84:0xa4);		break;	case SEN_KS0127:	case SEN_KS0127B:	case SEN_SAA7111A:		PDEBUG(5, "Unsupported with this sensor");		return -EPERM;	default:		err("Sensor not supported for set_light_freq");		return -EINVAL;	}	ov->lightfreq = freq;	return 0;}/* If enable is true, turn on the sensor's banding filter, otherwise turn it * off. This filter tries to reduce the pattern of horizontal light/dark bands * caused by some (usually fluorescent) lighting. The light frequency must be * set either before or after enabling it with ov51x_set_light_freq(). * * Tested with: OV7610, OV7620, OV76BE, OV6620. * Unsupported: KS0127, KS0127B, SAA7111A * Returns: 0 for success */static inline intsensor_set_banding_filter(struct usb_ov511 *ov, int enable){	int rc;	PDEBUG(4, " (%s)", enable ? "turn on" : "turn off");	if (ov->sensor == SEN_KS0127 || ov->sensor == SEN_KS0127B		|| ov->sensor == SEN_SAA7111A) {		PDEBUG(5, "Unsupported with this sensor");		return -EPERM;	}	rc = i2c_w_mask(ov, 0x2d, enable?0x04:0x00, 0x04);	if (rc < 0)		return rc;	ov->bandfilt = enable;	return 0;}/* If enable is true, turn on the sensor's auto brightness control, otherwise * turn it off. * * Unsupported: KS0127, KS0127B, SAA7111A * Returns: 0 for success */static inline intsensor_set_auto_brightness(struct usb_ov511 *ov, int enable){	int rc;	PDEBUG(4, " (%s)", enable ? "turn on" : "turn off");	if (ov->sensor == SEN_KS0127 || ov->sensor == SEN_KS0127B		|| ov->sensor == SEN_SAA7111A) {		PDEBUG(5, "Unsupported with this sensor");		return -EPERM;	}	rc = i2c_w_mask(ov, 0x2d, enable?0x10:0x00, 0x10);	if (rc < 0)		return rc;	ov->auto_brt = enable;	return 0;}/* If enable is true, turn on the sensor's auto exposure control, otherwise * turn it off. * * Unsupported: KS0127, KS0127B, SAA7111A * Returns: 0 for success */static inline intsensor_set_auto_exposure(struct usb_ov511 *ov, int enable){	PDEBUG(4, " (%s)", enable ? "turn on" : "turn off");	switch (ov->sensor) {	case SEN_OV7610:		i2c_w_mask(ov, 0x29, enable?0x00:0x80, 0x80);		break;	case SEN_OV6620:	case SEN_OV7620:	case SEN_OV76BE:	case SEN_OV8600:		i2c_w_mask(ov, 0x13, enable?0x01:0x00, 0x01);		break;	case SEN_OV6630:		i2c_w_mask(ov, 0x28, enable?0x00:0x10, 0x10);		break;	case SEN_KS0127:	case SEN_KS0127B:	case SEN_SAA7111A:		PDEBUG(5, "Unsupported with this sensor");		return -EPERM;	default:		err("Sensor not supported for set_auto_exposure");		return -EINVAL;	}	ov->auto_exp = enable;	return 0;}/* Modifies the sensor's exposure algorithm to allow proper exposure of objects * that are illuminated from behind. * * Tested with: OV6620, OV7620 * Unsupported: OV7610, OV76BE, KS0127, KS0127B, SAA7111A * Returns: 0 for success */static intsensor_set_backlight(struct usb_ov511 *ov, int enable){	PDEBUG(4, " (%s)", enable ? "turn on" : "turn off");	switch (ov->sensor) {	case SEN_OV7620:	case SEN_OV8600:		i2c_w_mask(ov, 0x68, enable?0xe0:0xc0, 0xe0);		i2c_w_mask(ov, 0x29, enable?0x08:0x00, 0x08);		i2c_w_mask(ov, 0x28, enable?0x02:0x00, 0x02);		break;	case SEN_OV6620:		i2c_w_mask(ov, 0x4e, enable?0xe0:0xc0, 0xe0);		i2c_w_mask(ov, 0x29, enable?0x08:0x00, 0x08);		i2c_w_mask(ov, 0x0e, enable?0x80:0x00, 0x80);		break;	case SEN_OV6630:		i2c_w_mask(ov, 0x4e, enable?0x80:0x60, 0xe0);		i2c_w_mask(ov, 0x29, enable?0x08:0x00, 0x08);		i2c_w_mask(ov, 0x28, enable?0x02:0x00, 0x02);		break;	case SEN_OV7610:	case SEN_OV76BE:	case SEN_KS0127:	case SEN_KS0127B:	case SEN_SAA7111A:		PDEBUG(5, "Unsupported with this sensor");		return -EPERM;	default:		err("Sensor not supported for set_backlight");		return -EINVAL;	}	ov->backlight = enable;	return 0;}static inline intsensor_set_mirror(struct usb_ov511 *ov, int enable){	PDEBUG(4, " (%s)", enable ? "turn on" : "turn off");	switch (ov->sensor) {	case SEN_OV6620:	case SEN_OV6630:	case SEN_OV7610:	case SEN_OV7620:	case SEN_OV76BE:	case SEN_OV8600:		i2c_w_mask(ov, 0x12, enable?0x40:0x00, 0x40);		break;	case SEN_KS0127:	case SEN_KS0127B:	case SEN_SAA7111A:		PDEBUG(5, "Unsupported with this sensor");		return -EPERM;	default:		err("Sensor not supported for set_mirror");		return -EINVAL;	}	ov->mirror = enable;	return 0;}/* Returns number of bits per pixel (regardless of where they are located; * planar or not), or zero for unsupported format. */static inline intget_depth(int palette){	switch (palette) {	case VIDEO_PALETTE_GREY:    return 8;	case VIDEO_PALETTE_YUV420:  return 12;	case VIDEO_PALETTE_YUV420P: return 12; /* Planar */	case VIDEO_PALETTE_RGB565:  return 16;	case VIDEO_PALETTE_RGB24:   return 24;	case VIDEO_PALETTE_YUV422:  return 16;	case VIDEO_PALETTE_YUYV:    return 16;	case VIDEO_PALETTE_YUV422P: return 16; /* Planar */	default:		    return 0;  /* Invalid format */	}}/* Bytes per frame. Used by read(). Return of 0 indicates error */static inline long intget_frame_length(struct ov511_frame *frame){	if (!frame)		return 0;	else		return ((frame->width * frame->height			 * get_depth(frame->format)) >> 3);}static intmode_init_ov_sensor_regs(struct usb_ov511 *ov, int width, int height,			 int mode, int sub_flag, int qvga){	int clock;	/******** Mode (VGA/QVGA) and sensor specific regs ********/	switch (ov->sensor) {	case SEN_OV7610:		i2c_w(ov, 0x14, qvga?0x24:0x04);// FIXME: Does this improve the image quality or frame rate?#if 0		i2c_w_mask(ov, 0x28, qvga?0x00:0x20, 0x20);		i2c_w(ov, 0x24, 0x10);		i2c_w(ov, 0x25, qvga?0x40:0x8a);		i2c_w(ov, 0x2f, qvga?0x30:0xb0);		i2c_w(ov, 0x35, qvga?0x1c:0x9c);#endif		break;	case SEN_OV7620://		i2c_w(ov, 0x2b, 0x00);		i2c_w(ov, 0x14, qvga?0xa4:0x84);		i2c_w_mask(ov, 0x28, qvga?0x00:0x20, 0x20);		i2c_w(ov, 0x24, qvga?0x20:0x3a);		i2c_w(ov, 0x25, qvga?0x30:0x60);		i2c_w_mask(ov, 0x2d, qvga?0x40:0x00, 0x40);		i2c_w_mask(ov, 0x67, qvga?0xf0:0x90, 0xf0);		i2c_w_mask(ov, 0x74, qvga?0x20:0x00, 0x20);		break;	case SEN_OV76BE://		i2c_w(ov, 0x2b, 0x00);		i2c_w(ov, 0x14, qvga?0xa4:0x84);// FIXME: Enable this once 7620AE uses 7620 initial settings#if 0		i2c_w_mask(ov, 0x28, qvga?0x00:0x20, 0x20);		i2c_w(ov, 0x24, qvga?0x20:0x3a);		i2c_w(ov, 0x25, qvga?0x30:0x60);		i2c_w_mask(ov, 0x2d, qvga?0x40:0x00, 0x40);		i2c_w_mask(ov, 0x67, qvga?0xb0:0x90, 0xf0);		i2c_w_mask(ov, 0x74, qvga?0x20:0x00, 0x20);#endif		break;	case SEN_OV6620:		i2c_w(ov, 0x14, qvga?0x24:0x04);		break;	case SEN_OV6630:		i2c_w(ov, 0x14, qvga?0xa0:0x80);		break;	default:		err("Invalid sensor");		return -EINVAL;	}	/******** Palette-specific regs ********/	if (mode == VIDEO_PALETTE_GREY) {		if (ov->sensor == SEN_OV7610 || ov->sensor == SEN_OV76BE) {			/* these aren't valid on the OV6620/OV7620/6630? */			i2c_w_mask(ov, 0x0e, 0x40, 0x40);		}		if (ov->sensor == SEN_OV6630 && ov->bridge == BRG_OV518		    && ov518_color) {			i2c_w_mask(ov, 0x12, 0x00, 0x10);			i2c_w_mask(ov, 0x13, 0x00, 0x20);		} else {			i2c_w_mask(ov, 0x13, 0x20, 0x20);		}	} else {		if (ov->sensor == SEN_OV7610 || ov->sensor == SEN_OV76BE) {			/* not valid on the OV6620/OV7620/6630? */			i2c_w_mask(ov, 0x0e, 0x00, 0x40);		}		/* The OV518 needs special treatment. Although both the OV518		 * and the OV6630 support a 16-bit video bus, only the 8 bit Y		 * bus is actually used. The UV bus is tied to ground.		 * Therefore, the OV6630 needs to be in 8-bit multiplexed		 * output mode */		if (ov->sensor == SEN_OV6630 && ov->bridge == BRG_OV518		    && ov518_color) {			i2c_w_mask(ov, 0x12, 0x10, 0x10);			i2c_w_mask(ov, 0x13, 0x20, 0x20);		} else {			i2c_w_mask(ov, 0x13, 0x00, 0x20);		}	}	/******** Clock programming ********/	// FIXME: Test this with OV6630	/* The OV6620 needs special handling. This prevents the 	 * severe banding that normally occurs */	if (ov->sensor == SEN_OV6620 || ov->sensor == SEN_OV6630)	{		/* Clock down */		i2c_w(ov, 0x2a, 0x04);		if (ov->compress) {//			clock = 0;    /* This ensures the highest frame rate */			clock = 3;		} else if (clockdiv == -1) {   /* If user didn't override it */			clock = 3;    /* Gives better exposure time */		} else {			clock = clockdiv;		}		PDEBUG(4, "Setting clock divisor to %d", clock);		i2c_w(ov, 0x11, clock);		i2c_w(ov, 0x2a, 0x84);		/* This next setting is critical. It seems to improve		 * the gain or the contrast. The "reserved" bits seem		 * to have some effect in this case. */		i2c_w(ov, 0x2d, 0x85);	}	else	{		if (ov->compress) {			clock = 1;    /* This ensures the highest frame rate */		} else if (clockdiv == -1) {   /* If user didn't override it */			/* Calculate and set the clock divisor */			clock = ((sub_flag ? ov->subw * ov->subh				  : width * height)				 * (mode == VIDEO_PALETTE_GREY ? 2 : 3) / 2)				 / 66000;		} else {			clock = clockdiv;		}		PDEBUG(4, "Setting clock divisor to %d", clock);		i2c_w(ov, 0x11, clock);	}	/******** Special Features ********/	if (framedrop >= 0)		i2c_w(ov, 0x16, framedrop);	/* Test Pattern */	i2c_w_mask(ov, 0x12, (testpat?0x02:0x00), 0x02);	/* Enable auto white balance */	i2c_w_mask(ov, 0x12, 0x04, 0x04);	// This will go away as soon as ov51x_mode_init_sensor_regs()	// is fully tested.	/* 7620/6620/6630? don't have register 0x35, so play it safe */	if (ov->sensor == SEN_OV7610 || ov->sensor == SEN_OV76BE) {		if (width == 640 && height == 480)			i2c_w(ov, 0x35, 0x9e);		else			i2c_w(ov, 0x35, 0x1e);	}	return 0;}static intset_ov_sensor_window(struct usb_ov511 *ov, int width, int height, int mode,		     int sub_flag){	int ret;	int hwsbase, hwebase, vwsbase, vwebase, hwsize, vwsize; 	int hoffset, voffset, hwscale = 0, vwscale = 0;	/* The different sensor ICs handle setting up of window differently.	 * IF YOU SET IT WRONG, YOU WILL GET ALL ZERO ISOC DATA FROM OV51x!!! */	switch (ov->sensor) {	case SEN_OV7610:	case SEN_OV76BE:		hwsbase = 0x38;		hwebase = 0x3a;		vwsbase = vwebase = 0x05;		break;	case SEN_OV6620:	case SEN_OV6630:		hwsbase = 0x38;		hwebase = 0x3a;		vwsbase = 0x05;		vwebase = 0x06;		break;	case SEN_OV7620:		hwsbase = 0x2f;		/* From 7620.SET (spec is wrong) */		hwebase = 0x2f;		vwsbase = vwebase = 0x05;		break;	default:		err("Invalid sensor");		return -EINVAL;	}	if (ov->sensor == SEN_OV6620 || ov->sensor == SEN_OV6630) {		/* Note: OV518(+) does downsample on its own) */		if ((width > 176 && height > 144)		    || ov->bclass == BCL_OV518) {  /* CIF */			ret = mode_init_ov_sensor_regs(ov, width, height,				mode, sub_flag, 0);			if (ret < 0)				return ret;			hwscale = 1;			vwscale = 1;  /* The datasheet says 0; it's wrong */			hwsize = 352;			vwsize = 288;		} else if (width > 176 || height > 144) {			err("Illegal dimensions");			return -EINVAL;		} else {			    /* QCIF */			ret = mode_init_ov_sensor_regs(ov, width, height,				mode, sub_flag, 1);			if (ret < 0)				return ret;			hwsize = 176;			vwsize = 144;		}	} else {		if (width > 320 && height > 240) {  /* VGA */			ret = mode_init_ov_sensor_regs(ov, width, height,				mode, sub_flag, 0);			if (ret < 0)				return ret;			hwscale = 2;			vwscale = 1;			hwsize = 640;			vwsize = 480;		} else if (width > 320 || height > 240) {			err("Illegal dimensions");			return -EINVAL;		} else {			    /* QVGA */			ret = mode_init_ov_sensor_regs(ov, width, height,				mode, sub_flag, 1);			if (ret < 0)				return ret;			hwscale = 1;			hwsize = 320;			vwsize = 240;		}	}	/* Center the window */	hoffset = ((hwsize - width) / 2) >> hwscale;	voffset = ((vwsize - height) / 2) >> vwscale;	/* FIXME! - This needs to be changed to support 160x120 and 6620!!! */	if (sub_flag) {		i2c_w(ov, 0x17, hwsbase+(ov->subx>>hwscale));		i2c_w(ov, 0x18,	hwebase+((ov->subx+ov->subw)>>hwscale));		i2c_w(ov, 0x19, vwsbase+(ov->suby>>vwscale));		i2c_w(ov, 0x1a, vwebase+((ov->suby+ov->subh)>>vwscale));	} else {		i2c_w(ov, 0x17, hwsbase + hoffset);		i2c_w(ov, 0x18, hwebase + hoffset + (hwsize>>hwscale));		i2c_w(ov, 0x19, vwsbase + voffset);		i2c_w(ov, 0x1a, vwebase + voffset + (vwsize>>vwscale));	}#ifdef OV511_DEBUG	if (dump_sensor)		dump_i2c_regs(ov);#endif	return 0;}/* Set up the OV511/OV511+ with the given 

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
尤物视频一区二区| 激情亚洲综合在线| 欧美理论片在线| 欧洲在线/亚洲| 欧美日韩精品欧美日韩精品| 欧美综合色免费| 在线影视一区二区三区| 7777精品伊人久久久大香线蕉经典版下载 | 91精品国产色综合久久不卡电影| 亚洲乱码国产乱码精品精可以看 | 麻豆高清免费国产一区| 日韩午夜激情视频| 国产人成亚洲第一网站在线播放| 丁香婷婷综合激情五月色| 亚洲欧美激情视频在线观看一区二区三区 | 精品av久久707| 国产成人福利片| 亚洲欧美偷拍卡通变态| 3d动漫精品啪啪一区二区竹菊| 美女脱光内衣内裤视频久久网站| 国产视频视频一区| 色欧美日韩亚洲| 日本女人一区二区三区| 欧美激情中文字幕| 欧洲一区二区三区在线| 久久国产精品72免费观看| 亚洲国产成人在线| 日韩欧美三级在线| 成人av网站免费| 婷婷一区二区三区| 国产精品久久一卡二卡| 91精品国产综合久久久久久久| 成人性生交大片免费看中文网站| 亚洲乱码日产精品bd| 欧美va日韩va| 欧洲人成人精品| 国产成人综合自拍| 三级不卡在线观看| 中文字幕一区二区三区不卡 | 色吊一区二区三区| 国产乱淫av一区二区三区| 亚洲国产乱码最新视频| 国产视频在线观看一区二区三区| 欧美日韩一本到| 成人深夜视频在线观看| 男女男精品视频| 亚洲夂夂婷婷色拍ww47| 国产精品理论在线观看| 精品黑人一区二区三区久久| 欧美日韩一区二区在线观看视频| 成人免费毛片app| 国产真实乱对白精彩久久| 亚洲综合免费观看高清在线观看| 国产精品青草综合久久久久99| 日韩一二三区视频| 欧美日韩精品一区二区三区四区| 99视频在线精品| 极品瑜伽女神91| 日日夜夜免费精品| 亚洲一区二区三区在线看| 国产精品欧美久久久久一区二区| 2021久久国产精品不只是精品| 欧美精品18+| 欧美日韩一区二区欧美激情| 91美女在线视频| 97se亚洲国产综合自在线| 福利一区二区在线观看| 国产iv一区二区三区| 国产又粗又猛又爽又黄91精品| 男女性色大片免费观看一区二区| 亚洲成av人在线观看| 亚洲国产精品影院| 国产1区2区3区精品美女| 免费在线观看一区| 蜜乳av一区二区三区| 日韩国产在线观看| 日韩不卡一二三区| 亚洲h动漫在线| 午夜电影一区二区| 日韩精品乱码免费| 婷婷久久综合九色综合伊人色| 亚洲成av人影院在线观看网| 午夜精品免费在线| 蜜桃精品视频在线| 国产在线不卡一卡二卡三卡四卡| 国产酒店精品激情| 国产福利一区二区三区视频在线| 国产精品一级在线| av中文字幕不卡| 欧美中文字幕一二三区视频| 欧美日韩在线免费视频| 91.麻豆视频| 久久一区二区视频| 欧美激情一区二区| 亚洲欧美日韩一区二区| 亚洲国产精品久久艾草纯爱| 日本亚洲一区二区| 美女一区二区视频| 国产精品影视在线观看| 97久久久精品综合88久久| 欧美性大战久久久| 欧美一级午夜免费电影| 2014亚洲片线观看视频免费| 国产精品女人毛片| 一区二区日韩av| 喷白浆一区二区| aaa亚洲精品| 欧美日韩国产另类一区| 久久久国产精华| 亚洲精品视频在线观看网站| 男女男精品网站| heyzo一本久久综合| 欧美高清hd18日本| 国产女人水真多18毛片18精品视频| 亚洲免费资源在线播放| 日本欧洲一区二区| a级高清视频欧美日韩| 日韩一卡二卡三卡国产欧美| 国产欧美日韩在线观看| 亚洲国产精品自拍| 国产不卡一区视频| 91精品国产综合久久精品app| 国产日韩精品久久久| 午夜精品久久久久影视| 粉嫩嫩av羞羞动漫久久久| 欧美性猛交一区二区三区精品| 久久亚洲综合色一区二区三区 | 国产欧美一区二区精品性色| 亚洲午夜日本在线观看| 国产suv精品一区二区6| 欧美日韩高清不卡| 一区精品在线播放| 精品一区二区三区在线播放| 日本精品一级二级| 丝袜亚洲另类欧美综合| aa级大片欧美| wwwwww.欧美系列| 日本sm残虐另类| 日本道色综合久久| 欧美激情一区二区三区| 精品制服美女丁香| 91精品啪在线观看国产60岁| 亚洲精品日日夜夜| 成人激情免费网站| 久久久99精品免费观看不卡| 日韩国产在线观看| 欧美色精品在线视频| 亚洲欧美日韩国产另类专区| 国产成人日日夜夜| 久久色视频免费观看| 麻豆精品视频在线观看视频| 欧美午夜精品电影| 一区二区三区日韩欧美| www.色精品| 中文字幕一区在线观看视频| 丰满亚洲少妇av| 久久久777精品电影网影网| 九九**精品视频免费播放| 欧美精品自拍偷拍| 亚洲成av人片在www色猫咪| 欧美亚洲图片小说| 一区二区三区在线观看欧美| 色综合久久天天| 亚洲欧美aⅴ...| 91福利精品视频| 一区二区三区久久| 在线观看日韩一区| 亚洲一区二区中文在线| 欧美色爱综合网| 午夜精品福利一区二区蜜股av | 欧美一区二区在线免费观看| 香蕉成人啪国产精品视频综合网| 欧美日韩专区在线| 视频在线观看一区二区三区| 4438成人网| 精品一区二区久久久| 国产日韩视频一区二区三区| 成人午夜av在线| 一区二区三区中文字幕在线观看| 色婷婷精品大在线视频| 亚洲国产一区在线观看| 欧美一区欧美二区| 狠狠色狠狠色综合| 国产精品家庭影院| 欧洲日韩一区二区三区| 奇米色一区二区| 久久青草国产手机看片福利盒子| 懂色av一区二区三区免费看| 亚洲欧美日韩国产一区二区三区| 欧美视频三区在线播放| 免费精品99久久国产综合精品| 久久综合色一综合色88| av日韩在线网站| 午夜视频一区二区三区| 精品国产免费一区二区三区四区| 成人午夜免费av| 午夜久久电影网| 国产人久久人人人人爽| 国产亚洲欧洲997久久综合| 不卡高清视频专区|