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

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

?? pxamci.c

?? mmc 記憶棒驅動 for linux ,可以看一看
?? C
字號:
/* *  linux/drivers/mmc/pxa.c - PXA MMCI driver * *  Copyright (C) 2003 Russell King, All Rights Reserved. * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License version 2 as * published by the Free Software Foundation. * *  This hardware is really sick: *   - No way to clear interrupts. *   - Have to turn off the clock whenever we touch the device. *   - Doesn't tell you how many data blocks were transferred. *  Yuck! * *	1 and 3 byte data transfers not supported *	max block length up to 1023 */#include <linux/config.h>#include <linux/module.h>#include <linux/init.h>#include <linux/ioport.h>#include <linux/platform_device.h>#include <linux/delay.h>#include <linux/interrupt.h>#include <linux/dma-mapping.h>#include <linux/mmc/host.h>#include <linux/mmc/protocol.h>#include <asm/dma.h>#include <asm/io.h>#include <asm/scatterlist.h>#include <asm/sizes.h>#include <asm/arch/pxa-regs.h>#include <asm/arch/mmc.h>#include "pxamci.h"#ifdef CONFIG_MMC_DEBUG#define DBG(x...)	printk(KERN_DEBUG x)#else#define DBG(x...)	do { } while (0)#endif#define DRIVER_NAME	"pxa2xx-mci"#define NR_SG	1struct pxamci_host {	struct mmc_host		*mmc;	spinlock_t		lock;	struct resource		*res;	void __iomem		*base;	int			irq;	int			dma;	unsigned int		clkrt;	unsigned int		cmdat;	unsigned int		imask;	unsigned int		power_mode;	struct pxamci_platform_data *pdata;	struct mmc_request	*mrq;	struct mmc_command	*cmd;	struct mmc_data		*data;	dma_addr_t		sg_dma;	struct pxa_dma_desc	*sg_cpu;	unsigned int		dma_len;	unsigned int		dma_dir;};static inline unsigned int ns_to_clocks(unsigned int ns){	return (ns * (CLOCKRATE / 1000000) + 999) / 1000;}static void pxamci_stop_clock(struct pxamci_host *host){	if (readl(host->base + MMC_STAT) & STAT_CLK_EN) {		unsigned long timeout = 10000;		unsigned int v;		writel(STOP_CLOCK, host->base + MMC_STRPCL);		do {			v = readl(host->base + MMC_STAT);			if (!(v & STAT_CLK_EN))				break;			udelay(1);		} while (timeout--);		if (v & STAT_CLK_EN)			dev_err(mmc_dev(host->mmc), "unable to stop clock\n");	}}static void pxamci_enable_irq(struct pxamci_host *host, unsigned int mask){	unsigned long flags;	spin_lock_irqsave(&host->lock, flags);	host->imask &= ~mask;	writel(host->imask, host->base + MMC_I_MASK);	spin_unlock_irqrestore(&host->lock, flags);}static void pxamci_disable_irq(struct pxamci_host *host, unsigned int mask){	unsigned long flags;	spin_lock_irqsave(&host->lock, flags);	host->imask |= mask;	writel(host->imask, host->base + MMC_I_MASK);	spin_unlock_irqrestore(&host->lock, flags);}static void pxamci_setup_data(struct pxamci_host *host, struct mmc_data *data){	unsigned int nob = data->blocks;	unsigned int timeout;	u32 dcmd;	int i;	host->data = data;	if (data->flags & MMC_DATA_STREAM)		nob = 0xffff;	writel(nob, host->base + MMC_NOB);	writel(1 << data->blksz_bits, host->base + MMC_BLKLEN);	timeout = ns_to_clocks(data->timeout_ns) + data->timeout_clks;	writel((timeout + 255) / 256, host->base + MMC_RDTO);	if (data->flags & MMC_DATA_READ) {		host->dma_dir = DMA_FROM_DEVICE;		dcmd = DCMD_INCTRGADDR | DCMD_FLOWTRG;		DRCMRTXMMC = 0;		DRCMRRXMMC = host->dma | DRCMR_MAPVLD;	} else {		host->dma_dir = DMA_TO_DEVICE;		dcmd = DCMD_INCSRCADDR | DCMD_FLOWSRC;		DRCMRRXMMC = 0;		DRCMRTXMMC = host->dma | DRCMR_MAPVLD;	}	dcmd |= DCMD_BURST32 | DCMD_WIDTH1;	host->dma_len = dma_map_sg(mmc_dev(host->mmc), data->sg, data->sg_len,				   host->dma_dir);	for (i = 0; i < host->dma_len; i++) {		if (data->flags & MMC_DATA_READ) {			host->sg_cpu[i].dsadr = host->res->start + MMC_RXFIFO;			host->sg_cpu[i].dtadr = sg_dma_address(&data->sg[i]);		} else {			host->sg_cpu[i].dsadr = sg_dma_address(&data->sg[i]);			host->sg_cpu[i].dtadr = host->res->start + MMC_TXFIFO;		}		host->sg_cpu[i].dcmd = dcmd | sg_dma_len(&data->sg[i]);		host->sg_cpu[i].ddadr = host->sg_dma + (i + 1) *					sizeof(struct pxa_dma_desc);	}	host->sg_cpu[host->dma_len - 1].ddadr = DDADR_STOP;	wmb();	DDADR(host->dma) = host->sg_dma;	DCSR(host->dma) = DCSR_RUN;}static void pxamci_start_cmd(struct pxamci_host *host, struct mmc_command *cmd, unsigned int cmdat){	WARN_ON(host->cmd != NULL);	host->cmd = cmd;	if (cmd->flags & MMC_RSP_BUSY)		cmdat |= CMDAT_BUSY;#define RSP_TYPE(x)	((x) & ~(MMC_RSP_BUSY|MMC_RSP_OPCODE))	switch (RSP_TYPE(mmc_resp_type(cmd))) {	case RSP_TYPE(MMC_RSP_R1): /* r1, r1b, r6 */		cmdat |= CMDAT_RESP_SHORT;		break;	case RSP_TYPE(MMC_RSP_R3):		cmdat |= CMDAT_RESP_R3;		break;	case RSP_TYPE(MMC_RSP_R2):		cmdat |= CMDAT_RESP_R2;		break;	default:		break;	}	writel(cmd->opcode, host->base + MMC_CMD);	writel(cmd->arg >> 16, host->base + MMC_ARGH);	writel(cmd->arg & 0xffff, host->base + MMC_ARGL);	writel(cmdat, host->base + MMC_CMDAT);	writel(host->clkrt, host->base + MMC_CLKRT);	writel(START_CLOCK, host->base + MMC_STRPCL);	pxamci_enable_irq(host, END_CMD_RES);}static void pxamci_finish_request(struct pxamci_host *host, struct mmc_request *mrq){	DBG("PXAMCI: request done\n");	host->mrq = NULL;	host->cmd = NULL;	host->data = NULL;	mmc_request_done(host->mmc, mrq);}static int pxamci_cmd_done(struct pxamci_host *host, unsigned int stat){	struct mmc_command *cmd = host->cmd;	int i;	u32 v;	if (!cmd)		return 0;	host->cmd = NULL;	/*	 * Did I mention this is Sick.  We always need to	 * discard the upper 8 bits of the first 16-bit word.	 */	v = readl(host->base + MMC_RES) & 0xffff;	for (i = 0; i < 4; i++) {		u32 w1 = readl(host->base + MMC_RES) & 0xffff;		u32 w2 = readl(host->base + MMC_RES) & 0xffff;		cmd->resp[i] = v << 24 | w1 << 8 | w2 >> 8;		v = w2;	}	if (stat & STAT_TIME_OUT_RESPONSE) {		cmd->error = MMC_ERR_TIMEOUT;	} else if (stat & STAT_RES_CRC_ERR && cmd->flags & MMC_RSP_CRC) {#ifdef CONFIG_PXA27x		/*		 * workaround for erratum #42:		 * Intel PXA27x Family Processor Specification Update Rev 001		 */		if (cmd->opcode == MMC_ALL_SEND_CID ||		    cmd->opcode == MMC_SEND_CSD ||		    cmd->opcode == MMC_SEND_CID) {			/* a bogus CRC error can appear if the msb of			   the 15 byte response is a one */			if ((cmd->resp[0] & 0x80000000) == 0)				cmd->error = MMC_ERR_BADCRC;		} else {			DBG("ignoring CRC from command %d - *risky*\n",cmd->opcode);		}#else		cmd->error = MMC_ERR_BADCRC;#endif	}	pxamci_disable_irq(host, END_CMD_RES);	if (host->data && cmd->error == MMC_ERR_NONE) {		pxamci_enable_irq(host, DATA_TRAN_DONE);	} else {		pxamci_finish_request(host, host->mrq);	}	return 1;}static int pxamci_data_done(struct pxamci_host *host, unsigned int stat){	struct mmc_data *data = host->data;	if (!data)		return 0;	DCSR(host->dma) = 0;	dma_unmap_sg(mmc_dev(host->mmc), data->sg, host->dma_len,		     host->dma_dir);	if (stat & STAT_READ_TIME_OUT)		data->error = MMC_ERR_TIMEOUT;	else if (stat & (STAT_CRC_READ_ERROR|STAT_CRC_WRITE_ERROR))		data->error = MMC_ERR_BADCRC;	/*	 * There appears to be a hardware design bug here.  There seems to	 * be no way to find out how much data was transferred to the card.	 * This means that if there was an error on any block, we mark all	 * data blocks as being in error.	 */	if (data->error == MMC_ERR_NONE)		data->bytes_xfered = data->blocks << data->blksz_bits;	else		data->bytes_xfered = 0;	pxamci_disable_irq(host, DATA_TRAN_DONE);	host->data = NULL;	if (host->mrq->stop && data->error == MMC_ERR_NONE) {		pxamci_stop_clock(host);		pxamci_start_cmd(host, host->mrq->stop, 0);	} else {		pxamci_finish_request(host, host->mrq);	}	return 1;}static irqreturn_t pxamci_irq(int irq, void *devid, struct pt_regs *regs){	struct pxamci_host *host = devid;	unsigned int ireg;	int handled = 0;	ireg = readl(host->base + MMC_I_REG);	DBG("PXAMCI: irq %08x\n", ireg);	if (ireg) {		unsigned stat = readl(host->base + MMC_STAT);		DBG("PXAMCI: stat %08x\n", stat);		if (ireg & END_CMD_RES)			handled |= pxamci_cmd_done(host, stat);		if (ireg & DATA_TRAN_DONE)			handled |= pxamci_data_done(host, stat);	}	return IRQ_RETVAL(handled);}static void pxamci_request(struct mmc_host *mmc, struct mmc_request *mrq){	struct pxamci_host *host = mmc_priv(mmc);	unsigned int cmdat;	WARN_ON(host->mrq != NULL);	host->mrq = mrq;	pxamci_stop_clock(host);	cmdat = host->cmdat;	host->cmdat &= ~CMDAT_INIT;	if (mrq->data) {		pxamci_setup_data(host, mrq->data);		cmdat &= ~CMDAT_BUSY;		cmdat |= CMDAT_DATAEN | CMDAT_DMAEN;		if (mrq->data->flags & MMC_DATA_WRITE)			cmdat |= CMDAT_WRITE;		if (mrq->data->flags & MMC_DATA_STREAM)			cmdat |= CMDAT_STREAM;	}	pxamci_start_cmd(host, mrq->cmd, cmdat);}static int pxamci_get_ro(struct mmc_host *mmc){	struct pxamci_host *host = mmc_priv(mmc);	if (host->pdata && host->pdata->get_ro)		return host->pdata->get_ro(mmc->dev);	/* Host doesn't support read only detection so assume writeable */	return 0;}static void pxamci_set_ios(struct mmc_host *mmc, struct mmc_ios *ios){	struct pxamci_host *host = mmc_priv(mmc);	DBG("pxamci_set_ios: clock %u power %u vdd %u.%02u\n",	    ios->clock, ios->power_mode, ios->vdd / 100,	    ios->vdd % 100);	if (ios->clock) {		unsigned int clk = CLOCKRATE / ios->clock;		if (CLOCKRATE / clk > ios->clock)			clk <<= 1;		host->clkrt = fls(clk) - 1;		pxa_set_cken(CKEN12_MMC, 1);		/*		 * we write clkrt on the next command		 */	} else {		pxamci_stop_clock(host);		pxa_set_cken(CKEN12_MMC, 0);	}	if (host->power_mode != ios->power_mode) {		host->power_mode = ios->power_mode;		if (host->pdata && host->pdata->setpower)			host->pdata->setpower(mmc->dev, ios->vdd);		if (ios->power_mode == MMC_POWER_ON)			host->cmdat |= CMDAT_INIT;	}	DBG("pxamci_set_ios: clkrt = %x cmdat = %x\n",	    host->clkrt, host->cmdat);}static struct mmc_host_ops pxamci_ops = {	.request	= pxamci_request,	.get_ro		= pxamci_get_ro,	.set_ios	= pxamci_set_ios,};static void pxamci_dma_irq(int dma, void *devid, struct pt_regs *regs){	printk(KERN_ERR "DMA%d: IRQ???\n", dma);	DCSR(dma) = DCSR_STARTINTR|DCSR_ENDINTR|DCSR_BUSERR;}static irqreturn_t pxamci_detect_irq(int irq, void *devid, struct pt_regs *regs){	struct pxamci_host *host = mmc_priv(devid);	mmc_detect_change(devid, host->pdata->detect_delay);	return IRQ_HANDLED;}static int pxamci_probe(struct platform_device *pdev){	struct mmc_host *mmc;	struct pxamci_host *host = NULL;	struct resource *r;	int ret, irq;	r = platform_get_resource(pdev, IORESOURCE_MEM, 0);	irq = platform_get_irq(pdev, 0);	if (!r || irq == NO_IRQ)		return -ENXIO;	r = request_mem_region(r->start, SZ_4K, DRIVER_NAME);	if (!r)		return -EBUSY;	mmc = mmc_alloc_host(sizeof(struct pxamci_host), &pdev->dev);	if (!mmc) {		ret = -ENOMEM;		goto out;	}	mmc->ops = &pxamci_ops;	mmc->f_min = CLOCKRATE_MIN;	mmc->f_max = CLOCKRATE_MAX;	/*	 * We can do SG-DMA, but we don't because we never know how much	 * data we successfully wrote to the card.	 */	mmc->max_phys_segs = NR_SG;	/*	 * Our hardware DMA can handle a maximum of one page per SG entry.	 */	mmc->max_seg_size = PAGE_SIZE;	host = mmc_priv(mmc);	host->mmc = mmc;	host->dma = -1;	host->pdata = pdev->dev.platform_data;	mmc->ocr_avail = host->pdata ?			 host->pdata->ocr_mask :			 MMC_VDD_32_33|MMC_VDD_33_34;	host->sg_cpu = dma_alloc_coherent(&pdev->dev, PAGE_SIZE, &host->sg_dma, GFP_KERNEL);	if (!host->sg_cpu) {		ret = -ENOMEM;		goto out;	}	spin_lock_init(&host->lock);	host->res = r;	host->irq = irq;	host->imask = MMC_I_MASK_ALL;	host->base = ioremap(r->start, SZ_4K);	if (!host->base) {		ret = -ENOMEM;		goto out;	}	/*	 * Ensure that the host controller is shut down, and setup	 * with our defaults.	 */	pxamci_stop_clock(host);	writel(0, host->base + MMC_SPI);	writel(64, host->base + MMC_RESTO);	writel(host->imask, host->base + MMC_I_MASK);	host->dma = pxa_request_dma(DRIVER_NAME, DMA_PRIO_LOW,				    pxamci_dma_irq, host);	if (host->dma < 0) {		ret = -EBUSY;		goto out;	}	ret = request_irq(host->irq, pxamci_irq, 0, DRIVER_NAME, host);	if (ret)		goto out;	platform_set_drvdata(pdev, mmc);	if (host->pdata && host->pdata->init)		host->pdata->init(&pdev->dev, pxamci_detect_irq, mmc);	mmc_add_host(mmc);	return 0; out:	if (host) {		if (host->dma >= 0)			pxa_free_dma(host->dma);		if (host->base)			iounmap(host->base);		if (host->sg_cpu)			dma_free_coherent(&pdev->dev, PAGE_SIZE, host->sg_cpu, host->sg_dma);	}	if (mmc)		mmc_free_host(mmc);	release_resource(r);	return ret;}static int pxamci_remove(struct platform_device *pdev){	struct mmc_host *mmc = platform_get_drvdata(pdev);	platform_set_drvdata(pdev, NULL);	if (mmc) {		struct pxamci_host *host = mmc_priv(mmc);		if (host->pdata && host->pdata->exit)			host->pdata->exit(&pdev->dev, mmc);		mmc_remove_host(mmc);		pxamci_stop_clock(host);		writel(TXFIFO_WR_REQ|RXFIFO_RD_REQ|CLK_IS_OFF|STOP_CMD|		       END_CMD_RES|PRG_DONE|DATA_TRAN_DONE,		       host->base + MMC_I_MASK);		DRCMRRXMMC = 0;		DRCMRTXMMC = 0;		free_irq(host->irq, host);		pxa_free_dma(host->dma);		iounmap(host->base);		dma_free_coherent(&pdev->dev, PAGE_SIZE, host->sg_cpu, host->sg_dma);		release_resource(host->res);		mmc_free_host(mmc);	}	return 0;}#ifdef CONFIG_PMstatic int pxamci_suspend(struct platform_device *dev, pm_message_t state){	struct mmc_host *mmc = platform_get_drvdata(dev);	int ret = 0;	if (mmc)		ret = mmc_suspend_host(mmc, state);	return ret;}static int pxamci_resume(struct platform_device *dev){	struct mmc_host *mmc = platform_get_drvdata(dev);	int ret = 0;	if (mmc)		ret = mmc_resume_host(mmc);	return ret;}#else#define pxamci_suspend	NULL#define pxamci_resume	NULL#endifstatic struct platform_driver pxamci_driver = {	.probe		= pxamci_probe,	.remove		= pxamci_remove,	.suspend	= pxamci_suspend,	.resume		= pxamci_resume,	.driver		= {		.name	= DRIVER_NAME,	},};static int __init pxamci_init(void){	return platform_driver_register(&pxamci_driver);}static void __exit pxamci_exit(void){	platform_driver_unregister(&pxamci_driver);}module_init(pxamci_init);module_exit(pxamci_exit);MODULE_DESCRIPTION("PXA Multimedia Card Interface Driver");MODULE_LICENSE("GPL");

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
中文字幕日韩欧美一区二区三区| 国产激情视频一区二区在线观看 | 这里只有精品免费| 亚洲综合一二三区| 欧美嫩在线观看| 日韩精品一区第一页| 欧美一区二区三区啪啪| 久久超级碰视频| 久久精品视频网| 92精品国产成人观看免费| 亚洲精选免费视频| 欧美精品在线视频| 韩国成人福利片在线播放| 国产精品色在线| 92国产精品观看| 日日噜噜夜夜狠狠视频欧美人| 91麻豆精品国产91久久久使用方法| 蜜桃av一区二区三区| 2017欧美狠狠色| 97精品国产露脸对白| 亚洲成人激情av| 精品国内二区三区| 福利电影一区二区| 亚洲一区在线观看视频| 欧美一卡二卡三卡| 成人深夜福利app| 亚洲电影一区二区| 久久久久亚洲综合| 欧美午夜片在线看| 狠狠色丁香久久婷婷综合丁香| 国产精品女人毛片| 欧美美女一区二区三区| 风流少妇一区二区| 肉肉av福利一精品导航| 国产精品三级av| 7777精品伊人久久久大香线蕉超级流畅 | 7777精品伊人久久久大香线蕉超级流畅| 久久丁香综合五月国产三级网站| 国产精品久久久久毛片软件| 欧美电影在哪看比较好| 成人精品国产一区二区4080| 日产国产欧美视频一区精品| 中文字幕亚洲欧美在线不卡| 日韩色在线观看| 91丨porny丨最新| 国内精品伊人久久久久影院对白| 日韩美女精品在线| 精品国产乱码91久久久久久网站| 91色视频在线| 国产精品538一区二区在线| 亚洲成人激情综合网| 中文字幕不卡三区| 日韩一级视频免费观看在线| 色94色欧美sute亚洲线路一ni| 国产制服丝袜一区| 五月婷婷久久综合| 亚洲精品国久久99热| 久久久久国产一区二区三区四区 | k8久久久一区二区三区| 老司机精品视频在线| 亚洲综合清纯丝袜自拍| 国产精品欧美久久久久一区二区| 欧美一级精品在线| 欧美日本一区二区| 一本色道久久综合亚洲精品按摩| 国产一区二区0| 蜜臀av性久久久久蜜臀aⅴ四虎| 亚洲美女视频在线| 国产精品久久福利| 久久精品夜夜夜夜久久| 精品久久99ma| 久久女同性恋中文字幕| 欧美电视剧免费全集观看| 欧美日韩欧美一区二区| 在线免费视频一区二区| 99久免费精品视频在线观看| 国产成人av电影在线播放| 国产自产高清不卡| 国产在线看一区| 国产呦精品一区二区三区网站| 美腿丝袜亚洲一区| 久久精品国内一区二区三区| 免费成人在线网站| 日本va欧美va精品发布| 美国毛片一区二区| 激情图区综合网| 国产主播一区二区| 国产成人亚洲综合色影视| 国产精品一区二区在线观看不卡| 久久国产生活片100| 国产美女精品人人做人人爽| 国产一区二区三区电影在线观看| 国产一区在线精品| 高清beeg欧美| 一本色道综合亚洲| 欧美精品黑人性xxxx| 91精品久久久久久久91蜜桃 | 色综合久久中文综合久久97 | 国产黄色精品网站| 成人在线视频一区二区| 波多野结衣中文字幕一区| 99九九99九九九视频精品| 在线视频一区二区免费| 欧美日韩另类一区| 日韩精品专区在线| 国产欧美精品一区二区三区四区| 国产精品午夜春色av| 亚洲人成人一区二区在线观看 | 成人国产精品免费观看动漫| 91在线精品一区二区三区| 欧美影院午夜播放| 欧美一级免费大片| 国产午夜精品久久久久久免费视| 中文字幕一区二区视频| 亚洲第一福利视频在线| 精品一区二区三区在线观看国产| 成人丝袜高跟foot| 欧美亚洲国产一区二区三区va | 国产欧美一二三区| 一二三区精品视频| 久久成人av少妇免费| 91在线观看地址| 在线播放91灌醉迷j高跟美女| 精品国产一区二区精华| 亚洲天堂成人在线观看| 日本aⅴ亚洲精品中文乱码| 国产成人在线影院| 欧美日韩免费电影| 夜夜精品浪潮av一区二区三区| 国产成人精品免费一区二区| 日韩欧美精品在线| 欧美日韩一级二级三级| 日韩精品一区二区三区在线观看| 国产精品毛片久久久久久| 日韩av不卡一区二区| 不卡的av在线| 欧美成人一区二区三区在线观看 | 亚洲视频免费在线| 免费不卡在线观看| 欧美日韩国产影片| 欧美高清在线一区二区| 日本最新不卡在线| 在线视频国产一区| 国产欧美日韩不卡| 日本欧美在线观看| 91久久香蕉国产日韩欧美9色| 久久先锋影音av| 日韩国产在线观看一区| 色婷婷综合五月| 国产欧美视频一区二区| 黄色精品一二区| 欧美一区二区在线看| 一区二区三区精品视频| 成人动漫精品一区二区| 精品国精品国产| 麻豆精品国产传媒mv男同 | 国产a级毛片一区| 精品美女在线观看| 亚洲成人av电影在线| 色综合天天综合网天天狠天天| 久久综合五月天婷婷伊人| 奇米在线7777在线精品| 欧美日韩不卡一区| 夜夜爽夜夜爽精品视频| 91福利区一区二区三区| 1024国产精品| av一本久道久久综合久久鬼色| 久久精品视频一区| 激情成人午夜视频| 欧美mv日韩mv| 久久精品国产网站| 精品国产自在久精品国产| 美腿丝袜亚洲综合| 日韩美女视频在线| 精品系列免费在线观看| 日韩午夜三级在线| 久久狠狠亚洲综合| 久久综合九色综合97婷婷女人 | 日韩电影在线免费| 欧美精品日韩综合在线| 免费在线观看精品| 精品国产百合女同互慰| 国产制服丝袜一区| 国产欧美一区二区精品性| 成人av免费在线| 综合自拍亚洲综合图不卡区| 99精品国产视频| 亚洲午夜在线电影| 欧美一区二区网站| 激情综合网激情| 中文字幕国产一区二区| 一本久道久久综合中文字幕| 亚洲一区二区黄色| 欧美高清hd18日本| 国产在线精品免费| 中文字幕精品三区| 欧美影院一区二区三区| 麻豆国产精品官网| 国产日产欧美一区| 色综合久久久久综合体|