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

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

?? mmc_bus.c

?? samsung s3c2410 的sd/mmc driver
?? 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;	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一区二区三区免费野_久草精品视频
日韩免费福利电影在线观看| 亚洲国产aⅴ成人精品无吗| 中文字幕一区二区三| 五月天精品一区二区三区| 国产风韵犹存在线视精品| 欧美日韩一级大片网址| 欧美韩国日本不卡| 老司机精品视频导航| 日本韩国一区二区三区| 欧美激情在线一区二区三区| 美女视频黄 久久| 91黄色在线观看| 国产精品视频线看| 国产精品自拍三区| 日韩欧美一卡二卡| 日韩精品久久理论片| 色综合中文字幕国产 | 国内精品在线播放| 欧美日本在线播放| 亚洲一区在线观看网站| 91毛片在线观看| 国产精品每日更新在线播放网址 | 亚洲主播在线观看| 91女人视频在线观看| 国产精品少妇自拍| 风间由美一区二区av101| 久久精品亚洲精品国产欧美| 久久成人精品无人区| 日韩午夜在线观看| 日韩成人午夜电影| 欧美日韩成人综合| 污片在线观看一区二区| 91官网在线观看| 亚洲一区精品在线| 欧美日韩一区二区三区视频| 亚洲国产精品一区二区www在线| 日本乱人伦一区| 亚洲精品视频免费观看| 欧洲精品一区二区三区在线观看| 亚洲激情图片qvod| 色婷婷亚洲综合| 亚洲精品乱码久久久久久日本蜜臀 | 国模一区二区三区白浆| 久久色.com| 97se狠狠狠综合亚洲狠狠| 亚洲乱码精品一二三四区日韩在线| 99久久99久久精品免费看蜜桃| 亚洲乱码国产乱码精品精小说| 在线欧美一区二区| 免费三级欧美电影| 国产欧美日韩卡一| 99精品黄色片免费大全| 亚洲一区二区三区在线| 成人精品一区二区三区中文字幕| 欧美一区二区在线观看| 久久精品国产一区二区三区免费看| 欧美videossexotv100| 国产一区二区美女| 亚洲欧洲色图综合| 欧美高清性hdvideosex| 国产传媒日韩欧美成人| 亚洲精品国产成人久久av盗摄| 欧美日韩国产色站一区二区三区| 免费xxxx性欧美18vr| 久久久精品国产免大香伊| 91麻豆成人久久精品二区三区| 性感美女极品91精品| 337p粉嫩大胆噜噜噜噜噜91av | 亚洲免费色视频| 91精品国产色综合久久| 风间由美一区二区三区在线观看| 亚洲国产精品一区二区久久| 久久精品亚洲精品国产欧美| 在线免费精品视频| 国内精品不卡在线| 亚洲成人午夜影院| 国产精品毛片无遮挡高清| 欧美日韩成人综合| 成人性生交大片免费看中文 | 午夜私人影院久久久久| 国产日韩欧美精品综合| 这里只有精品视频在线观看| 国产91精品一区二区麻豆亚洲| 午夜私人影院久久久久| 国产精品黄色在线观看| 欧美成人一区二区| 欧美婷婷六月丁香综合色| 懂色av中文字幕一区二区三区| 秋霞电影网一区二区| 亚洲色欲色欲www| 久久久国产精品午夜一区ai换脸| 欧美日韩国产一区二区三区地区| 99视频精品全部免费在线| 精品无人码麻豆乱码1区2区 | 国产精品大尺度| 26uuu色噜噜精品一区二区| 91国产丝袜在线播放| 欧美日韩国产高清一区| 大白屁股一区二区视频| 精品一区二区免费在线观看| 午夜精品一区二区三区免费视频 | 喷水一区二区三区| 亚洲va天堂va国产va久| 亚洲精品乱码久久久久久黑人| 日本一区二区视频在线| 精品精品国产高清一毛片一天堂| 欧美性做爰猛烈叫床潮| 在线观看亚洲精品视频| 色哟哟国产精品| 91福利在线播放| 欧美在线观看禁18| 欧美三级一区二区| 色哟哟日韩精品| 91国产福利在线| 欧美性极品少妇| 6080亚洲精品一区二区| 欧美电影一区二区| 日韩一级视频免费观看在线| 欧美一区二区三区成人| 日韩欧美国产综合一区 | 国内精品久久久久影院薰衣草| 久久精品久久99精品久久| 激情五月婷婷综合| 国产裸体歌舞团一区二区| 国产99精品国产| 风间由美一区二区三区在线观看 | 26uuu国产电影一区二区| 精品播放一区二区| 欧美国产欧美综合| 亚洲美女偷拍久久| 亚洲一区二区三区不卡国产欧美| 亚洲国产视频一区| 成人午夜短视频| 91在线小视频| 欧美日韩在线播放三区四区| 555www色欧美视频| 精品国产网站在线观看| 欧美国产成人精品| 亚洲午夜在线视频| 免费在线观看不卡| www.亚洲色图| 欧美日本在线视频| 久久综合99re88久久爱| 亚洲图片另类小说| 免费观看日韩电影| 成人国产电影网| 91视视频在线观看入口直接观看www | 成人欧美一区二区三区1314| 久久精品综合网| 亚洲欧美激情一区二区| 美女网站色91| 欧美日韩国产乱码电影| 亚洲天堂精品视频| 日本欧美大码aⅴ在线播放| 国产一区二区调教| 在线成人午夜影院| 国产精品久久久一区麻豆最新章节| 中文字幕精品三区| 亚洲国产另类av| 美国十次综合导航| 精品视频在线看| 天堂影院一区二区| 99久久综合国产精品| 欧美成人激情免费网| 欧美亚洲另类激情小说| 国产99久久久精品| 中文字幕一区av| 欧美系列亚洲系列| 亚洲色图欧洲色图| 韩国欧美一区二区| 7777精品伊人久久久大香线蕉的| 2019国产精品| 国产在线播放一区| 欧美一区二区三区免费视频 | 日本亚洲最大的色成网站www| 国产一区二区视频在线| 亚洲国产日产av| 午夜精品一区在线观看| 亚洲欧美日韩一区二区 | 午夜精品爽啪视频| 不卡大黄网站免费看| 精品理论电影在线| 日韩av中文字幕一区二区三区| 一本久道中文字幕精品亚洲嫩| 欧美经典三级视频一区二区三区| 日韩av电影天堂| 欧美日韩一区二区三区在线看 | 国产精品一区二区久久不卡| 欧美精品久久99久久在免费线 | 一区二区不卡在线视频 午夜欧美不卡在| 日本不卡在线视频| 欧美性大战久久久久久久 | 久久婷婷久久一区二区三区| 日日夜夜精品免费视频| 欧美视频一区二区三区| 亚洲成人你懂的| 欧美午夜影院一区| 亚洲国产一区在线观看| 欧美日韩国产综合一区二区三区| 亚洲国产成人porn|