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

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

?? cpia.c

?? linux和2410結合開發 用他可以生成2410所需的zImage文件
?? C
?? 第 1 頁 / 共 5 頁
字號:
/* * cpia CPiA driver * * Supports CPiA based Video Camera's. * * (C) Copyright 1999-2000 Peter Pregler * (C) Copyright 1999-2000 Scott J. Bertin * (C) Copyright 1999-2000 Johannes Erdfelt <johannes@erdfelt.com> * * 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., 675 Mass Ave, Cambridge, MA 02139, USA. *//* #define _CPIA_DEBUG_		define for verbose debug output */#include <linux/config.h>#include <linux/module.h>#include <linux/version.h>#include <linux/init.h>#include <linux/fs.h>#include <linux/vmalloc.h>#include <linux/delay.h>#include <linux/slab.h>#include <linux/proc_fs.h>#include <linux/ctype.h>#include <linux/pagemap.h>#include <asm/io.h>#include <asm/semaphore.h>#include <linux/wrapper.h>#ifdef CONFIG_KMOD#include <linux/kmod.h>#endif#include "cpia.h"#ifdef CONFIG_VIDEO_CPIA_PPextern int cpia_pp_init(void);#endif#ifdef CONFIG_VIDEO_CPIA_USBextern int cpia_usb_init(void);#endifstatic int video_nr = -1;#ifdef MODULEMODULE_PARM(video_nr,"i");MODULE_AUTHOR("Scott J. Bertin <sbertin@mindspring.com> & Peter Pregler <Peter_Pregler@email.com> & Johannes Erdfelt <jerdfelt@valinux.com>");MODULE_DESCRIPTION("V4L-driver for Vision CPiA based cameras");MODULE_LICENSE("GPL");MODULE_SUPPORTED_DEVICE("video");#endif#define ABOUT "V4L-Driver for Vision CPiA based cameras"#ifndef VID_HARDWARE_CPIA#define VID_HARDWARE_CPIA 24    /* FIXME -> from linux/videodev.h */#endif#define CPIA_MODULE_CPIA			(0<<5)#define CPIA_MODULE_SYSTEM			(1<<5)#define CPIA_MODULE_VP_CTRL			(5<<5)#define CPIA_MODULE_CAPTURE			(6<<5)#define CPIA_MODULE_DEBUG			(7<<5)#define INPUT (DATA_IN << 8)#define OUTPUT (DATA_OUT << 8)#define CPIA_COMMAND_GetCPIAVersion	(INPUT | CPIA_MODULE_CPIA | 1)#define CPIA_COMMAND_GetPnPID		(INPUT | CPIA_MODULE_CPIA | 2)#define CPIA_COMMAND_GetCameraStatus	(INPUT | CPIA_MODULE_CPIA | 3)#define CPIA_COMMAND_GotoHiPower	(OUTPUT | CPIA_MODULE_CPIA | 4)#define CPIA_COMMAND_GotoLoPower	(OUTPUT | CPIA_MODULE_CPIA | 5)#define CPIA_COMMAND_GotoSuspend	(OUTPUT | CPIA_MODULE_CPIA | 7)#define CPIA_COMMAND_GotoPassThrough	(OUTPUT | CPIA_MODULE_CPIA | 8)#define CPIA_COMMAND_ModifyCameraStatus	(OUTPUT | CPIA_MODULE_CPIA | 10)#define CPIA_COMMAND_ReadVCRegs		(INPUT | CPIA_MODULE_SYSTEM | 1)#define CPIA_COMMAND_WriteVCReg		(OUTPUT | CPIA_MODULE_SYSTEM | 2)#define CPIA_COMMAND_ReadMCPorts	(INPUT | CPIA_MODULE_SYSTEM | 3)#define CPIA_COMMAND_WriteMCPort	(OUTPUT | CPIA_MODULE_SYSTEM | 4)#define CPIA_COMMAND_SetBaudRate	(OUTPUT | CPIA_MODULE_SYSTEM | 5)#define CPIA_COMMAND_SetECPTiming	(OUTPUT | CPIA_MODULE_SYSTEM | 6)#define CPIA_COMMAND_ReadIDATA		(INPUT | CPIA_MODULE_SYSTEM | 7)#define CPIA_COMMAND_WriteIDATA		(OUTPUT | CPIA_MODULE_SYSTEM | 8)#define CPIA_COMMAND_GenericCall	(OUTPUT | CPIA_MODULE_SYSTEM | 9)#define CPIA_COMMAND_I2CStart		(OUTPUT | CPIA_MODULE_SYSTEM | 10)#define CPIA_COMMAND_I2CStop		(OUTPUT | CPIA_MODULE_SYSTEM | 11)#define CPIA_COMMAND_I2CWrite		(OUTPUT | CPIA_MODULE_SYSTEM | 12)#define CPIA_COMMAND_I2CRead		(INPUT | CPIA_MODULE_SYSTEM | 13)#define CPIA_COMMAND_GetVPVersion	(INPUT | CPIA_MODULE_VP_CTRL | 1)#define CPIA_COMMAND_SetColourParams	(OUTPUT | CPIA_MODULE_VP_CTRL | 3)#define CPIA_COMMAND_SetExposure	(OUTPUT | CPIA_MODULE_VP_CTRL | 4)#define CPIA_COMMAND_SetColourBalance	(OUTPUT | CPIA_MODULE_VP_CTRL | 6)#define CPIA_COMMAND_SetSensorFPS	(OUTPUT | CPIA_MODULE_VP_CTRL | 7)#define CPIA_COMMAND_SetVPDefaults	(OUTPUT | CPIA_MODULE_VP_CTRL | 8)#define CPIA_COMMAND_SetApcor		(OUTPUT | CPIA_MODULE_VP_CTRL | 9)#define CPIA_COMMAND_SetFlickerCtrl	(OUTPUT | CPIA_MODULE_VP_CTRL | 10)#define CPIA_COMMAND_SetVLOffset	(OUTPUT | CPIA_MODULE_VP_CTRL | 11)#define CPIA_COMMAND_GetColourParams	(INPUT | CPIA_MODULE_VP_CTRL | 16)#define CPIA_COMMAND_GetColourBalance	(INPUT | CPIA_MODULE_VP_CTRL | 17)#define CPIA_COMMAND_GetExposure	(INPUT | CPIA_MODULE_VP_CTRL | 18)#define CPIA_COMMAND_SetSensorMatrix	(OUTPUT | CPIA_MODULE_VP_CTRL | 19)#define CPIA_COMMAND_ColourBars		(OUTPUT | CPIA_MODULE_VP_CTRL | 25)#define CPIA_COMMAND_ReadVPRegs		(INPUT | CPIA_MODULE_VP_CTRL | 30)#define CPIA_COMMAND_WriteVPReg		(OUTPUT | CPIA_MODULE_VP_CTRL | 31)#define CPIA_COMMAND_GrabFrame		(OUTPUT | CPIA_MODULE_CAPTURE | 1)#define CPIA_COMMAND_UploadFrame	(OUTPUT | CPIA_MODULE_CAPTURE | 2)#define CPIA_COMMAND_SetGrabMode	(OUTPUT | CPIA_MODULE_CAPTURE | 3)#define CPIA_COMMAND_InitStreamCap	(OUTPUT | CPIA_MODULE_CAPTURE | 4)#define CPIA_COMMAND_FiniStreamCap	(OUTPUT | CPIA_MODULE_CAPTURE | 5)#define CPIA_COMMAND_StartStreamCap	(OUTPUT | CPIA_MODULE_CAPTURE | 6)#define CPIA_COMMAND_EndStreamCap	(OUTPUT | CPIA_MODULE_CAPTURE | 7)#define CPIA_COMMAND_SetFormat		(OUTPUT | CPIA_MODULE_CAPTURE | 8)#define CPIA_COMMAND_SetROI		(OUTPUT | CPIA_MODULE_CAPTURE | 9)#define CPIA_COMMAND_SetCompression	(OUTPUT | CPIA_MODULE_CAPTURE | 10)#define CPIA_COMMAND_SetCompressionTarget (OUTPUT | CPIA_MODULE_CAPTURE | 11)#define CPIA_COMMAND_SetYUVThresh	(OUTPUT | CPIA_MODULE_CAPTURE | 12)#define CPIA_COMMAND_SetCompressionParams (OUTPUT | CPIA_MODULE_CAPTURE | 13)#define CPIA_COMMAND_DiscardFrame	(OUTPUT | CPIA_MODULE_CAPTURE | 14)#define CPIA_COMMAND_OutputRS232	(OUTPUT | CPIA_MODULE_DEBUG | 1)#define CPIA_COMMAND_AbortProcess	(OUTPUT | CPIA_MODULE_DEBUG | 4)#define CPIA_COMMAND_SetDramPage	(OUTPUT | CPIA_MODULE_DEBUG | 5)#define CPIA_COMMAND_StartDramUpload	(OUTPUT | CPIA_MODULE_DEBUG | 6)#define CPIA_COMMAND_StartDummyDtream	(OUTPUT | CPIA_MODULE_DEBUG | 8)#define CPIA_COMMAND_AbortStream	(OUTPUT | CPIA_MODULE_DEBUG | 9)#define CPIA_COMMAND_DownloadDRAM	(OUTPUT | CPIA_MODULE_DEBUG | 10)enum {	FRAME_READY,		/* Ready to grab into */	FRAME_GRABBING,		/* In the process of being grabbed into */	FRAME_DONE,		/* Finished grabbing, but not been synced yet */	FRAME_UNUSED,		/* Unused (no MCAPTURE) */};#define COMMAND_NONE			0x0000#define COMMAND_SETCOMPRESSION		0x0001#define COMMAND_SETCOMPRESSIONTARGET	0x0002#define COMMAND_SETCOLOURPARAMS		0x0004#define COMMAND_SETFORMAT		0x0008#define COMMAND_PAUSE			0x0010#define COMMAND_RESUME			0x0020#define COMMAND_SETYUVTHRESH		0x0040#define COMMAND_SETECPTIMING		0x0080#define COMMAND_SETCOMPRESSIONPARAMS	0x0100#define COMMAND_SETEXPOSURE		0x0200#define COMMAND_SETCOLOURBALANCE	0x0400#define COMMAND_SETSENSORFPS		0x0800#define COMMAND_SETAPCOR		0x1000#define COMMAND_SETFLICKERCTRL		0x2000#define COMMAND_SETVLOFFSET		0x4000/* Developer's Guide Table 5 p 3-34 * indexed by [mains][sensorFps.baserate][sensorFps.divisor]*/static u8 flicker_jumps[2][2][4] ={ { { 76, 38, 19, 9 }, { 92, 46, 23, 11 } },  { { 64, 32, 16, 8 }, { 76, 38, 19, 9} }};/* forward declaration of local function */static void reset_camera_struct(struct cam_data *cam);/********************************************************************** * * Memory management * * This is a shameless copy from the USB-cpia driver (linux kernel * version 2.3.29 or so, I have no idea what this code actually does ;). * Actually it seems to be a copy of a shameless copy of the bttv-driver. * Or that is a copy of a shameless copy of ... (To the powers: is there * no generic kernel-function to do this sort of stuff?) * * Yes, it was a shameless copy from the bttv-driver. IIRC, Alan says * there will be one, but apparentely not yet - jerdfelt * **********************************************************************//* Given PGD from the address space's page table, return the kernel * virtual mapping of the physical memory mapped at ADR. */static inline unsigned long uvirt_to_kva(pgd_t *pgd, unsigned long adr){	unsigned long ret = 0UL;	pmd_t *pmd;	pte_t *ptep, pte;	if (!pgd_none(*pgd)) {		pmd = pmd_offset(pgd, adr);		if (!pmd_none(*pmd)) {			ptep = pte_offset(pmd, adr);			pte = *ptep;			if (pte_present(pte)) {				ret = (unsigned long) page_address(pte_page(pte));				ret |= (adr & (PAGE_SIZE-1));			}		}	}	return ret;}/* Here we want the physical address of the memory. * This is used when initializing the contents of the * area and marking the pages as reserved. */static inline unsigned long kvirt_to_pa(unsigned long adr){	unsigned long va, kva, ret;	va = VMALLOC_VMADDR(adr);	kva = uvirt_to_kva(pgd_offset_k(va), va);	ret = __pa(kva);	return ret;}static void *rvmalloc(unsigned long size){	void *mem;	unsigned long adr, page;	/* Round it off to PAGE_SIZE */	size += (PAGE_SIZE - 1);	size &= ~(PAGE_SIZE - 1);	mem = vmalloc_32(size);	if (!mem)		return NULL;	memset(mem, 0, size); /* Clear the ram out, no junk to the user */	adr = (unsigned long) mem;	while (size > 0) {		page = kvirt_to_pa(adr);		mem_map_reserve(virt_to_page(__va(page)));		adr += PAGE_SIZE;		if (size > PAGE_SIZE)			size -= PAGE_SIZE;		else			size = 0;	}	return mem;}static void rvfree(void *mem, unsigned long size){	unsigned long adr, page;	if (!mem)		return;	size += (PAGE_SIZE - 1);	size &= ~(PAGE_SIZE - 1);	adr = (unsigned long) mem;	while (size > 0) {		page = kvirt_to_pa(adr);		mem_map_unreserve(virt_to_page(__va(page)));		adr += PAGE_SIZE;		if (size > PAGE_SIZE)			size -= PAGE_SIZE;		else			size = 0;	}	vfree(mem);}/********************************************************************** * * /proc interface * **********************************************************************/#ifdef CONFIG_PROC_FSstatic struct proc_dir_entry *cpia_proc_root=NULL;static int cpia_read_proc(char *page, char **start, off_t off,                          int count, int *eof, void *data){	char *out = page;	int len, tmp;	struct cam_data *cam = data;	char tmpstr[20];	/* IMPORTANT: This output MUST be kept under PAGE_SIZE	 *            or we need to get more sophisticated. */	out += sprintf(out, "read-only\n-----------------------\n");	out += sprintf(out, "V4L Driver version:       %d.%d.%d\n",		       CPIA_MAJ_VER, CPIA_MIN_VER, CPIA_PATCH_VER);	out += sprintf(out, "CPIA Version:             %d.%02d (%d.%d)\n",	               cam->params.version.firmwareVersion,	               cam->params.version.firmwareRevision,	               cam->params.version.vcVersion,	               cam->params.version.vcRevision);	out += sprintf(out, "CPIA PnP-ID:              %04x:%04x:%04x\n",	               cam->params.pnpID.vendor, cam->params.pnpID.product,	               cam->params.pnpID.deviceRevision);	out += sprintf(out, "VP-Version:               %d.%d %04x\n",	               cam->params.vpVersion.vpVersion,	               cam->params.vpVersion.vpRevision,	               cam->params.vpVersion.cameraHeadID);		out += sprintf(out, "system_state:             %#04x\n",	               cam->params.status.systemState);	out += sprintf(out, "grab_state:               %#04x\n",	               cam->params.status.grabState);	out += sprintf(out, "stream_state:             %#04x\n",	               cam->params.status.streamState);	out += sprintf(out, "fatal_error:              %#04x\n",	               cam->params.status.fatalError);	out += sprintf(out, "cmd_error:                %#04x\n",	               cam->params.status.cmdError);	out += sprintf(out, "debug_flags:              %#04x\n",	               cam->params.status.debugFlags);	out += sprintf(out, "vp_status:                %#04x\n",	               cam->params.status.vpStatus);	out += sprintf(out, "error_code:               %#04x\n",	               cam->params.status.errorCode);	out += sprintf(out, "video_size:               %s\n",	               cam->params.format.videoSize == VIDEOSIZE_CIF ?		       "CIF " : "QCIF");	out += sprintf(out, "sub_sample:               %s\n",	               cam->params.format.subSample == SUBSAMPLE_420 ?		       "420" : "422");	out += sprintf(out, "yuv_order:                %s\n",	               cam->params.format.yuvOrder == YUVORDER_YUYV ?		       "YUYV" : "UYVY");	out += sprintf(out, "roi:                      (%3d, %3d) to (%3d, %3d)\n",	               cam->params.roi.colStart*8,	               cam->params.roi.rowStart*4,	               cam->params.roi.colEnd*8,	               cam->params.roi.rowEnd*4);	out += sprintf(out, "actual_fps:               %3d\n", cam->fps);	out += sprintf(out, "transfer_rate:            %4dkB/s\n",	               cam->transfer_rate);		out += sprintf(out, "\nread-write\n");	out += sprintf(out, "-----------------------  current       min"	               "       max   default  comment\n");	out += sprintf(out, "brightness:             %8d  %8d  %8d  %8d\n",	               cam->params.colourParams.brightness, 0, 100, 50);	if (cam->params.version.firmwareVersion == 1 &&	   cam->params.version.firmwareRevision == 2)		/* 1-02 firmware limits contrast to 80 */		tmp = 80;	else		tmp = 96;	out += sprintf(out, "contrast:               %8d  %8d  %8d  %8d"	               "  steps of 8\n",	               cam->params.colourParams.contrast, 0, tmp, 48);	out += sprintf(out, "saturation:             %8d  %8d  %8d  %8d\n",	               cam->params.colourParams.saturation, 0, 100, 50);	tmp = (25000+5000*cam->params.sensorFps.baserate)/	      (1<<cam->params.sensorFps.divisor);	out += sprintf(out, "sensor_fps:             %4d.%03d  %8d  %8d  %8d\n",	               tmp/1000, tmp%1000, 3, 30, 15);	out += sprintf(out, "stream_start_line:      %8d  %8d  %8d  %8d\n",	               2*cam->params.streamStartLine, 0,		       cam->params.format.videoSize == VIDEOSIZE_CIF ? 288:144,		       cam->params.format.videoSize == VIDEOSIZE_CIF ? 240:120);	out += sprintf(out, "ecp_timing:             %8s  %8s  %8s  %8s\n",	               cam->params.ecpTiming ? "slow" : "normal", "slow",		       "normal", "normal");	if (cam->params.colourBalance.balanceModeIsAuto) {		sprintf(tmpstr, "auto");	} else {		sprintf(tmpstr, "manual");	}	out += sprintf(out, "color_balance_mode:     %8s  %8s  %8s"		       "  %8s\n",  tmpstr, "manual", "auto", "auto");	out += sprintf(out, "red_gain:               %8d  %8d  %8d  %8d\n",	               cam->params.colourBalance.redGain, 0, 212, 32);	out += sprintf(out, "green_gain:             %8d  %8d  %8d  %8d\n",	               cam->params.colourBalance.greenGain, 0, 212, 6);	out += sprintf(out, "blue_gain:              %8d  %8d  %8d  %8d\n",	               cam->params.colourBalance.blueGain, 0, 212, 92);	if (cam->params.version.firmwareVersion == 1 &&	   cam->params.version.firmwareRevision == 2)		/* 1-02 firmware limits gain to 2 */		sprintf(tmpstr, "%8d  %8d", 1, 2);	else		sprintf(tmpstr, "1,2,4,8");	if (cam->params.exposure.gainMode == 0)		out += sprintf(out, "max_gain:                unknown  %18s"		               "  %8d\n", tmpstr, 2); 	else		out += sprintf(out, "max_gain:               %8d  %18s  %8d\n", 		               1<<(cam->params.exposure.gainMode-1), tmpstr, 2);	switch(cam->params.exposure.expMode) {	case 1:	case 3:		sprintf(tmpstr, "manual");		break;	case 2:		sprintf(tmpstr, "auto");		break;	default:		sprintf(tmpstr, "unknown");		break;	}	out += sprintf(out, "exposure_mode:          %8s  %8s  %8s"		       "  %8s\n",  tmpstr, "manual", "auto", "auto");	out += sprintf(out, "centre_weight:          %8s  %8s  %8s  %8s\n",	               (2-cam->params.exposure.centreWeight) ? "on" : "off",	               "off", "on", "on");	out += sprintf(out, "gain:                   %8d  %8d  max_gain  %8d  1,2,4,8 possible\n",	               1<<cam->params.exposure.gain, 1, 1);	if (cam->params.version.firmwareVersion == 1 &&	   cam->params.version.firmwareRevision == 2)		/* 1-02 firmware limits fineExp to 127 */		tmp = 255;	else		tmp = 511;	out += sprintf(out, "fine_exp:               %8d  %8d  %8d  %8d\n",	               cam->params.exposure.fineExp*2, 0, tmp, 0);	if (cam->params.version.firmwareVersion == 1 &&	   cam->params.version.firmwareRevision == 2)		/* 1-02 firmware limits coarseExpHi to 0 */		tmp = 255;	else		tmp = 65535;	out += sprintf(out, "coarse_exp:             %8d  %8d  %8d"		       "  %8d\n", cam->params.exposure.coarseExpLo+		       256*cam->params.exposure.coarseExpHi, 0, tmp, 185);	out += sprintf(out, "red_comp:               %8d  %8d  %8d  %8d\n",

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美电视剧在线观看完整版| 国产精品久久久久精k8| 久久久亚洲精品石原莉奈| 亚洲乱码日产精品bd| 美日韩黄色大片| 欧美在线色视频| 国产欧美日韩麻豆91| 首页综合国产亚洲丝袜| 99久久精品免费看| 久久综合丝袜日本网| 视频一区中文字幕| 一本色道久久综合亚洲aⅴ蜜桃| 精品国产麻豆免费人成网站| 亚洲国产日韩a在线播放| 成人精品免费视频| 欧美不卡在线视频| 奇米色一区二区三区四区| 日本乱人伦aⅴ精品| 国产精品电影一区二区三区| 国产在线精品一区二区夜色| 5月丁香婷婷综合| 亚洲一卡二卡三卡四卡| 99精品视频一区| 国产精品无遮挡| 国产91色综合久久免费分享| 精品国产一区二区三区av性色| 无码av免费一区二区三区试看 | 97精品超碰一区二区三区| 久久久国产精品午夜一区ai换脸| 日韩精品91亚洲二区在线观看 | 日韩亚洲欧美在线| 亚洲福利一区二区三区| 91久久精品国产91性色tv| 日韩一区在线看| 97精品久久久午夜一区二区三区 | 亚洲精品亚洲人成人网在线播放| 国产福利一区在线| 久久精品视频网| 福利91精品一区二区三区| 久久久久久久精| 成人综合在线观看| 亚洲少妇最新在线视频| 色综合天天综合在线视频| 亚洲男同性恋视频| 欧美日韩一级片在线观看| 亚洲成av人**亚洲成av**| 欧美日本免费一区二区三区| 麻豆91在线观看| 久久日韩精品一区二区五区| 国产精品亚洲成人| 综合欧美一区二区三区| 欧美伊人久久大香线蕉综合69| 五月天亚洲精品| 精品99999| 99精品久久只有精品| 亚洲精品日产精品乱码不卡| 欧美人狂配大交3d怪物一区| 久久精品国产99| 欧美激情艳妇裸体舞| 色综合久久久久久久久久久| 午夜免费欧美电影| 久久久久久久免费视频了| av成人免费在线| 五月激情综合色| 中文在线一区二区| 欧美日韩久久一区二区| 国产精品一区专区| 亚洲综合久久久久| 日韩一级在线观看| 91伊人久久大香线蕉| 五月婷婷综合网| 天天射综合影视| 欧美韩国日本一区| 欧美一区二区在线播放| 懂色一区二区三区免费观看| 亚洲国产精品一区二区久久| 久久综合久久综合久久| 在线观看欧美精品| 国产精品一区三区| 丝袜美腿亚洲一区二区图片| 中国色在线观看另类| 欧美一区二区视频观看视频| 高清在线不卡av| 免费成人在线网站| 亚洲综合精品自拍| 国产精品久久一卡二卡| 日韩美女天天操| 欧美午夜片在线观看| 成人av资源在线| 激情综合色丁香一区二区| 亚洲午夜久久久久久久久久久 | 韩国成人福利片在线播放| 夜色激情一区二区| 欧美激情一区二区三区蜜桃视频| 91精品免费在线| 在线区一区二视频| 不卡的av中国片| 国产一区二区三区最好精华液| 五月天网站亚洲| 亚洲成人一区二区在线观看| 中文字幕亚洲精品在线观看| 精品少妇一区二区三区在线视频| 欧美亚一区二区| 91丝袜美腿高跟国产极品老师 | 欧美日韩精品免费| 91亚洲午夜精品久久久久久| 国产精品99久久久久久宅男| 蜜桃一区二区三区四区| 午夜a成v人精品| 亚洲综合av网| 一区二区在线观看av| 亚洲色图视频免费播放| 亚洲国产高清aⅴ视频| 欧美激情中文不卡| 国产日韩精品视频一区| 久久久综合视频| 国产亚洲欧洲一区高清在线观看| 欧美成人精品福利| 欧美va亚洲va国产综合| 欧美大度的电影原声| 精品99999| 国产日韩v精品一区二区| 久久综合九色综合欧美亚洲| 亚洲精品一区二区三区香蕉| 久久久精品国产免大香伊| 久久久久国产精品麻豆| 国产精品免费久久| 亚洲欧美日韩久久精品| 亚洲国产欧美日韩另类综合 | 国产在线麻豆精品观看| 国产成人av一区| av影院午夜一区| 色先锋资源久久综合| 欧美日韩亚洲综合在线 欧美亚洲特黄一级 | 亚洲视频中文字幕| 一区二区三区国产精华| 亚洲va欧美va人人爽| 美女视频黄频大全不卡视频在线播放| 麻豆国产精品官网| 国产伦精品一区二区三区免费迷 | 五月激情综合色| 国产一区二区三区日韩| 91小视频免费观看| 日本乱人伦一区| 精品久久久久久久久久久久包黑料 | 日韩电影免费在线观看网站| 日本不卡在线视频| 大胆欧美人体老妇| 欧美性视频一区二区三区| 欧美一级二级在线观看| 亚洲国产岛国毛片在线| 亚洲夂夂婷婷色拍ww47| 久久国产尿小便嘘嘘尿| av午夜一区麻豆| 日韩午夜av一区| 亚洲手机成人高清视频| 蜜桃av一区二区| 99久久99久久精品免费观看| ...av二区三区久久精品| 五月综合激情日本mⅴ| 国产999精品久久久久久| 欧美色综合天天久久综合精品| 欧美成人在线直播| 亚洲精品一二三| 国产精品99久久久| 欧美片网站yy| 亚洲日本va在线观看| 久久爱另类一区二区小说| 色菇凉天天综合网| 国产日产亚洲精品系列| 亚洲第一福利视频在线| aaa国产一区| 26uuu成人网一区二区三区| 亚洲一区二区3| 99re热这里只有精品免费视频| 精品久久久久一区| 亚洲国产日韩精品| 色综合激情久久| 国产精品成人在线观看| 精品一区二区三区av| 91精品国产综合久久久蜜臀粉嫩| 亚洲日本免费电影| 国产91精品久久久久久久网曝门 | 日韩av午夜在线观看| 色视频一区二区| ●精品国产综合乱码久久久久| 国产精品自产自拍| 日韩美女视频在线| 午夜精品久久久久久久久久久| 97久久精品人人澡人人爽| 久久精品视频免费| 久久99精品国产麻豆婷婷洗澡| 91麻豆精品91久久久久久清纯| 亚洲精品视频一区| 91亚洲男人天堂| 亚洲人被黑人高潮完整版| 成人97人人超碰人人99| 国产精品美日韩| 99久久夜色精品国产网站| 国产精品第13页|