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

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

?? ser2440_ser.c

?? windows ce 50 drive program
?? C
?? 第 1 頁 / 共 2 頁
字號:
/*++
THIS CODE AND INFORMATION IS PROVIDED "AS IS" WITHOUT WARRANTY OF
ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING BUT NOT LIMITED TO
THE IMPLIED WARRANTIES OF MERCHANTABILITY AND/OR FITNESS FOR A
PARTICULAR PURPOSE.
Copyright (c) 1995-2000 Microsoft Corporation.  All rights reserved.
Copyright (c) 2001-2002 SAMSUNG Electronics Corporation.  All rights reserved.

Author	hmseo@sec.samsung.com (SAMSUNG Electronics)

Module Name:  

SER2440_SER.C

Abstract:  

Notes: 
--*/

#define EXAMINE_BOOTARGS
#define DEBUGMODE 0

#include <windows.h>
#include <types.h>
#include <ceddk.h>
#include <memory.h>
#include <serhw.h>
#include <ser16550.h>
#include <hw16550.h>
#include <nkintr.h>
#include <devload.h>
#include <windev.h>
#include <notify.h>
#include <pm.h>

#include "S2440.h"

#define USERDBG        1

#ifdef EXAMINE_BOOTARGS
#include <bootarg.h>
#include <oalintr.h>
#include <pc.h>
#endif

#include <ser2440.h>

#undef ZONE_INIT
#include <serdbg.h>

static BOOL IRDA;

#define BAUD_TABLE_SIZE 23
static const
PAIRS   BaudPairs[BAUD_TABLE_SIZE] =    {
	{50,        2307},
	{75,        1538},
	{110,       1049},
	{135,       858},
	{150,       769},
	{300,       384},
	{600,       192},
	{1200,      96},
	{1800,      64},
	{2000,      58},
	{2400,      48},
	{3600,      32},
	{4800,      24},
	{7200,      16},
	{9600,      12},
	{12800,     9},
	{14400,     8},
	{19200,     6},
	{23040,     5},
	{28800,     4},
	{38400,     3},
	{57600,     2},
	{115200,    1}
};

static const LOOKUP_TBL  BaudTable = {BAUD_TABLE_SIZE, (PAIRS *) BaudPairs};

// Miscellaneous internal routines.
PUCHAR
static
Ser_InternalMapRegisterAddresses(ULONG HWAddress, ULONG Size)
{
	PUCHAR              ioPortBase; 
	ULONG               inIoSpace      = 1;
	PHYSICAL_ADDRESS    ioPhysicalBase = { HWAddress, 0};

	RETAILMSG(DEBUGMODE, (TEXT("+ Ser_InternalMapRegisterAddresses : HalTranslateBusAddress\r\n")));
	if ( HalTranslateBusAddress(Isa, 0, ioPhysicalBase, &inIoSpace, &ioPhysicalBase))
	{
		DEBUGMSG(1, (TEXT("Ser_InternalMapRegisterAddresses : HalTranslateBusAddress - OK\r\n")));
		if ( !inIoSpace )
		{
			DEBUGMSG(1, (TEXT("Ser_InternalMapRegisterAddresses : ! IO Space\r\n")));
			if ( (ioPortBase = (PUCHAR)MmMapIoSpace(ioPhysicalBase, Size, FALSE)) == NULL )
			{
				// We may as well not continue
				DEBUGMSG(ZONE_INIT | ZONE_ERROR, (TEXT("Error mapping I/O Ports\r\n")));
				return (NULL);
			}
		}
		else
		{
			DEBUGMSG(1, (TEXT("Ser_InternalMapRegisterAddresses : IO Space\r\n")));
			ioPortBase = (PUCHAR)ioPhysicalBase.LowPart;
		}
	}
	else
	{
		DEBUGMSG(ZONE_INIT | ZONE_ERROR, (TEXT("Error translating I/O Ports.\r\n")));
		return (NULL);
	}

	RETAILMSG(DEBUGMODE, (TEXT("- Ser_InternalMapRegisterAddresses : %d\r\n"),ioPortBase ));
	return (ioPortBase);
}

static
BOOL
SerSetIRBaudRate(
			PSER_INFO   pHWHead,
			ULONG baud     // @parm     UINT16 what is the baud rate
					)
{
	PS2440_UART_INFO   pHWHead2   = (PS2440_UART_INFO)pHWHead;

	RETAILMSG(DEBUGMODE, (TEXT("IRDA : +SerSetIRBaudRate\r\n")));    
	DEBUGMSG (ZONE_INIT|1, (TEXT("Serial set IR Baud %d\r\n"), baud));

	if ( (pHWHead2->s2440SerReg->rUCON & CS_MASK) == CS_PCLK )
	{
		RETAILMSG (1, (TEXT("USE CS_PCLK\r\n")));    
		OUTREG(pHWHead2,rUBRDIV,( (int)(S2440PCLK/16.0/baud) -1 ));
	}
	else		// if  ( (pHWHead2->s2440SerReg->rUCON & CS_MASK) == CS_UCLK )
	{
		RETAILMSG (1, (TEXT("USE CS_UCLK\r\n")));    
		OUTREG(pHWHead2,rUBRDIV,( (int)(S2440UCLK/16.0/baud) -1 ));
	}
		
	RETAILMSG(DEBUGMODE, (TEXT("IRDA : -SerSetIRBaudRate\r\n")));
	return (TRUE);
}

/*
 *  NOTE : The caller should have set pHWHead->fIRMode.  It is not
 * set here, since power on/off may need to temporarily disable
 * the intefaces without actually overwriting the current recorded
 * mode.
 */
static
void
SerSetOutputMode(
                PSER_INFO   pHWHead,
                BOOL UseIR,     // @parm     BOOL Should we use IR interface
                BOOL Use9Pin    // @parm     BOOL Should we use Wire interface
                )
{
	// If you support IR, here you need to set the interface to either IR mode
	// or normal serial. Note that it is possible for both BOOls to
	// be false (i.e. power down), but never for both to be TRUE.

	PS2440_UART_INFO   pHWHead2   = (PS2440_UART_INFO)pHWHead;

	RETAILMSG (DEBUGMODE, (TEXT("+SerSetOutputMode\r\n")));

	if(UseIR)  
		SETREG(pHWHead2,rULCON,SER2440_IRMODE_MASK);   // Infra-red mode enable.
	else
		CLEARREG(pHWHead2,rULCON,SER2440_IRMODE_MASK);   // Infra-red mode enable.
	
	RETAILMSG(DEBUGMODE, (TEXT("-SerSetOutputMode\r\n")));
}



/*++
*******************************************************************************
Routine:

    Ser_GetRegistryData

Description:

    Take the registry path provided to COM_Init and use it to find this 
    requested comm port's DeviceArrayIndex, teh IOPort Base Address, and the
   Interrupt number.
   
Arguments:

    LPCTSTR regKeyPath	the registry path passed in to COM_Init.

Return Value:

    -1 if there is an error.

*******************************************************************************
--*/
BOOL
Ser_GetRegistryData(PSER_INFO pHWHead, LPCTSTR regKeyPath)
{
#define GCI_BUFFER_SIZE 256   

	LONG    regError;
	HKEY    hKey;
	DWORD   dwDataSize = GCI_BUFFER_SIZE;

	RETAILMSG(DEBUGMODE, (TEXT("Try to open %s\r\n"), regKeyPath));

	// We've been handed the name of a key in the registry that was generated
	// on the fly by device.exe.  We're going to open that key and pull from it
	// a value that is the name of this serial port's real key.  That key
	// will have the DeviceArrayIndex that we're trying to find.  
	hKey = OpenDeviceKey(regKeyPath);
	if ( hKey == NULL )
	{
		DEBUGMSG(ZONE_INIT | ZONE_ERROR,(TEXT("Failed to open device key\r\n")));
		return ( FALSE );        
	}

	// Okay, we're finally ready to try and load our registry data.
	dwDataSize = PC_REG_DEVINDEX_VAL_LEN;
	regError = RegQueryValueEx(
					hKey, 
					PC_REG_DEVINDEX_VAL_NAME, 
					NULL, 
					NULL,
					(LPBYTE)(&pHWHead->dwDevIndex), 
					&dwDataSize);

	if ( regError == ERROR_SUCCESS )
	{
		dwDataSize = PC_REG_IRQ_VAL_LEN;
		regError = RegQueryValueEx(
					hKey, 
					PC_REG_IRQ_VAL_NAME, 
					NULL, 
					NULL,
					(LPBYTE)(&pHWHead->dwIRQ), 
					&dwDataSize);
	}

	if ( regError == ERROR_SUCCESS )
	{
		dwDataSize = PC_REG_IOBASE_VAL_LEN;
		regError = RegQueryValueEx(
					hKey, 
					PC_REG_IOBASE_VAL_NAME, 
					NULL, 
					NULL,
					(LPBYTE)(&pHWHead->dwIOBase), 
					&dwDataSize);
	}

	if ( regError == ERROR_SUCCESS )
	{
		dwDataSize = PC_REG_IOLEN_VAL_LEN;
		regError = RegQueryValueEx(
					hKey, 
					PC_REG_IOLEN_VAL_NAME, 
					NULL, 
					NULL,
					(LPBYTE)(&pHWHead->dwIOLen), 
					&dwDataSize);
	}

	RegCloseKey (hKey);

	if ( regError != ERROR_SUCCESS )
	{
		RETAILMSG(DEBUGMODE, (TEXT("Failed to get serial registry values, Error 0x%X\r\n"),regError));
		return ( FALSE );
	}

	RETAILMSG (DEBUGMODE,(TEXT("SerInit - Devindex %d, IRQ %d, IOB %X, IOLen %X \r\n"),
		pHWHead->dwDevIndex, pHWHead->dwIRQ, pHWHead->dwIOBase, pHWHead->dwIOLen));

	return ( TRUE ); 
}



/*
 @doc OEM 
 @func PVOID | SerInit | Initializes device identified by argument.
 *  This routine sets information controlled by the user
 *  such as Line control and baud rate. It can also initialize events and
 *  interrupts, thereby indirectly managing initializing hardware buffers.
 *  Exported only to driver, called only once per process.
 *
 @rdesc The return value is a PVOID to be passed back into the HW
 dependent layer when HW functions are called.
 */
static
PVOID
SerInit(
	BOOL bIR,
       ULONG   Identifier, // @parm Device identifier.
       PVOID   pMddHead,   // @parm First argument to mdd callbacks.
       PHWOBJ  pHWObj      // @parm Pointer to our own HW OBJ for this device
       )
{
	PSER_INFO			pHWHead;

#ifdef EXAMINE_BOOTARGS    
	PVOID				*ppBootArgs     = NULL;  // Pointer to pointer to bootargs.
	PHYSICAL_ADDRESS	PhysicalAddress = {0,0};
#endif    

	// Note on defaults.  While the PC typcially considers COM1 to be at 
	// 3F8, irq4 and COM2 to be 2F8, irq3, NKPC uses COM1 internally for the
	// debugger.  So, when NK tells me to start "COM1" it really means the
	// first one that's available, which is what the PC calls COM2.  Confused?
	// The end result is that COM1 on NK is what the PC considers to be COM2.
	// But wait, there's more.  On a Puzzle, the debugger is on COM2 and the
	// COM1 for NK is ACTUALLY COM1.  So PCs need 2F8 for their port base
	// and Puzzles need 3F8.

	RETAILMSG(DEBUGMODE, (TEXT("SerInit - !!! \r\n")));

	// Allocate for our main data structure and one of it's fields.
	pHWHead = (PSER_INFO)LocalAlloc( LMEM_ZEROINIT|LMEM_FIXED,	sizeof(SER_INFO) );
	if ( !pHWHead )
		return( NULL );

	if ( ! Ser_GetRegistryData(pHWHead, (LPCTSTR)Identifier) )
	{
		DEBUGMSG (ZONE_INIT|ZONE_ERROR,	(TEXT("SerInit - Unable to read registry data.  Failing Init !!! \r\n")));
		goto ALLOCFAILED;
	}

	pHWHead->pBaseAddress = Ser_InternalMapRegisterAddresses(pHWHead->dwIOBase, pHWHead->dwIOLen);

#ifdef EXAMINE_BOOTARGS        
	// Allocate a pointer to our bootargs since they may indicate that we don't have
	// access to the hardware resource.

	// First, map the bootargs pointer itself.  Note that I'm reading/writing
	// directly on the physical address.  I can do this since I know this is CEPC and 
	// know the adress is not in IO space.  For OEM platforms you would want to do
	// HalTranslateBusAddress first.
	PhysicalAddress.LowPart = BOOT_ARG_PTR_LOCATION & ~0x80000000;

	if ( ppBootArgs = MmMapIoSpace(PhysicalAddress, sizeof( PVOID ), TRUE ) )
	{
		DEBUGMSG (ZONE_INIT, (TEXT("SerInit - ppBootArgs (%X) at %X\r\n"), PhysicalAddress.LowPart, ppBootArgs ));
	}
	else
	{
		DEBUGMSG (ZONE_INIT | ZONE_ERROR, (TEXT("SerInit - ppBootArgs failure at %X\r\n"), PhysicalAddress.LowPart ));
		goto ALLOCFAILED;
	}

	// Now map the bootargs structure itself
	PhysicalAddress.LowPart = (DWORD) *ppBootArgs;
	if ( pHWHead->pBootArgs = MmMapIoSpace(PhysicalAddress, sizeof(BOOT_ARGS), TRUE ) )
	{
		DEBUGMSG (ZONE_INIT, (TEXT("SerInit - pBootArgs (%X) at %X\r\n"), PhysicalAddress.LowPart, pHWHead->pBootArgs ));
	}
	else
	{
		DEBUGMSG (ZONE_INIT | ZONE_ERROR, (TEXT("SerInit - pBootArgs failure at %X\r\n"), (DWORD)PhysicalAddress.LowPart));
		goto ALLOCFAILED;
	}

	// We no longer need ppBootArgs
	MmUnmapIoSpace( ppBootArgs, sizeof(PVOID) );
#endif // EXAMINE_BOOTARGS

	pHWHead->pMddHead     = pMddHead;
	pHWHead->pHWObj = pHWObj;
	pHWHead->cOpenCount   = 0;

	RETAILMSG(DEBUGMODE,(TEXT("SerInit - IRQ %d = SYSINTR %d\r\n"),
					pHWHead->dwIRQ, pHWHead->pHWObj->dwIntID));

	// Set up our Comm Properties data    
	pHWHead->CommProp.wPacketLength       = 0xffff;
	pHWHead->CommProp.wPacketVersion     = 0xffff;
	pHWHead->CommProp.dwServiceMask      = SP_SERIALCOMM;
	pHWHead->CommProp.dwReserved1         = 0;
	pHWHead->CommProp.dwMaxTxQueue        = 16;
	pHWHead->CommProp.dwMaxRxQueue        = 16;
	pHWHead->CommProp.dwMaxBaud       = BAUD_115200;
	pHWHead->CommProp.dwProvSubType      = PST_RS232;
	pHWHead->CommProp.dwProvCapabilities =
		PCF_DTRDSR | PCF_RLSD | PCF_RTSCTS |
		PCF_SETXCHAR |
		PCF_INTTIMEOUTS |
		PCF_PARITY_CHECK |
		PCF_SPECIALCHARS |
		PCF_TOTALTIMEOUTS |
		PCF_XONXOFF;
	pHWHead->CommProp.dwSettableBaud      =
		BAUD_075 | BAUD_110 | BAUD_150 | BAUD_300 | BAUD_600 |
		BAUD_1200 | BAUD_1800 | BAUD_2400 | BAUD_4800 |
		BAUD_7200 | BAUD_9600 | BAUD_14400 |
		BAUD_19200 | BAUD_38400 | BAUD_56K | BAUD_128K |
		BAUD_115200 | BAUD_57600 | BAUD_USER;
	pHWHead->CommProp.dwSettableParams    =
		SP_BAUD | SP_DATABITS | SP_HANDSHAKING | SP_PARITY |
		SP_PARITY_CHECK | SP_RLSD | SP_STOPBITS;
	pHWHead->CommProp.wSettableData       =
		DATABITS_5 | DATABITS_6 | DATABITS_7 | DATABITS_8;
	pHWHead->CommProp.wSettableStopParity =
		STOPBITS_10 | STOPBITS_20 |
		PARITY_NONE | PARITY_ODD | PARITY_EVEN | PARITY_SPACE |
		PARITY_MARK;

	pHWHead->fIRMode = bIR;
	pHWHead->s2440COM.UseIrDA = bIR;

#ifdef EXAMINE_BOOTARGS
	// Don't actually init the hardware if it is being used for debugging
	if ( ((pHWHead->pBootArgs->ucComPort == 1) && (pHWHead->dwIOBase == COM1_BASE)) ||
		((pHWHead->pBootArgs->ucComPort == 2) && (pHWHead->dwIOBase == COM2_BASE)) || 
		((pHWHead->pBootArgs->ucComPort == 3) && (pHWHead->dwIOBase == COM3_BASE)) ||
		((pHWHead->pBootArgs->ucComPort == 4) && (pHWHead->dwIOBase == COM4_BASE)) ) {
		DEBUGMSG (ZONE_INIT|ZONE_ERROR, (TEXT("\r\nSerInit - Skipping hardware init of debug port\r\n\r\n")));        
	} else
#endif
	{
		DEBUGMSG (ZONE_INIT|USERDBG, (TEXT("SerInit - Init 16550 data\r\n")));
		SL_Init( pHWHead, pHWHead->pBaseAddress, 1,
				EvaluateEventFlag, pMddHead, (PLOOKUP_TBL)&BaudTable);
		DEBUGMSG (ZONE_INIT,
			(TEXT("SerInit - Disabling UART Power\r\n")));
		SerSetOutputMode(pHWHead, FALSE, FALSE );    
	}

	return (pHWHead);

	ALLOCFAILED:
	if ( pHWHead->pBaseAddress )
		VirtualFree(pHWHead->pBaseAddress, 0, MEM_RELEASE);
	if ( ppBootArgs )
		MmUnmapIoSpace( ppBootArgs, sizeof( PVOID ) );
	if ( pHWHead->pBootArgs )
		MmUnmapIoSpace( pHWHead->pBootArgs, sizeof(BOOT_ARGS) );

	LocalFree(pHWHead);
	return (NULL);
}


PVOID
SerInitSerial(
       ULONG   Identifier, // @parm Device identifier.
       PVOID   pMddHead,   // @parm First argument to mdd callbacks.
       PHWOBJ  pHWObj      // @parm Pointer to our own HW OBJ for this device
)
{
	return (SerInit(FALSE, Identifier, pMddHead, pHWObj));
}

PVOID		
SerInitSerial2(
       ULONG   Identifier, // @parm Device identifier.
       PVOID   pMddHead,   // @parm First argument to mdd callbacks.
       PHWOBJ  pHWObj      // @parm Pointer to our own HW OBJ for this device
)
{
	return (SerInit(FALSE, Identifier, pMddHead, pHWObj));
}

PVOID		
SerInitSerial3(
       ULONG   Identifier, // @parm Device identifier.
       PVOID   pMddHead,   // @parm First argument to mdd callbacks.
       PHWOBJ  pHWObj      // @parm Pointer to our own HW OBJ for this device
)
{
	return (SerInit(FALSE, Identifier, pMddHead, pHWObj));
}

PVOID
SerInitIR(
       ULONG   Identifier, // @parm Device identifier.
       PVOID   pMddHead,   // @parm First argument to mdd callbacks.

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美午夜精品一区二区蜜桃| 久久久久国产精品免费免费搜索| 亚洲国产日日夜夜| 欧美一级视频精品观看| 一本久道中文字幕精品亚洲嫩| 激情欧美一区二区三区在线观看| 亚洲精品久久嫩草网站秘色| 国产亚洲欧美在线| 欧美大尺度电影在线| 欧美在线视频你懂得| www.成人在线| 国产91精品精华液一区二区三区| 青青草精品视频| 蜜桃视频第一区免费观看| 午夜视频久久久久久| 午夜精品免费在线| 91亚洲国产成人精品一区二区三 | 91精品国产综合久久婷婷香蕉| 久久国产生活片100| 亚洲成a天堂v人片| 成人av电影在线播放| 欧美一区二区在线观看| 综合欧美亚洲日本| 欧美激情在线看| 国产精品久久久一区麻豆最新章节| 26uuu另类欧美亚洲曰本| 欧美一区二区三区精品| 综合欧美一区二区三区| 99国产精品视频免费观看| 欧美亚洲动漫另类| 亚洲天天做日日做天天谢日日欢 | 国产日韩成人精品| 亚洲欧洲成人精品av97| 久久精品欧美日韩| 韩日av一区二区| 精品国产91九色蝌蚪| 色综合久久久久| caoporen国产精品视频| 久久蜜桃av一区二区天堂| 狠狠色丁香婷婷综合| 日韩精品一区二区三区视频| 成人福利在线看| 国产精品麻豆久久久| 亚洲综合色网站| 久久电影网站中文字幕 | 亚洲综合小说图片| 色吊一区二区三区| 日韩欧美高清在线| 国产乱码精品1区2区3区| 在线视频中文字幕一区二区| 一区二区三区中文字幕| 国产一区在线观看麻豆| 91国偷自产一区二区三区观看| 亚洲天堂久久久久久久| 欧美日韩在线播放三区四区| 久久精品夜色噜噜亚洲aⅴ| 国产一区二区三区黄视频| 国产精品欧美一区二区三区| 色88888久久久久久影院野外| 亚洲国产综合色| 欧美v日韩v国产v| 婷婷丁香激情综合| 精品理论电影在线| 99精品国产热久久91蜜凸| 亚洲欧美日韩电影| 国产aⅴ精品一区二区三区色成熟| √…a在线天堂一区| 7777精品伊人久久久大香线蕉 | 欧美性猛片aaaaaaa做受| 无码av中文一区二区三区桃花岛| 精品国产91洋老外米糕| av中文一区二区三区| 日韩电影在线免费看| 91影院在线免费观看| 亚洲h精品动漫在线观看| 久久久久久久久97黄色工厂| 9i看片成人免费高清| 人妖欧美一区二区| 国产精品毛片a∨一区二区三区| 欧美体内she精视频| 韩国女主播一区| 亚洲一区在线电影| 欧美国产丝袜视频| 91精品久久久久久久久99蜜臂| 成人三级在线视频| 欧美成人艳星乳罩| 欧美日韩一级二级| 九九精品视频在线看| 中文字幕永久在线不卡| 天堂一区二区在线免费观看| 日本精品一区二区三区高清 | 久久福利视频一区二区| 精品一区二区精品| 国产大片一区二区| 男人的天堂亚洲一区| 免费在线观看一区| 精品一区二区三区蜜桃| 国产成都精品91一区二区三| 岛国av在线一区| 91小视频免费观看| 欧美精品乱码久久久久久| 丁香六月久久综合狠狠色| 蓝色福利精品导航| 久久久久久免费网| 91麻豆精品国产91久久久久久久久| 欧美精品在线观看播放| 日韩欧美国产一区在线观看| 久久夜色精品国产欧美乱极品| 国产精品人妖ts系列视频| 樱花草国产18久久久久| 蜜臀久久久99精品久久久久久| 国产在线日韩欧美| 91小宝寻花一区二区三区| 欧美精品免费视频| 国产欧美va欧美不卡在线| 亚洲一区二区三区四区在线| 麻豆成人av在线| 99国产欧美久久久精品| 欧美一区二区黄色| 中文字幕一区二区三区色视频| 亚洲成人黄色影院| 岛国一区二区在线观看| 91精品国产综合久久精品麻豆 | 成人激情免费电影网址| 欧美日韩五月天| 国产精品色眯眯| 日韩电影在线免费看| 92精品国产成人观看免费 | 亚洲精品一区二区精华| 亚洲蜜臀av乱码久久精品蜜桃| 亚洲国产人成综合网站| 国产成人三级在线观看| 欧美性生活大片视频| 国产日韩精品视频一区| 麻豆久久久久久| 91福利视频久久久久| 久久久www成人免费无遮挡大片| 亚洲永久免费视频| 不卡一区二区在线| 久久久久久久久岛国免费| 天天亚洲美女在线视频| 91热门视频在线观看| 久久精子c满五个校花| 欧美96一区二区免费视频| 欧美少妇xxx| 国产精品久久久久久久第一福利| 久久国产乱子精品免费女| 欧美色区777第一页| 亚洲视频在线一区二区| 国产夫妻精品视频| 亚洲精品一区二区三区蜜桃下载 | 日韩电影在线一区二区| 在线精品视频免费观看| 国产精品成人一区二区三区夜夜夜| 捆绑调教一区二区三区| 欧美高清www午色夜在线视频| 亚洲人成影院在线观看| 成人免费视频视频| 欧美激情自拍偷拍| 国v精品久久久网| 久久久国产精华| 成人深夜在线观看| 日本一区二区免费在线观看视频| 另类综合日韩欧美亚洲| 精品免费国产一区二区三区四区| 日韩国产成人精品| 制服.丝袜.亚洲.另类.中文| 亚洲成av人片在线观看| 在线观看亚洲一区| 亚洲一区影音先锋| 欧美日本视频在线| 精品对白一区国产伦| 精品在线你懂的| 日韩区在线观看| 亚洲国产成人午夜在线一区| 国产乱码精品一区二区三区五月婷| 久久综合色播五月| 国产麻豆日韩欧美久久| 国产视频一区在线播放| 粉嫩嫩av羞羞动漫久久久| 国产精品成人免费| 91麻豆高清视频| 午夜激情久久久| 欧美成人三级电影在线| 国产成人av网站| 亚洲精品国久久99热| 色婷婷国产精品| 亚洲va欧美va人人爽午夜| 欧美日韩成人在线| 老司机午夜精品99久久| 国产欧美一区二区精品性色超碰| 床上的激情91.| 夜夜亚洲天天久久| 日韩一区二区视频| 国产999精品久久| 一区二区免费在线| 欧美成人高清电影在线| gogo大胆日本视频一区| 亚洲成人av在线电影| 久久一区二区三区四区|