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

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

?? pwc-dec23.c

?? webcam device driver
?? C
?? 第 1 頁 / 共 2 頁
字號:
/* Linux driver for Philips webcam   Decompression for chipset version 2 et 3   (C) 2004-2006  Luc Saillard (luc@saillard.org)   NOTE: this version of pwc is an unofficial (modified) release of pwc & pcwx   driver and thus may have bugs that are not present in the original version.   Please send bug reports and support requests to <luc@saillard.org>.   The decompression routines have been implemented by reverse-engineering the   Nemosoft binary pwcx module. Caveat emptor.   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*/#include "pwc-timon.h"#include "pwc-kiara.h"#include "pwc-dec23.h"#include "pwc-ioctl.h"#include <linux/string.h>/* * USE_LOOKUP_TABLE_TO_CLAMP *   0: use a C version of this tests:  {  a<0?0:(a>255?255:a) } *   1: use a faster lookup table for cpu with a big cache (intel) */#define USE_LOOKUP_TABLE_TO_CLAMP	1/* * UNROLL_LOOP_FOR_COPYING_BLOCK *   0: use a loop for a smaller code (but little slower) *   1: when unrolling the loop, gcc produces some faster code (perhaps only *   valid for intel processor class). Activating this option, automaticaly *   activate USE_LOOKUP_TABLE_TO_CLAMP */#define UNROLL_LOOP_FOR_COPY		1#if UNROLL_LOOP_FOR_COPY# undef USE_LOOKUP_TABLE_TO_CLAMP# define USE_LOOKUP_TABLE_TO_CLAMP 1#endif/* * ENABLE_BAYER_DECODER *   0: bayer decoder is not build (save some space) *   1: bayer decoder is build and can be used */#define ENABLE_BAYER_DECODER 0static void build_subblock_pattern(struct pwc_dec23_private *pdec){	static const unsigned int initial_values[12] = {		-0x526500, -0x221200, 0x221200, 0x526500,	       	           -0x3de200, 0x3de200,                -0x6db480, -0x2d5d00, 0x2d5d00, 0x6db480,			   -0x12c200, 0x12c200	};	static const unsigned int values_derivated[12] = {		0xa4ca, 0x4424, -0x4424, -0xa4ca, 			0x7bc4, -0x7bc4,		0xdb69, 0x5aba, -0x5aba, -0xdb69,			0x2584, -0x2584	};	unsigned int temp_values[12];	int i, j;	memcpy(temp_values, initial_values, sizeof(initial_values));	for (i = 0; i < 256; i++) {		for (j = 0; j < 12; j++) {			pdec->table_subblock[i][j] = temp_values[j];			temp_values[j] += values_derivated[j];		}	}}static void build_bit_powermask_table(struct pwc_dec23_private *pdec){	unsigned char *p;	unsigned int bit, byte, mask, val;	unsigned int bitpower = 1;	for (bit = 0; bit < 8; bit++) {		mask = bitpower - 1;		p = pdec->table_bitpowermask[bit];		for (byte = 0; byte < 256; byte++) {			val = (byte & mask);			if (byte & bitpower)				val = -val;			*p++ = val;		}		bitpower<<=1;	}}static void build_table_color(const unsigned int romtable[16][8],    			      unsigned char p0004[16][1024],			      unsigned char p8004[16][256]){	int compression_mode, j, k, bit, pw;	unsigned char *p0, *p8;	const unsigned int *r;	/* We have 16 compressions tables */	for (compression_mode = 0; compression_mode < 16; compression_mode++) {		p0 = p0004[compression_mode];		p8 = p8004[compression_mode];		r  = romtable[compression_mode];		for (j = 0; j < 8; j++, r++, p0 += 128) {			for (k = 0; k < 16; k++) {				if (k == 0)					bit = 1;				else if (k >= 1 && k < 3)					bit = (r[0] >> 15) & 7;				else if (k >= 3 && k < 6)					bit = (r[0] >> 12) & 7;				else if (k >= 6 && k < 10)					bit = (r[0] >> 9) & 7;				else if (k >= 10 && k < 13)					bit = (r[0] >> 6) & 7;				else if (k >= 13 && k < 15)					bit = (r[0] >> 3) & 7;				else					bit = (r[0]) & 7;				if (k == 0)					*p8++ = 8;				else					*p8++ = j - bit;				*p8++ = bit;				pw = 1 << bit;				p0[k + 0x00] = (1 * pw) + 0x80;				p0[k + 0x10] = (2 * pw) + 0x80;				p0[k + 0x20] = (3 * pw) + 0x80;				p0[k + 0x30] = (4 * pw) + 0x80;				p0[k + 0x40] = (-1 * pw) + 0x80;				p0[k + 0x50] = (-2 * pw) + 0x80;				p0[k + 0x60] = (-3 * pw) + 0x80;				p0[k + 0x70] = (-4 * pw) + 0x80;			}	/* end of for (k=0; k<16; k++, p8++) */		}	/* end of for (j=0; j<8; j++ , table++) */	} /* end of foreach compression_mode */}/* * */static void fill_table_dc00_d800(struct pwc_dec23_private *pdec){#define SCALEBITS 15#define ONE_HALF  (1UL << (SCALEBITS - 1))	int i;	unsigned int offset1 = ONE_HALF;	unsigned int offset2 = 0x0000;	for (i=0; i<256; i++) {		pdec->table_dc00[i] = offset1 & ~(ONE_HALF);		pdec->table_d800[i] = offset2;		offset1 += 0x7bc4;		offset2 += 0x7bc4;	}}/* * To decode the stream: *   if look_bits(2) == 0:	# op == 2 in the lookup table *      skip_bits(2) *      end of the stream *   elif look_bits(3) == 7:	# op == 1 in the lookup table *      skip_bits(3) *      yyyy = get_bits(4) *      xxxx = get_bits(8) *   else:			# op == 0 in the lookup table *      skip_bits(x) * * For speedup processing, we build a lookup table and we takes the first 6 bits. *  * struct { *   unsigned char op;	    // operation to execute *   unsigned char bits;    // bits use to perform operation *   unsigned char offset1; // offset to add to access in the table_0004 % 16 *   unsigned char offset2; // offset to add to access in the table_0004 * } * * How to build this table ? *   op == 2 when (i%4)==0 *   op == 1 when (i%8)==7 *   op == 0 otherwise * */static const unsigned char hash_table_ops[64*4] = {	0x02, 0x00, 0x00, 0x00,	0x00, 0x03, 0x01, 0x00,	0x00, 0x04, 0x01, 0x10,	0x00, 0x06, 0x01, 0x30,	0x02, 0x00, 0x00, 0x00,	0x00, 0x03, 0x01, 0x40,	0x00, 0x05, 0x01, 0x20,	0x01, 0x00, 0x00, 0x00,	0x02, 0x00, 0x00, 0x00,	0x00, 0x03, 0x01, 0x00,	0x00, 0x04, 0x01, 0x50,	0x00, 0x05, 0x02, 0x00,	0x02, 0x00, 0x00, 0x00,	0x00, 0x03, 0x01, 0x40,	0x00, 0x05, 0x03, 0x00,	0x01, 0x00, 0x00, 0x00,	0x02, 0x00, 0x00, 0x00,	0x00, 0x03, 0x01, 0x00,	0x00, 0x04, 0x01, 0x10,	0x00, 0x06, 0x02, 0x10,	0x02, 0x00, 0x00, 0x00,	0x00, 0x03, 0x01, 0x40,	0x00, 0x05, 0x01, 0x60,	0x01, 0x00, 0x00, 0x00,	0x02, 0x00, 0x00, 0x00,	0x00, 0x03, 0x01, 0x00,	0x00, 0x04, 0x01, 0x50,	0x00, 0x05, 0x02, 0x40,	0x02, 0x00, 0x00, 0x00,	0x00, 0x03, 0x01, 0x40,	0x00, 0x05, 0x03, 0x40,	0x01, 0x00, 0x00, 0x00,	0x02, 0x00, 0x00, 0x00,	0x00, 0x03, 0x01, 0x00,	0x00, 0x04, 0x01, 0x10,	0x00, 0x06, 0x01, 0x70,	0x02, 0x00, 0x00, 0x00,	0x00, 0x03, 0x01, 0x40,	0x00, 0x05, 0x01, 0x20,	0x01, 0x00, 0x00, 0x00,	0x02, 0x00, 0x00, 0x00,	0x00, 0x03, 0x01, 0x00,	0x00, 0x04, 0x01, 0x50,	0x00, 0x05, 0x02, 0x00,	0x02, 0x00, 0x00, 0x00,	0x00, 0x03, 0x01, 0x40,	0x00, 0x05, 0x03, 0x00,	0x01, 0x00, 0x00, 0x00,	0x02, 0x00, 0x00, 0x00,	0x00, 0x03, 0x01, 0x00,	0x00, 0x04, 0x01, 0x10,	0x00, 0x06, 0x02, 0x50,	0x02, 0x00, 0x00, 0x00,	0x00, 0x03, 0x01, 0x40,	0x00, 0x05, 0x01, 0x60,	0x01, 0x00, 0x00, 0x00,	0x02, 0x00, 0x00, 0x00,	0x00, 0x03, 0x01, 0x00,	0x00, 0x04, 0x01, 0x50,	0x00, 0x05, 0x02, 0x40,	0x02, 0x00, 0x00, 0x00,	0x00, 0x03, 0x01, 0x40,	0x00, 0x05, 0x03, 0x40,	0x01, 0x00, 0x00, 0x00};/* * */static const unsigned int MulIdx[16][16] = {	{0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,},	{0, 1, 2, 3, 0, 1, 2, 3, 0, 1, 2, 3, 0, 1, 2, 3,},	{0, 0, 0, 0, 1, 1, 1, 1, 2, 2, 2, 2, 3, 3, 3, 3,},	{4, 4, 4, 4, 5, 5, 5, 5, 5, 5, 5, 5, 4, 4, 4, 4,},	{6, 7, 8, 9, 7, 10, 11, 8, 8, 11, 10, 7, 9, 8, 7, 6,},	{4, 5, 5, 4, 4, 5, 5, 4, 4, 5, 5, 4, 4, 5, 5, 4,},	{1, 3, 0, 2, 1, 3, 0, 2, 1, 3, 0, 2, 1, 3, 0, 2,},	{0, 3, 3, 0, 1, 2, 2, 1, 2, 1, 1, 2, 3, 0, 0, 3,},	{0, 1, 2, 3, 3, 2, 1, 0, 3, 2, 1, 0, 0, 1, 2, 3,},	{1, 1, 1, 1, 3, 3, 3, 3, 0, 0, 0, 0, 2, 2, 2, 2,},	{7, 10, 11, 8, 9, 8, 7, 6, 6, 7, 8, 9, 8, 11, 10, 7,},	{4, 5, 5, 4, 5, 4, 4, 5, 5, 4, 4, 5, 4, 5, 5, 4,},	{7, 9, 6, 8, 10, 8, 7, 11, 11, 7, 8, 10, 8, 6, 9, 7,},	{1, 3, 0, 2, 2, 0, 3, 1, 2, 0, 3, 1, 1, 3, 0, 2,},	{1, 2, 2, 1, 3, 0, 0, 3, 0, 3, 3, 0, 2, 1, 1, 2,},	{10, 8, 7, 11, 8, 6, 9, 7, 7, 9, 6, 8, 11, 7, 8, 10}};#if USE_LOOKUP_TABLE_TO_CLAMP#define MAX_OUTER_CROP_VALUE	(512)static unsigned char pwc_crop_table[256 + 2*MAX_OUTER_CROP_VALUE];#define CLAMP(x) (pwc_crop_table[MAX_OUTER_CROP_VALUE+(x)])#else#define CLAMP(x) ((x)>255?255:((x)<0?0:x))#endif/* If the type or the command change, we rebuild the lookup table */int pwc_dec23_init(struct pwc_device *pwc, int type, unsigned char *cmd){	int flags, version, shift, i;	struct pwc_dec23_private *pdec;	if (pwc->decompress_data == NULL) {		pdec = kmalloc(sizeof(struct pwc_dec23_private), GFP_KERNEL);		if (pdec == NULL)			return -ENOMEM;		pwc->decompress_data = pdec;	}	pdec = pwc->decompress_data;	if (DEVICE_USE_CODEC3(type)) {		flags = cmd[2] & 0x18;		if (flags == 8)			pdec->nbits = 7;	/* More bits, mean more bits to encode the stream, but better quality */		else if (flags == 0x10)			pdec->nbits = 8;		else			pdec->nbits = 6;		version = cmd[2] >> 5;		build_table_color(KiaraRomTable[version][0], pdec->table_0004_pass1, pdec->table_8004_pass1);		build_table_color(KiaraRomTable[version][1], pdec->table_0004_pass2, pdec->table_8004_pass2);	} else {		flags = cmd[2] & 6;		if (flags == 2)			pdec->nbits = 7;		else if (flags == 4)			pdec->nbits = 8;		else			pdec->nbits = 6;		version = cmd[2] >> 3;		build_table_color(TimonRomTable[version][0], pdec->table_0004_pass1, pdec->table_8004_pass1);		build_table_color(TimonRomTable[version][1], pdec->table_0004_pass2, pdec->table_8004_pass2);	}	/* Informations can be coded on a variable number of bits but never less than 8 */	shift = 8 - pdec->nbits;	pdec->scalebits = SCALEBITS - shift;	pdec->nbitsmask = 0xFF >> shift;	fill_table_dc00_d800(pdec);	build_subblock_pattern(pdec);	build_bit_powermask_table(pdec);#if USE_LOOKUP_TABLE_TO_CLAMP	/* Build the static table to clamp value [0-255] */	for (i=0;i<MAX_OUTER_CROP_VALUE;i++)		pwc_crop_table[i] = 0;	for (i=0; i<256; i++)		pwc_crop_table[MAX_OUTER_CROP_VALUE+i] = i;	for (i=0; i<MAX_OUTER_CROP_VALUE; i++)		pwc_crop_table[MAX_OUTER_CROP_VALUE+256+i] = 255;#endif	return 0;}/* * Copy the 4x4 image block to Y plane buffer */static void copy_image_block_Y(const int *src, unsigned char *dst, unsigned int bytes_per_line, unsigned int scalebits){#if UNROLL_LOOP_FOR_COPY	const unsigned char *cm = pwc_crop_table+MAX_OUTER_CROP_VALUE;	const int *c = src;	unsigned char *d = dst;	*d++ = cm[c[0] >> scalebits];	*d++ = cm[c[1] >> scalebits];	*d++ = cm[c[2] >> scalebits];	*d++ = cm[c[3] >> scalebits];	d = dst + bytes_per_line;	*d++ = cm[c[4] >> scalebits];	*d++ = cm[c[5] >> scalebits];	*d++ = cm[c[6] >> scalebits];	*d++ = cm[c[7] >> scalebits];	d = dst + bytes_per_line*2;	*d++ = cm[c[8] >> scalebits];	*d++ = cm[c[9] >> scalebits];	*d++ = cm[c[10] >> scalebits];	*d++ = cm[c[11] >> scalebits];	d = dst + bytes_per_line*3;	*d++ = cm[c[12] >> scalebits];	*d++ = cm[c[13] >> scalebits];	*d++ = cm[c[14] >> scalebits];	*d++ = cm[c[15] >> scalebits];#else	int i;	const int *c = src;	unsigned char *d = dst;	for (i = 0; i < 4; i++, c++)		*d++ = CLAMP((*c) >> scalebits);	d = dst + bytes_per_line;	for (i = 0; i < 4; i++, c++)		*d++ = CLAMP((*c) >> scalebits);	d = dst + bytes_per_line*2;	for (i = 0; i < 4; i++, c++)		*d++ = CLAMP((*c) >> scalebits);	d = dst + bytes_per_line*3;	for (i = 0; i < 4; i++, c++)		*d++ = CLAMP((*c) >> scalebits);#endif}/* * Copy the 4x4 image block to a CrCb plane buffer *  */static void copy_image_block_CrCb(const int *src, unsigned char *dst, unsigned int bytes_per_line, unsigned int scalebits){#if UNROLL_LOOP_FOR_COPY	/* Unroll all loops */	const unsigned char *cm = pwc_crop_table+MAX_OUTER_CROP_VALUE;	const int *c = src;	unsigned char *d = dst;	*d++ = cm[c[0] >> scalebits];	*d++ = cm[c[4] >> scalebits];	*d++ = cm[c[1] >> scalebits];	*d++ = cm[c[5] >> scalebits];	*d++ = cm[c[2] >> scalebits];	*d++ = cm[c[6] >> scalebits];	*d++ = cm[c[3] >> scalebits];	*d++ = cm[c[7] >> scalebits];	d = dst + bytes_per_line;	*d++ = cm[c[12] >> scalebits];	*d++ = cm[c[8] >> scalebits];	*d++ = cm[c[13] >> scalebits];	*d++ = cm[c[9] >> scalebits];	*d++ = cm[c[14] >> scalebits];	*d++ = cm[c[10] >> scalebits];	*d++ = cm[c[15] >> scalebits];	*d++ = cm[c[11] >> scalebits];#else	int i;	const int *c1 = src;	const int *c2 = src + 4;	unsigned char *d = dst;	for (i = 0; i < 4; i++, c1++, c2++) {		*d++ = CLAMP((*c1) >> scalebits);		*d++ = CLAMP((*c2) >> scalebits);	}	c1 = src + 12;	d = dst + bytes_per_line;	for (i = 0; i < 4; i++, c1++, c2++) {		*d++ = CLAMP((*c1) >> scalebits);		*d++ = CLAMP((*c2) >> scalebits);	}#endif}#if ENABLE_BAYER_DECODER/* * Format: 8x2 pixels

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人污污视频在线观看| 精品美女一区二区三区| 日韩一区二区三区视频| 国产精品无码永久免费888| 亚洲高清一区二区三区| 成人午夜激情影院| 91精品国产一区二区三区蜜臀| 1024国产精品| 久久er精品视频| 欧美日韩免费高清一区色橹橹 | 国产精品日日摸夜夜摸av| 五月婷婷激情综合网| av高清不卡在线| 久久一夜天堂av一区二区三区| 日韩精品欧美成人高清一区二区| 色哟哟一区二区| 亚洲国产精品传媒在线观看| 韩日av一区二区| 欧美一区二区私人影院日本| 亚洲第一会所有码转帖| 色av一区二区| 成人欧美一区二区三区视频网页| 国产精品综合网| 久久久久青草大香线综合精品| 美女视频黄 久久| 日韩视频国产视频| 日韩av网站在线观看| 欧美亚洲日本国产| 亚洲成a人v欧美综合天堂| 欧美日韩五月天| 午夜欧美电影在线观看| 欧美日韩在线电影| 视频在线在亚洲| 日韩一级精品视频在线观看| 美国十次综合导航| 精品国精品国产| 国产美女精品在线| 久久久亚洲精华液精华液精华液| 久久精品国产亚洲5555| 久久这里只有精品6| 国产麻豆精品久久一二三| 国产喂奶挤奶一区二区三区| 国产精品996| 国产精品二区一区二区aⅴ污介绍| 成人h版在线观看| 一区二区在线免费| 欧美精品第一页| 久草中文综合在线| 日本一区二区在线不卡| 91丝袜高跟美女视频| 亚洲愉拍自拍另类高清精品| 91精品国产全国免费观看| 久久狠狠亚洲综合| 国产精品成人免费在线| 色哟哟国产精品| 日韩av二区在线播放| 久久久午夜精品| 99久久精品国产麻豆演员表| 亚洲五码中文字幕| 久久综合狠狠综合久久综合88| 成人性生交大片免费看中文| 亚洲综合小说图片| 精品捆绑美女sm三区| 波多野结衣亚洲一区| 亚洲v日本v欧美v久久精品| 亚洲精品一区二区在线观看| 91一区二区三区在线播放| 亚欧色一区w666天堂| 2023国产精品| 欧美性xxxxxxxx| 国产91清纯白嫩初高中在线观看| 亚洲成人午夜电影| 中文字幕不卡一区| 欧美乱妇23p| 成人av电影在线播放| 肉色丝袜一区二区| 亚洲丝袜精品丝袜在线| 日韩欧美中文字幕一区| 韩国成人在线视频| 亚洲成av人在线观看| 欧美一区二区二区| 91视视频在线直接观看在线看网页在线看 | 日韩国产欧美在线视频| 国产三级精品在线| 欧美日韩国产一区| 99精品在线免费| 国内久久婷婷综合| 天天综合色天天综合| 亚洲欧美自拍偷拍| 国产亚洲欧美在线| 欧美一区二区三区影视| 91成人国产精品| 成人毛片老司机大片| 韩国v欧美v亚洲v日本v| 亚洲福利视频一区二区| 国产精品高潮久久久久无| 26uuu亚洲婷婷狠狠天堂| 欧美一区二区人人喊爽| 在线视频欧美区| 91在线观看视频| av电影在线观看不卡| 国产成人亚洲精品青草天美 | 亚洲柠檬福利资源导航| 国产午夜精品理论片a级大结局| 91麻豆精品国产91久久久更新时间| 色欧美片视频在线观看在线视频| 成人sese在线| 成人午夜视频福利| 国产成人午夜视频| 国产精品自拍三区| 国产精品2024| 丁香婷婷综合五月| 成人妖精视频yjsp地址| 国产99久久精品| 粉嫩在线一区二区三区视频| 国产一区二区中文字幕| 国产美女一区二区三区| 国产乱人伦偷精品视频不卡| 国产精品一区二区你懂的| 国产精品主播直播| 国产.欧美.日韩| 不卡高清视频专区| 91丨porny丨国产| 欧美在线高清视频| 69久久夜色精品国产69蝌蚪网| 欧美日韩成人综合天天影院 | 蜜桃视频一区二区三区在线观看| 日本一区中文字幕| 国精产品一区一区三区mba视频 | 欧美美女bb生活片| 日韩丝袜情趣美女图片| 久久精品欧美日韩| 亚洲精品日日夜夜| 亚洲二区视频在线| 九九精品一区二区| eeuss鲁片一区二区三区| 色综合天天综合狠狠| 欧美日韩你懂的| 久久久午夜电影| 亚洲免费毛片网站| 日本强好片久久久久久aaa| 精品一区二区三区免费观看| 不卡视频在线观看| 欧美一区午夜精品| 国产日韩欧美精品一区| 一区二区成人在线| 久久精品99国产精品| 成人黄色777网| 欧美区视频在线观看| 欧美激情一区二区| 亚洲bdsm女犯bdsm网站| 狠狠色狠狠色合久久伊人| 91网页版在线| 欧美成人bangbros| 亚洲欧美激情插| 精品一区二区三区视频在线观看| 成人av免费在线播放| 5858s免费视频成人| 亚洲欧洲日韩女同| 蜜臀av亚洲一区中文字幕| 91视视频在线观看入口直接观看www | 欧美性一区二区| 国产亚洲自拍一区| 亚洲v中文字幕| 91香蕉视频在线| 国产肉丝袜一区二区| 亚洲午夜电影在线| av一本久道久久综合久久鬼色| 欧美剧情片在线观看| 中文字幕一区二区三区不卡| 国产呦精品一区二区三区网站| 欧美在线播放高清精品| 中文字幕第一区综合| 久久99国产精品免费网站| 在线看一区二区| 中文字幕欧美一| 国产精品一线二线三线| 7777精品伊人久久久大香线蕉超级流畅| 国产精品第一页第二页第三页| 麻豆一区二区在线| 欧美麻豆精品久久久久久| 亚洲精品水蜜桃| 99精品视频在线播放观看| 国产欧美日韩精品在线| 国产最新精品精品你懂的| 欧美一卡二卡在线观看| 亚洲成av人片在线| 欧美性猛交xxxx黑人交| 最好看的中文字幕久久| aaa亚洲精品| 中文字幕一区二区三区不卡| 国产九色精品成人porny| 精品国产区一区| 另类人妖一区二区av| 91精品综合久久久久久| 无吗不卡中文字幕| 欧美另类高清zo欧美| 日本视频在线一区| 日韩久久精品一区| 精品影视av免费|