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

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

?? rtusb_bulk.c

?? r73模塊的無線網卡在Linux下的驅動程序
?? C
?? 第 1 頁 / 共 3 頁
字號:
/*************************************************************************** * RT2x00 SourceForge Project - http://rt2x00.serialmonkey.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.,                                       * *   59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.             * *                                                                         * *   Licensed under the GNU GPL                                            * *   Original code supplied under license from RaLink Inc, 2004.           * ***************************************************************************//*************************************************************************** *	Module Name:	rtusb_bulk.c * *	Abstract: * *	Revision History: *	Who		When		What *	--------	----------	----------------------------- *	idamlaj		14-10-2006	RFMONTx (based on MarkW's code) * ***************************************************************************/#include	"rt_config.h"void RTusb_fill_bulk_urb (struct urb *pUrb,	struct usb_device *pUsb_Dev,	unsigned int bulkpipe,	void *pTransferBuf,	int BufSize,	usb_complete_t Complete,	void *pContext){#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,5,0)	usb_fill_bulk_urb(pUrb, pUsb_Dev, bulkpipe, pTransferBuf, BufSize, Complete, pContext);#else	FILL_BULK_URB(pUrb, pUsb_Dev, bulkpipe, pTransferBuf, BufSize, Complete, pContext);#endif}// ************************ Completion Func ************************ ///*	========================================================================	Routine Description:		This routine processes data and RTS/CTS frame completions.		If the current frame has transmitted OK and there are more fragments,		then schedule the next frame fragment.		If there's been an error, empty any remaining fragments for that		queue from the tx ring.	Arguments:		pUrb		Our URB		pt_regs		Historical	Return Value:		void	Note:		ALL (i.e. we've done a submit_urb) in-flight URBS are posted complete.	========================================================================*/VOID RTUSBBulkOutDataPacketComplete(purbb_t pUrb, struct pt_regs *pt_regs){	PTX_CONTEXT 	pTxContext;	PRTMP_ADAPTER	pAd;	NTSTATUS		status;	UCHAR			BulkOutPipeId;	unsigned long			flags;	pTxContext= (PTX_CONTEXT)pUrb->context;	pAd = pTxContext->pAd;	status = pUrb->status;	atomic_dec(&pAd->PendingTx);	DBGPRINT(RT_DEBUG_TRACE, "--->%s status=%d PendingTx=%d\n",			__FUNCTION__, status, atomic_read(&pAd->PendingTx));	// Store BulkOut PipeId	BulkOutPipeId = pTxContext->BulkOutPipeId;	pAd->BulkOutDataOneSecCount++;	switch (status) {		case 0:					// OK			if (pTxContext->LastOne == TRUE)			{				pAd->Counters.GoodTransmits++;				FREE_TX_RING(pAd, BulkOutPipeId, pTxContext);				pAd->TxRingTotalNumber[BulkOutPipeId]--;// sync. to PendingTx				pTxContext = nextTxContext(pAd, BulkOutPipeId);				if (pTxContext->bWaitingBulkOut == TRUE) {					RTUSB_SET_BULK_FLAG(pAd,							(fRTUSB_BULK_OUT_DATA_NORMAL << BulkOutPipeId));				}			}			else {				if ((!RTMP_TEST_FLAG(pAd, fRTMP_ADAPTER_RESET_IN_PROGRESS)) &&					(!RTMP_TEST_FLAG(pAd, fRTMP_ADAPTER_HALT_IN_PROGRESS)) &&					(!RTMP_TEST_FLAG(pAd, fRTMP_ADAPTER_NIC_NOT_EXIST)) &&					(!RTMP_TEST_FLAG(pAd, fRTMP_ADAPTER_BULKOUT_RESET)))				{					FREE_TX_RING(pAd, BulkOutPipeId, pTxContext);					pAd->TxRingTotalNumber[BulkOutPipeId]--;// sync. to PendingTx					// Indicate next one is frag data which has highest priority					RTUSB_SET_BULK_FLAG(pAd,							(fRTUSB_BULK_OUT_DATA_FRAG << BulkOutPipeId));				}				else {					do {						FREE_TX_RING(pAd, BulkOutPipeId, pTxContext);						pAd->TxRingTotalNumber[BulkOutPipeId]--;// sync. to PendingTx						pTxContext = nextTxContext(pAd, BulkOutPipeId);					} while (pTxContext->InUse != FALSE);				}			}			RTUSBMlmeUp(pAd);			break;		case -ECONNRESET:		// async unlink via call to usb_unlink_urb()		case -ENOENT:			// stopped by call to usb_kill_urb		case -ESHUTDOWN:		// hardware gone = -108		case -EPROTO:			// unplugged = -71			DBGPRINT(RT_DEBUG_ERROR,"=== %s: shutdown status=%d\n",					__FUNCTION__, status);			do {				FREE_TX_RING(pAd, BulkOutPipeId, pTxContext);				pAd->TxRingTotalNumber[BulkOutPipeId]--;// sync. to PendingTx				pTxContext = nextTxContext(pAd, BulkOutPipeId);			} while (pTxContext->InUse != FALSE);			break;		default:#if 1	// TODO: Think about if we really want to do this reset - bb			do {				FREE_TX_RING(pAd, BulkOutPipeId, pTxContext);				pAd->TxRingTotalNumber[BulkOutPipeId]--;// sync. to PendingTx				pTxContext = nextTxContext(pAd, BulkOutPipeId);			} while (pTxContext->InUse != FALSE);			if ((!RTMP_TEST_FLAG(pAd, fRTMP_ADAPTER_RESET_IN_PROGRESS)) &&				(!RTMP_TEST_FLAG(pAd, fRTMP_ADAPTER_HALT_IN_PROGRESS)) &&				(!RTMP_TEST_FLAG(pAd, fRTMP_ADAPTER_NIC_NOT_EXIST)) &&				(!RTMP_TEST_FLAG(pAd, fRTMP_ADAPTER_BULKOUT_RESET)))			{				DBGPRINT(RT_DEBUG_ERROR, "Bulk Out Data Packet Failed\n");				RTMP_SET_FLAG(pAd, fRTMP_ADAPTER_BULKOUT_RESET);				RTUSBEnqueueInternalCmd(pAd, RT_OID_USB_RESET_BULK_OUT);			}#endif			break;	}	NdisAcquireSpinLock(&pAd->BulkOutLock[BulkOutPipeId]);	pAd->BulkOutPending[BulkOutPipeId] = FALSE;	NdisReleaseSpinLock(&pAd->BulkOutLock[BulkOutPipeId]);}// NULL frame use BulkOutPipeId = 0VOID RTUSBBulkOutNullFrameComplete(purbb_t pUrb, struct pt_regs *pt_regs){	PRTMP_ADAPTER	pAd;	PTX_CONTEXT		pNullContext;	NTSTATUS		status;	unsigned long			flags;	pNullContext= (PTX_CONTEXT)pUrb->context;	pAd = pNullContext->pAd;	// Reset Null frame context flags	pNullContext->IRPPending = FALSE;	pNullContext->InUse = FALSE;	status = pUrb->status;	atomic_dec(&pAd->PendingTx);	DBGPRINT(RT_DEBUG_TRACE, "--->%s status=%d PendingTx=%d\n",			__FUNCTION__, status, atomic_read(&pAd->PendingTx));	switch (status) {		case 0:					// OK			RTUSBMlmeUp(pAd);			break;		case -ECONNRESET:		// async unlink via call to usb_unlink_urb()		case -ENOENT:			// stopped by call to usb_kill_urb		case -ESHUTDOWN:		// hardware gone = -108		case -EPROTO:			// unplugged = -71			DBGPRINT(RT_DEBUG_ERROR,"=== %s: shutdown status=%d\n",					__FUNCTION__, status);			break;		default:#if 1	// STATUS_OTHER			if ((!RTMP_TEST_FLAG(pAd, fRTMP_ADAPTER_RESET_IN_PROGRESS)) &&				(!RTMP_TEST_FLAG(pAd, fRTMP_ADAPTER_HALT_IN_PROGRESS)) &&				(!RTMP_TEST_FLAG(pAd, fRTMP_ADAPTER_NIC_NOT_EXIST)) &&				(!RTMP_TEST_FLAG(pAd, fRTMP_ADAPTER_BULKOUT_RESET)))			{				DBGPRINT(RT_DEBUG_ERROR, "Bulk Out Null Frame Failed\n");				RTMP_SET_FLAG(pAd, fRTMP_ADAPTER_BULKOUT_RESET);				RTUSBEnqueueInternalCmd(pAd, RT_OID_USB_RESET_BULK_OUT);			}			break;#endif	}	NdisAcquireSpinLock(&pAd->BulkOutLock[0]);	pAd->BulkOutPending[0] = FALSE;	NdisReleaseSpinLock(&pAd->BulkOutLock[0]);	DBGPRINT(RT_DEBUG_TRACE, "<---RTUSBBulkOutNullFrameComplete\n");}// RTS frame use BulkOutPipeId = PipeIDVOID RTUSBBulkOutRTSFrameComplete(purbb_t pUrb, struct pt_regs *pt_regs){	PRTMP_ADAPTER	pAd;	PTX_CONTEXT		pRTSContext;	NTSTATUS		status;	unsigned long			flags;	pRTSContext= (PTX_CONTEXT)pUrb->context;	pAd = pRTSContext->pAd;	// Reset RTS frame context flags	pRTSContext->IRPPending = FALSE;	pRTSContext->InUse = FALSE;	status = pUrb->status;	atomic_dec(&pAd->PendingTx);	DBGPRINT(RT_DEBUG_TRACE, "--->%s status=%d PendingTx=%d\n",			__FUNCTION__, status, atomic_read(&pAd->PendingTx));	switch (status) {		case 0:					// OK			RTUSBMlmeUp(pAd);			break;		case -ECONNRESET:		// async unlink via call to usb_unlink_urb()		case -ENOENT:			// stopped by call to usb_kill_urb		case -ESHUTDOWN:		// hardware gone = -108		case -EPROTO:			// unplugged = -71			DBGPRINT(RT_DEBUG_ERROR,"=== %s: shutdown status=%d\n",					__FUNCTION__, status);			break;		default:#if 1	// STATUS_OTHER			if ((!RTMP_TEST_FLAG(pAd, fRTMP_ADAPTER_RESET_IN_PROGRESS)) &&				(!RTMP_TEST_FLAG(pAd, fRTMP_ADAPTER_HALT_IN_PROGRESS)) &&				(!RTMP_TEST_FLAG(pAd, fRTMP_ADAPTER_NIC_NOT_EXIST)) &&				(!RTMP_TEST_FLAG(pAd, fRTMP_ADAPTER_BULKOUT_RESET)))			{				DBGPRINT(RT_DEBUG_ERROR, "Bulk Out RTS Frame Failed\n");				RTMP_SET_FLAG(pAd, fRTMP_ADAPTER_BULKOUT_RESET);				RTUSBEnqueueInternalCmd(pAd, RT_OID_USB_RESET_BULK_OUT);			}			break;#endif	}	NdisAcquireSpinLock(&pAd->BulkOutLock[pRTSContext->BulkOutPipeId]);	pAd->BulkOutPending[pRTSContext->BulkOutPipeId] = FALSE;	NdisReleaseSpinLock(&pAd->BulkOutLock[pRTSContext->BulkOutPipeId]);	DBGPRINT(RT_DEBUG_TRACE, "<---RTUSBBulkOutRTSFrameComplete\n");}// MLME use BulkOutPipeId = 0VOID RTUSBBulkOutMLMEPacketComplete(purbb_t pUrb, struct pt_regs *pt_regs){	PTX_CONTEXT			pMLMEContext;	PRTMP_ADAPTER		pAd;	NTSTATUS			status;	unsigned long				flags;	pMLMEContext= (PTX_CONTEXT)pUrb->context;	pAd = pMLMEContext->pAd;	status = pUrb->status;	atomic_dec(&pAd->PendingTx);	DBGPRINT(RT_DEBUG_TRACE, "--->%s status=%d PendingTx=%d\n",			__FUNCTION__, status, atomic_read(&pAd->PendingTx));	pAd->PrioRingTxCnt--;	if (pAd->PrioRingTxCnt < 0)		pAd->PrioRingTxCnt = 0;	pAd->PrioRingFirstIndex++;	if (pAd->PrioRingFirstIndex >= PRIO_RING_SIZE)	{		pAd->PrioRingFirstIndex = 0;	}#if 0	DBGPRINT(RT_DEBUG_INFO, "RTUSBBulkOutMLMEPacketComplete::PrioRingFirstIndex = %d, PrioRingTxCnt = %d, PopMgmtIndex = %d, PushMgmtIndex = %d, NextMLMEIndex = %d\n",			pAd->PrioRingFirstIndex,			pAd->PrioRingTxCnt, pAd->PopMgmtIndex, pAd->PushMgmtIndex, pAd->NextMLMEIndex);#endif	// Reset MLME context flags	pMLMEContext->IRPPending	= FALSE;	pMLMEContext->InUse 		= FALSE;	switch (status) {		case 0:					// OK			if (pAd->PrioRingTxCnt > 0) {				RTUSB_SET_BULK_FLAG(pAd, fRTUSB_BULK_OUT_MLME);			}			RTUSBMlmeUp(pAd);			break;		case -ECONNRESET:		// async unlink via call to usb_unlink_urb()		case -ENOENT:			// stopped by call to usb_kill_urb		case -ESHUTDOWN:		// hardware gone = -108		case -EPROTO:			// unplugged = -71			DBGPRINT(RT_DEBUG_ERROR,"=== %s: shutdown status=%d\n",					__FUNCTION__, status);			break;		default:#if 1	// STATUS_OTHER			if ((!RTMP_TEST_FLAG(pAd, fRTMP_ADAPTER_RESET_IN_PROGRESS)) &&				(!RTMP_TEST_FLAG(pAd, fRTMP_ADAPTER_HALT_IN_PROGRESS)) &&				(!RTMP_TEST_FLAG(pAd, fRTMP_ADAPTER_NIC_NOT_EXIST)) &&				(!RTMP_TEST_FLAG(pAd, fRTMP_ADAPTER_BULKOUT_RESET)))			{				DBGPRINT(RT_DEBUG_ERROR, "Bulk Out MLME Failed\n");				RTMP_SET_FLAG(pAd, fRTMP_ADAPTER_BULKOUT_RESET);				RTUSBEnqueueInternalCmd(pAd, RT_OID_USB_RESET_BULK_OUT);			}			break;#endif	}	NdisAcquireSpinLock(&pAd->BulkOutLock[0]);	pAd->BulkOutPending[0] = FALSE;	NdisReleaseSpinLock(&pAd->BulkOutLock[0]);	DBGPRINT(RT_DEBUG_TRACE, "<---RTUSBBulkOutMLMEPacketComplete\n");}// PS-Poll frame use BulkOutPipeId = 0VOID RTUSBBulkOutPsPollComplete(purbb_t pUrb,struct pt_regs *pt_regs){	PRTMP_ADAPTER	pAd;	PTX_CONTEXT		pPsPollContext;	NTSTATUS		status;	unsigned long			flags;	pPsPollContext= (PTX_CONTEXT)pUrb->context;	pAd = pPsPollContext->pAd;	// Reset PsPoll context flags	pPsPollContext->IRPPending	= FALSE;	pPsPollContext->InUse		= FALSE;	status = pUrb->status;	atomic_dec(&pAd->PendingTx);	DBGPRINT(RT_DEBUG_TRACE, "--->%s status=%d PendingTx=%d\n",			__FUNCTION__, status, atomic_read(&pAd->PendingTx));	switch (status) {		case 0:					// OK			RTUSBMlmeUp(pAd);			break;		case -ECONNRESET:		// async unlink via call to usb_unlink_urb()		case -ENOENT:			// stopped by call to usb_kill_urb		case -ESHUTDOWN:		// hardware gone = -108		case -EPROTO:			// unplugged = -71			DBGPRINT(RT_DEBUG_ERROR,"=== %s: shutdown status=%d\n",					__FUNCTION__, status);			break;		default:#if 1	// STATUS_OTHER			if ((!RTMP_TEST_FLAG(pAd, fRTMP_ADAPTER_RESET_IN_PROGRESS)) &&				(!RTMP_TEST_FLAG(pAd, fRTMP_ADAPTER_HALT_IN_PROGRESS)) &&				(!RTMP_TEST_FLAG(pAd, fRTMP_ADAPTER_NIC_NOT_EXIST)) &&				(!RTMP_TEST_FLAG(pAd, fRTMP_ADAPTER_BULKOUT_RESET)))			{				DBGPRINT(RT_DEBUG_ERROR, "Bulk Out PSPoll Failed\n");				RTMP_SET_FLAG(pAd, fRTMP_ADAPTER_BULKOUT_RESET);				RTUSBEnqueueInternalCmd(pAd, RT_OID_USB_RESET_BULK_OUT);			}			break;#endif	}	NdisAcquireSpinLock(&pAd->BulkOutLock[0]);	pAd->BulkOutPending[0] = FALSE;	NdisReleaseSpinLock(&pAd->BulkOutLock[0]);	DBGPRINT(RT_DEBUG_TRACE, "<---RTUSBBulkOutPsPollComplete\n");}/*	========================================================================	Routine Description:		This routine process Rx Irp and call rx complete function.	Arguments:		DeviceObject	Pointer to the device object for next lower						device. DeviceObject passed in here belongs to						the next lower driver in the stack because we						were invoked via IoCallDriver in USB_RxPacket						AND it is not OUR device object	  Irp				Ptr to completed IRP	  Context			Ptr to our Adapter object (context specified						in IoSetCompletionRoutine	Return Value:		Always returns STATUS_MORE_PROCESSING_REQUIRED	Note:		Always returns STATUS_MORE_PROCESSING_REQUIRED	========================================================================*/VOID RTUSBBulkRxComplete(purbb_t pUrb, struct pt_regs *pt_regs){	PRX_CONTEXT 	pRxContext;	PRTMP_ADAPTER	pAd;	NTSTATUS		status;	pRxContext= (PRX_CONTEXT)pUrb->context;	pAd = pRxContext->pAd;	//	// We have a number of cases:	//		1) The USB read timed out and we received no data.	//		2) The USB read timed out and we received some data.	//		3) The USB read was successful and fully filled our irp buffer.	//		4) The irp was cancelled.	//		5) Some other failure from the USB device object.	//	status = pUrb->status;	atomic_set(&pRxContext->IrpLock, IRPLOCK_COMPLETED);	atomic_dec(&pAd->PendingRx);	DBGPRINT(RT_DEBUG_TRACE, "--->%s status=%d PendingRx=%d\n",			__FUNCTION__, status, atomic_read(&pAd->PendingRx));	switch (status)	{		case 0:			RTUSBMlmeUp(pAd);			break;		case -ECONNRESET:		// async unlink via call to usb_unlink_urb()		case -ENOENT:			// stopped by call to usb_kill_urb		case -ESHUTDOWN:		// hardware gone = -108		case -EPROTO:			// unplugged = -71			DBGPRINT(RT_DEBUG_ERROR,"=== %s: shutdown status=%d\n",					__FUNCTION__, status);			pRxContext->InUse = FALSE;		default:			break;	}}VOID	RTUSBInitTxDesc(

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲美女视频在线观看| 国产一区二区伦理片| 免费欧美在线视频| 成人sese在线| 欧美变态口味重另类| 亚洲三级电影全部在线观看高清| 亚洲v日本v欧美v久久精品| 大美女一区二区三区| 欧美一级午夜免费电影| 亚洲日本va在线观看| 国产美女一区二区| 欧美一卡二卡在线观看| 一区二区三区影院| 成人在线一区二区三区| 日韩一区二区视频在线观看| 一区二区三区成人| 成人晚上爱看视频| 欧美激情综合在线| 久久国产精品99精品国产| 欧美麻豆精品久久久久久| 亚洲男女一区二区三区| 国产成人三级在线观看| 日韩精品中午字幕| 午夜国产不卡在线观看视频| 91福利在线免费观看| 国产精品动漫网站| 成人一级视频在线观看| 国产亚洲欧美色| 国产黄人亚洲片| 精品国产一区二区在线观看| 日本不卡一二三| 91精品国产综合久久香蕉麻豆 | 成人少妇影院yyyy| 2021国产精品久久精品| 免费成人在线播放| 日韩欧美激情在线| 国内精品伊人久久久久av一坑| 欧美一区二区三区在线视频| 日本欧美久久久久免费播放网| 欧美性感一类影片在线播放| 亚洲一二三四区| 欧美日韩一区久久| 麻豆精品一区二区三区| 久久综合久久综合久久综合| 国产精品自在欧美一区| 亚洲国产精品成人综合色在线婷婷 | 韩国午夜理伦三级不卡影院| 精品国产乱码久久久久久闺蜜| 免费观看成人鲁鲁鲁鲁鲁视频| 精品美女一区二区| 国产高清不卡二三区| 日产国产高清一区二区三区| 欧美一区二区三区免费| 国产在线精品一区二区三区不卡| 国产婷婷色一区二区三区四区| 成人免费视频网站在线观看| 一区二区三区在线观看欧美 | 久久久久国产精品麻豆ai换脸| 国产一区在线不卡| 中文字幕一区二区三区不卡在线 | 2023国产一二三区日本精品2022| 国产一区二区不卡老阿姨| 国产精品乱人伦| 欧美美女网站色| 狠狠色丁香婷综合久久| 国产精品欧美久久久久无广告| 欧美色男人天堂| 国内精品免费在线观看| 最新国产成人在线观看| 日韩写真欧美这视频| 波多野结衣中文一区| 天堂久久一区二区三区| 久久五月婷婷丁香社区| 色香色香欲天天天影视综合网| 日韩黄色片在线观看| 国产精品久久久久久久久图文区 | 欧美狂野另类xxxxoooo| 国产一区二区精品久久| 亚洲精品成人少妇| 久久综合九色综合97婷婷女人 | 欧美日韩精品欧美日韩精品| 国产在线视频一区二区三区| 亚洲午夜日本在线观看| 国产香蕉久久精品综合网| 欧美日韩一区二区三区不卡| 国产剧情在线观看一区二区| 亚洲国产日日夜夜| 1区2区3区欧美| 26uuu成人网一区二区三区| 色综合久久天天综合网| 久久爱www久久做| 亚洲综合一区在线| 日韩理论片在线| 久久久久久久综合| 91精品国产入口| 欧美性三三影院| 99久久777色| 国产成人精品一区二区三区四区| 免费在线视频一区| 性做久久久久久免费观看| 亚洲三级免费电影| 中文字幕欧美日韩一区| 精品国产乱码久久久久久夜甘婷婷 | 国产精品美女www爽爽爽| 精品国产乱码久久久久久久 | 国产精品白丝jk黑袜喷水| 婷婷综合久久一区二区三区| 亚洲欧美色一区| 中文字幕日韩精品一区| 国产香蕉久久精品综合网| 久久综合成人精品亚洲另类欧美| 51精品秘密在线观看| 欧美丝袜丝nylons| 日本高清视频一区二区| 99精品久久99久久久久| 色综合网站在线| 色婷婷综合久久久久中文一区二区| 成人免费黄色在线| jizz一区二区| 日本福利一区二区| 在线观看免费视频综合| 在线观看亚洲精品视频| 欧美天天综合网| 欧美久久久久久久久久| 91精品国产综合久久久久久久| 欧美日韩亚洲高清一区二区| 欧美日韩综合色| 91精品国产色综合久久ai换脸| 精品日韩成人av| 中文字幕av在线一区二区三区| 亚洲欧洲无码一区二区三区| 亚洲情趣在线观看| 亚洲成a人v欧美综合天堂下载| 视频在线在亚洲| 欧美日韩精品专区| 制服视频三区第一页精品| 欧美成人一区二区三区片免费| 久久一日本道色综合| 国产精品私人自拍| 亚洲精品乱码久久久久久久久| 亚洲va国产va欧美va观看| 美女视频黄频大全不卡视频在线播放| 国产在线视频精品一区| 91视视频在线观看入口直接观看www | 日本乱码高清不卡字幕| 欧美精品高清视频| 国产欧美一区二区精品性色| 亚洲欧美偷拍卡通变态| 日本中文在线一区| 成人一区二区三区中文字幕| 欧美艳星brazzers| 欧美精品一区男女天堂| 一区二区三区四区激情 | 在线观看亚洲精品| 精品美女在线播放| 亚洲综合在线五月| 激情综合网av| 日本精品视频一区二区三区| 欧美成人r级一区二区三区| 国产精品第五页| 精品无人区卡一卡二卡三乱码免费卡 | 九九久久精品视频| 色网站国产精品| 国产免费成人在线视频| 午夜精品免费在线| eeuss鲁片一区二区三区| 日韩欧美三级在线| 亚洲国产成人av好男人在线观看| 国产精品123区| 日韩无一区二区| 一区二区久久久久久| 成人激情免费网站| 精品国产第一区二区三区观看体验| 夜夜操天天操亚洲| 91丝袜美女网| 国产精品久久久久7777按摩| 老司机免费视频一区二区| 欧美日韩视频第一区| 一区二区三区在线视频免费| 成人午夜在线播放| 2020国产精品自拍| 久久国产精品99久久人人澡| 69av一区二区三区| 亚洲综合成人网| 97se亚洲国产综合自在线| 精品sm捆绑视频| 天天爽夜夜爽夜夜爽精品视频| 国产欧美一区二区精品秋霞影院 | 国产亚洲成av人在线观看导航 | 狠狠色丁香久久婷婷综| 7777精品伊人久久久大香线蕉完整版| 欧美激情资源网| 国产二区国产一区在线观看| 日韩小视频在线观看专区| 亚洲二区视频在线| 欧美午夜精品一区| 国产精品超碰97尤物18| jizz一区二区| 亚洲嫩草精品久久| 99在线热播精品免费|