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

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

?? mmc_bus.c

?? UDA1341音頻接口芯片的驅動源碼,可以支持立體聲耳機與麥克風
?? C
字號:
/* * drivers/mmc/mmc_bus.c * * MMC bus protocol interfaces  * * Copyright (C) 2001-2003 MIZI Research, Inc. * * Author: Yong-iL Joh <tolkien@mizi.com> * $Id: mmc_bus.c,v 1.2 2004/01/26 08:29:56 laputa Exp $ * * Revision History: * * 2001-XX-XX Yong-iL Joh <tolkien@mizi.com> * - initial release * * 2002-07-25 Chan Gyun Jeong <cgjeong@mizi.com> * - code cleanup  * * 2002-12-07 Chan Gyun Jeong <cgjeong@mizi.com> * - rough restructuring for S3C2410 SD Controller * */#include <linux/config.h>#include <linux/module.h>#include <linux/kernel.h>#include <linux/init.h>#include <linux/errno.h>#include <linux/delay.h>#ifdef CONFIG_PROC_FS#include <linux/proc_fs.h>#endif#include "mmc.h"#define MMC_RETRIES_MAX		20#define MMC_RETRIES_SD_CHECK	2#define MMC_OP_COND_DELAY	set_current_state(TASK_INTERRUPTIBLE); \				schedule_timeout(HZ/10)static DECLARE_MUTEX(mmc_slots_mutex);static struct mmc_slot *mmc_slots[MAX_MMC_SLOTS];static struct mmc_notifier *mmc_notifiers;const int mmc_res_len[] = {	0,	MMC_RES_LEN_SHORT,	MMC_RES_LEN_SHORT,	MMC_RES_LEN_LONG,	MMC_RES_LEN_SHORT,	MMC_RES_LEN_SHORT,	MMC_RES_LEN_SHORT,	MMC_RES_LEN_SHORT,};static int mmc_do_transfer_1blk(struct mmc_slot *slot, int rd, u_long from, 				u_char *buf){	int ret;	struct mmc_cmd cmd;	DEBUG2(3, "[%s] from: %lu, read: %d\n", __FUNCTION__, from, rd);#if 0	/* I don't know how to do	   if there exists difference between read_len and write_len */	if (!rd && (slot->read_len != slot->write_len))		return -EINVAL;	if ((from % slot->read_len) || (from >= slot->sizes))		return -EINVAL;#endif	ret = down_interruptible(&slot->mutex);	if (ret < 0) {		return ret;	}	/* check card-state. if card-state != StandBy, return BUSY */	cmd.cmd = MMC_CMD13;	cmd.arg = (slot->rca << 16) & 0xffff0000;	cmd.res_type = MMC_RES_TYPE_R1;	cmd.res_flag = 0;	cmd.t_res = MMC_TIME_NCR_MAX;	cmd.t_fin = MMC_TIME_NRC_MIN;	ret = slot->send_cmd(slot, &cmd);	DEBUG2(2, "sent CMD13\n");	if (ret < 0) {		DEBUG2(1, "CMD13 failed, ret = %d\n", ret);		goto err;	}	mmc_str2r1(&(slot->r1), cmd.res);	if (slot->r1 & (R1_cc_err | R1_err)) {		DEBUG2(1, "CMD13 failed, R1(0x%08x)\n", slot->r1);		ret = -EIO;		goto err;	}	if (!(slot->r1 & STATE_STBY)) {		DEBUG2(1, "CMD13 failed, R1(0x%08x): Busy\n", slot->r1);		ret = -EBUSY;		goto err;	}	/* SELECT CARD & set card state from Stand-by to Transfer */	cmd.cmd = MMC_CMD7;	cmd.arg = (slot->rca << 16) & 0xffff0000;//printk("RCA=%d\n", slot->rca);	//hzh	cmd.res_type = MMC_RES_TYPE_R1;	cmd.res_flag = 0;	cmd.t_res = MMC_TIME_NCR_MAX;	cmd.t_fin = MMC_TIME_NRC_MIN;	ret = slot->send_cmd(slot, &cmd);	DEBUG2(2, "sent CMD7\n");	if (ret < 0) {		DEBUG2(1, "CMD7 failed, ret = %d\n", ret);		goto err;	}	mmc_str2r1(&(slot->r1), cmd.res);	if (slot->r1 & (R1_cc_err | R1_err)) {		DEBUG2(1, "CMD7 failed, R1(0x%08x)\n", slot->r1);		ret = -EIO;		goto err;	}	ret = 0;	if (rd) {		/* adtc, 31:0 dadr, R1, READ_SINGLE_BLOCK */		/* set card state from Transfer to Sending-data */		cmd.cmd = MMC_CMD17;		cmd.arg = from;		cmd.res_type = MMC_RES_TYPE_R1;		cmd.res_flag = MMC_RES_FLAG_RDATA;		cmd.data = buf;		cmd.data_len = slot->read_len;		cmd.t_res = MMC_TIME_NCR_MAX;		cmd.t_fin = MMC_TIME_NAC_MIN;		ret = slot->send_cmd(slot, &cmd);		DEBUG2(2, "sent CMD17\n");		if (ret < 0) {			DEBUG2(1, "CMD17 failed, ret = %d\n", ret);		}	} else {		/* adtc, 31:0 dadr, R1, WRITE_SINGLE_BLOCK */		/* set card state from Transfer to Receive-data */		cmd.cmd = MMC_CMD24;		cmd.arg = from;		cmd.res_type = MMC_RES_TYPE_R1;		cmd.res_flag = MMC_RES_FLAG_WDATA;		cmd.data = buf;		cmd.data_len = slot->write_len;		cmd.t_res = MMC_TIME_NCR_MAX;		cmd.t_fin = MMC_TIME_NWR_MIN;		ret = slot->send_cmd(slot, &cmd);		DEBUG2(2, "sent CMD24\n");		if (ret < 0) {			DEBUG2(1, "CMD24 failed, ret = %d\n", ret);		}	}	/* DESELECT CARD */	cmd.cmd = MMC_CMD7;	cmd.arg = 0;	cmd.res_type = MMC_RES_TYPE_NONE;	cmd.res_flag = 0;	cmd.t_fin = MMC_TIME_NRC_MIN;	slot->send_cmd(slot, &cmd);	DEBUG2(2, "sent CMD7(DESELECT)\n"); err:	up(&slot->mutex);	return ret;}inline static int mmc_reset(struct mmc_slot *slot){	int ret;	struct mmc_cmd cmd;	/* go IDLE state */	cmd.cmd = MMC_CMD0;	cmd.arg = 0;	cmd.res_type = MMC_RES_TYPE_NONE;	cmd.res_flag = 0;	cmd.t_fin = MMC_TIME_NCC_MIN;	ret = slot->send_cmd(slot, &cmd);	DEBUG2(2, "sent CMD0\n");	if (ret < 0) {		DEBUG2(1, "CMD0 failed, ret = %d\n", ret);		return ret;	}	/* wait for reset */	if (slot->wait_for_reset) {		slot->wait_for_reset(slot);	}	return 0;}inline static int mmc_identify(struct mmc_slot *slot){	int ret;	int retries = MMC_RETRIES_MAX;	struct mmc_cmd cmd; retry_send_op_cond:	/* SEND_OP_COND */	slot->ocr = MMC_VDD_27_36;	cmd.cmd = MMC_CMD1;	cmd.arg = slot->ocr;	cmd.res_type = MMC_RES_TYPE_R3;	cmd.res_flag = MMC_RES_FLAG_NOCRC;	cmd.t_res = MMC_TIME_NCR_MAX;	cmd.t_fin = MMC_TIME_NRC_MIN;	ret = slot->send_cmd(slot, &cmd);	DEBUG2(2, "sent CMD1\n");	if (ret < 0) {		DEBUG2(1, "CMD1 failed, ret = %d\n", ret);		if (ret != -ENODEV && retries--) {			ret = mmc_reset(slot);			if (ret < 0) {				return ret;			}			MMC_OP_COND_DELAY;			goto retry_send_op_cond;		}		return -ENODEV;	}	mmc_str2ocr(&(slot->ocr), cmd.res);	if (!(slot->ocr & MMC_nCARD_BUSY)) {		DEBUG2(1, "CMD1 failed, ocr = 0x%08x\n", slot->ocr);		if (retries--) {			MMC_OP_COND_DELAY;			goto retry_send_op_cond;		}		return -ENODEV;	}	DEBUG2(3, "ocr = %08x\n", slot->ocr);	/* ALL_SEND_CID */	cmd.cmd = MMC_CMD2;	cmd.arg = 0;	cmd.res_type = MMC_RES_TYPE_R2;	cmd.res_flag = 0;	cmd.t_res = MMC_TIME_NID_MAX;	cmd.t_fin = MMC_TIME_NRC_MIN;	ret = slot->send_cmd(slot, &cmd);	DEBUG2(2, "sent CMD2\n");	if (ret < 0) {		DEBUG2(1, "CMD2 failed, ret = %d\n", ret);		return ret;	}	mmc_str2cid(&(slot->cid), cmd.res);	DEBUG2(3, "mid = 0x%02x, oid = 0x%04x, pnm = %s, prv = %d\n"	       "psn = 0x%08x, mdt = 0x%02x\n",	       slot->cid.mid, slot->cid.oid, slot->cid.pnm,	       slot->cid.prv, slot->cid.psn, slot->cid.mdt);	/* SET_RELATIVE_ADDR, Stand-by State */	slot->rca = 1 + slot->id; /* slot id begins at 0 */	cmd.cmd = MMC_CMD3;	cmd.arg = (slot->rca << 16) & 0xffff0000;	cmd.res_type = MMC_RES_TYPE_R1;	cmd.res_flag = 0;	cmd.t_res = MMC_TIME_NCR_MAX;	cmd.t_fin = MMC_TIME_NRC_MIN;	ret = slot->send_cmd(slot, &cmd);	DEBUG2(2, "sent CMD3\n");	if (ret < 0) {		DEBUG2(1, "CMD3 failed, ret = %d\n", ret);		return ret;	}	mmc_str2r1(&(slot->r1), cmd.res);	if (!(slot->r1 & STATE_IDENT)) {		DEBUG2(1, "CMD3 failed, r1 = 0x%08x\n", slot->r1);		return -ENODEV;	}	DEBUG2(3, "R1 = %08x\n", slot->r1);	/* SEND_CSD, Stand-by State */	cmd.cmd = MMC_CMD9;	cmd.arg = (slot->rca << 16) & 0xffff0000;	cmd.res_type = MMC_RES_TYPE_R2;	cmd.res_flag = 0;	cmd.t_res = MMC_TIME_NCR_MAX;	cmd.t_fin = MMC_TIME_NRC_MIN;	ret = slot->send_cmd(slot, &cmd);	DEBUG2(2, "sent CMD9\n");	if (ret < 0) {		DEBUG2(1, "CMD9 failed, ret = %d\n", ret);		return ret;	}	mmc_str2csd(&(slot->csd), cmd.res);	DEBUG2(3, "csd(%d) spec(%d) taac.man(%d) taac.exp(%d) nsac(%d)\n"	       "tran.man(%d) tran.exp(%d) ccc(%03x) read_len(%d)\n"	       "read_part(%d) write_mis(%d) read_mis(%d) dsr(%d) c_size(%d)\n"	       "vcc_r_min(%d) vcc_r_max(%d) vcc_w_min(%d) vcc_w_max(%d)\n"	       "c_size_mult(%d) er_size(%d) er_grp_size(%d) wp_grp_size(%d)\n"	       "wp_grp_en(%d) dflt_ecc(%d) r2w_factor(%d) write_len(%d)\n"	       "write_part(%d) ffmt_grp(%d) copy(%d) perm_wp(%d) tmp_wp(%d)\n"	       "ffmt(%d) ecc(%d)\n",	       slot->csd.csd, slot->csd.spec_vers, slot->csd.taac.man, 	       slot->csd.taac.exp, slot->csd.nsac, slot->csd.tran_speed.man, 	       slot->csd.tran_speed.exp, slot->csd.ccc, slot->csd.read_len, 	       slot->csd.read_part, slot->csd.write_mis, slot->csd.read_mis,	       slot->csd.dsr, slot->csd.c_size, slot->csd.vcc_r_min, 	       slot->csd.vcc_r_max, slot->csd.vcc_w_min, slot->csd.vcc_w_max,	       slot->csd.c_size_mult, slot->csd.er_size, 	       slot->csd.er_grp_size, slot->csd.wp_grp_size, 	       slot->csd.wp_grp_en, slot->csd.dflt_ecc, slot->csd.r2w_factor, 	       slot->csd.write_len, slot->csd.write_part, slot->csd.ffmt_grp,	       slot->csd.copy, slot->csd.perm_wp, slot->csd.tmp_wp,	       slot->csd.ffmt, slot->csd.ecc);	/* Get CSD value */	mmc_get_CSD_info(slot, &(slot->csd));	/* Set high clock rate for the normal data transfer */	slot->set_clock(slot, MMC_MMC_CLOCK_HIGH);	return 0;}static int card_identify(struct mmc_slot *slot){	int ret;	int retry = MMC_RETRIES_SD_CHECK;	struct mmc_cmd cmd;	/* Initialize some slot variables */	slot->rca = 0;	/* Power up */	if (slot->power_up) {		slot->power_up(slot);	}	/* Set low clock rate for the indentification */	slot->set_clock(slot, MMC_MMC_CLOCK_LOW); retry_card_check:	/* go IDLE state */	ret = mmc_reset(slot);	if (ret < 0) {		return ret;	}	/* check whether it's a MMC or a SD card. */	/* APP_CMD */	cmd.cmd = MMC_CMD55;	cmd.arg = (slot->rca << 16) & 0xffff0000;	cmd.res_type = MMC_RES_TYPE_R1;	cmd.res_flag = 0;	cmd.t_res = MMC_TIME_NCR_MAX;	cmd.t_fin = MMC_TIME_NRC_MIN;	ret = slot->send_cmd(slot, &cmd);	DEBUG2(2, "sent CMD55\n");	if (ret < 0) {		if (ret == -ENODEV) {			return ret;		}		if (retry--) {			DEBUG2(1, "retry to check MMC or SD\n");			goto retry_card_check;		}		DEBUG2(1, "identify MultiMediaCard\n");		ret = mmc_identify(slot);	} else {                DEBUG2(1, " SD Memory Card IDentified. Use SDMC Driver\n");                printk("SD Memory Card IDentified. Use SDMC Driver\n");                ret = SD_CARD;        }                                                                                	return ret;}#ifdef CONFIG_PROC_FSstatic int mmc_read_proc(char *page, char **start, off_t off,                         int count, int *eof, void *data){	char *p = page;	int len;	struct mmc_slot *slot = (struct mmc_slot *)data;	p += sprintf(p, "read-only\t: %s\n"			"card type\t: %s\n"			"product name\t: %s\n"			"card size\t: %ldMB\n",			slot->readonly ? "yes":"no", "MMC",			slot->cid.pnm, 			slot->size/(1024 * 1024));	len = (p - page) - off;	if (len < 0) len = 0;	*eof = (len <= count) ? 1 : 0;	*start = page + off;	return len;}#endifint add_mmc_device(struct mmc_slot *slot){	int i;	DEBUG2(2, "[%s] slot id: %d\n", __FUNCTION__, slot->id);	down(&mmc_slots_mutex);	slot->stat = 0;	i = card_identify(slot);	if (i) {		up(&mmc_slots_mutex);		return i;	}	init_MUTEX(&slot->mutex);	slot->transfer1b = mmc_do_transfer_1blk;	slot->stat = 1;	for (i = 0; i < MAX_MMC_SLOTS; i++) {		if (!mmc_slots[i]) {			struct mmc_notifier *not=mmc_notifiers;			mmc_slots[i] = slot;			while (not) {				(*(not->add))(slot);				not = not->next;                        }			up(&mmc_slots_mutex);			MOD_INC_USE_COUNT;#ifdef CONFIG_PROC_FS			create_proc_read_entry ("driver/mmc", 0, NULL, 						mmc_read_proc, (void *)slot);#endif			return 0;		}	}	up(&mmc_slots_mutex);	return -ENOSPC;}int del_mmc_device(struct mmc_slot *slot){	int i;	DEBUG2(2, "[%s] slot id: %d\n", __FUNCTION__, slot->id);	down(&mmc_slots_mutex);	/* Power down */	if (slot->power_down) {		slot->power_down(slot);	}	for (i = 0; i < MAX_MMC_SLOTS; i++) {		if (mmc_slots[i] == slot) {			struct mmc_notifier *not=mmc_notifiers;#ifdef CONFIG_PROC_FS			remove_proc_entry ("driver/mmc", NULL);#endif			while (not) {				(*(not->remove))(slot);				not = not->next;			}			mmc_slots[i] = NULL;			up (&mmc_slots_mutex);			MOD_DEC_USE_COUNT;			return 0;		}	}	up(&mmc_slots_mutex);	return -EINVAL;}int reidentify_mmc_device(struct mmc_slot *slot){	int ret;	down(&mmc_slots_mutex);	ret = card_identify(slot);	up(&mmc_slots_mutex);	return ret;}void register_mmc_user(struct mmc_notifier *new){	int i;	down(&mmc_slots_mutex);	new->next = mmc_notifiers;	mmc_notifiers = new;	MOD_INC_USE_COUNT;	for (i=0; i< MAX_MMC_SLOTS; i++)		if (mmc_slots[i])			new->add(mmc_slots[i]);	up(&mmc_slots_mutex);}int unregister_mmc_user(struct mmc_notifier *old){	struct mmc_notifier **prev = &mmc_notifiers;	struct mmc_notifier *cur;	int i;	down(&mmc_slots_mutex);	while ((cur = *prev)) {		if (cur == old) {			*prev = cur->next;			MOD_DEC_USE_COUNT;			for (i=0; i< MAX_MMC_SLOTS; i++)				if (mmc_slots[i])					old->remove(mmc_slots[i]);			up(&mmc_slots_mutex);			return 0;		}		prev = &cur->next;	}	up(&mmc_slots_mutex);	return 1;}static int __init init_mmc_bus(void){	int i;	for (i = 0; i < MAX_MMC_SLOTS; i++) {		mmc_slots[i] = NULL;	}	mmc_notifiers = NULL;	return 0;}static void __exit exit_mmc_bus(void){}module_init(init_mmc_bus);module_exit(exit_mmc_bus);EXPORT_SYMBOL(add_mmc_device);EXPORT_SYMBOL(del_mmc_device);EXPORT_SYMBOL(reidentify_mmc_device);EXPORT_SYMBOL(register_mmc_user);EXPORT_SYMBOL(unregister_mmc_user);EXPORT_SYMBOL(mmc_res_len);MODULE_AUTHOR("Yong-iL Joh <tolkien@mizi.com>");MODULE_LICENSE("Not GPL, Proprietary License");MODULE_DESCRIPTION("MMC bus protocol interfaces");

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
狠狠v欧美v日韩v亚洲ⅴ| 日韩免费电影网站| 欧美一二三区在线| 1区2区3区欧美| 韩日精品视频一区| 91麻豆精品国产91| 一区二区在线免费观看| 国产电影一区二区三区| 欧美一级高清片| 亚洲午夜电影网| aaa欧美大片| 中文字幕精品三区| 国产精品 欧美精品| 日韩精品在线一区二区| 日韩激情中文字幕| 欧美日韩一级大片网址| 亚洲人123区| av亚洲精华国产精华精华| 国产亚洲人成网站| 精品一区二区三区欧美| 欧美一区二区成人| 石原莉奈在线亚洲二区| 欧美美女直播网站| 天天爽夜夜爽夜夜爽精品视频| 99九九99九九九视频精品| 国产精品萝li| 成人一级黄色片| 国产精品久久久久久久久搜平片| 国产精品911| 欧美韩国日本综合| av在线不卡网| 一区二区欧美精品| 欧美亚洲综合另类| 亚洲成a天堂v人片| 欧美一区二区私人影院日本| 毛片av一区二区三区| 日韩三级免费观看| 另类成人小视频在线| 欧美精品一区二区三区在线播放| 蜜桃91丨九色丨蝌蚪91桃色| 日韩视频在线观看一区二区| 久久超碰97中文字幕| 久久日韩粉嫩一区二区三区| 国产成人av自拍| ㊣最新国产の精品bt伙计久久| av不卡免费在线观看| 亚洲综合色噜噜狠狠| 欧美一区二区三区在线视频| 国产一区美女在线| 亚洲欧洲日韩av| 欧美日韩国产成人在线免费| 麻豆精品一区二区av白丝在线| 26uuu国产一区二区三区| 成人免费看的视频| 伊人夜夜躁av伊人久久| 欧美一区二区国产| 波多野结衣精品在线| 亚洲综合免费观看高清完整版在线 | 亚洲精品成a人| 精品视频在线免费看| 精品一区中文字幕| 1区2区3区国产精品| 欧美一级免费大片| 成人免费福利片| 天天综合日日夜夜精品| 国产拍揄自揄精品视频麻豆| 在线视频一区二区免费| 美女mm1313爽爽久久久蜜臀| 中文字幕一区视频| 欧美videos中文字幕| 日本高清视频一区二区| 国产在线精品一区二区 | 国产日韩欧美a| 欧美性生活一区| 国产丶欧美丶日本不卡视频| 亚洲成人免费在线| 亚洲国产精品v| 日韩三级在线免费观看| 在线看不卡av| 成人性生交大片免费看在线播放| 亚洲国产精品精华液网站| 国产精品丝袜一区| 欧美sm极限捆绑bd| 欧美人成免费网站| 91一区一区三区| 国产激情视频一区二区在线观看 | 中文天堂在线一区| 欧美大片一区二区| 欧美日韩一区在线| 99v久久综合狠狠综合久久| 狠狠色伊人亚洲综合成人| 性感美女极品91精品| 亚洲视频一区二区在线| 国产日韩欧美麻豆| 欧美电影免费提供在线观看| 欧美剧情电影在线观看完整版免费励志电影 | 精品sm在线观看| 91精品国产综合久久精品app| 色综合咪咪久久| 成人黄色777网| 国产成人午夜精品影院观看视频| 看电视剧不卡顿的网站| 视频一区欧美精品| 午夜久久久久久电影| 亚洲欧美偷拍卡通变态| 亚洲欧洲在线观看av| 国产精品色在线观看| 中文字幕电影一区| 中文字幕在线观看不卡| 中文字幕在线观看一区二区| 欧美国产禁国产网站cc| 久久久久国产精品厨房| 国产午夜久久久久| 久久久国产精华| 欧美国产一区视频在线观看| 国产三级久久久| 中文字幕一区二区三中文字幕| 中文成人av在线| 国产精品国产三级国产a| 亚洲色图在线播放| 一区二区三区免费网站| 亚洲午夜日本在线观看| 午夜精品久久久久久久久久| 日韩国产在线一| 男女男精品视频网| 国产乱码精品一区二区三 | 欧美亚洲国产一区二区三区| 欧美在线观看视频一区二区 | 日日噜噜夜夜狠狠视频欧美人 | 国产亚洲精品7777| 精品女同一区二区| 久久久高清一区二区三区| 久久亚洲精品小早川怜子| 中文字幕成人网| 亚洲欧美影音先锋| 午夜av电影一区| 日本韩国一区二区三区视频| 欧美精品一二三四| 欧美成人伊人久久综合网| 国产欧美一区二区三区沐欲| 亚洲久草在线视频| 日韩av一区二| 成+人+亚洲+综合天堂| 欧美性猛交xxxx乱大交退制版| 9191成人精品久久| 国产欧美一二三区| 亚洲一区二区精品久久av| 麻豆精品在线播放| 91网址在线看| 精品日韩99亚洲| 一区在线中文字幕| 老司机午夜精品99久久| 一本色道久久加勒比精品| 日韩精品一区二区三区视频在线观看 | 国产精品午夜春色av| 亚洲r级在线视频| 国产盗摄女厕一区二区三区| 欧美日韩高清不卡| 国产精品狼人久久影院观看方式| 视频一区二区三区中文字幕| 成人黄色在线视频| 精品蜜桃在线看| 亚洲va欧美va天堂v国产综合| 国产精品18久久久久久久久久久久| 在线观看国产日韩| 日本一区二区久久| 老司机午夜精品99久久| 欧美三级乱人伦电影| 国产精品免费看片| 精品一区二区三区久久| 欧美军同video69gay| 亚洲精品免费看| 欧美一区二区久久久| 亚洲自拍偷拍图区| av午夜一区麻豆| 欧美激情一区二区在线| 韩国三级中文字幕hd久久精品| 在线免费观看日本一区| 国产精品嫩草影院com| 国产美女娇喘av呻吟久久| 欧美一区中文字幕| 亚洲福利电影网| 色婷婷综合久久| 亚洲老司机在线| 色综合一区二区三区| 欧美国产综合色视频| 东方aⅴ免费观看久久av| 久久久影视传媒| 国产精品白丝jk黑袜喷水| 欧美大片在线观看一区二区| 免费欧美高清视频| 9191久久久久久久久久久| 日日欢夜夜爽一区| 欧美一级片在线观看| 视频一区国产视频| 欧美一区二区三区人| 美女视频黄 久久| 精品国产乱码久久久久久夜甘婷婷| 免费久久99精品国产| 欧美电影免费观看高清完整版在线|