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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? smsc111.c

?? WinCE5.0BSP for Renesas SH7770
?? C
?? 第 1 頁 / 共 5 頁
字號:
//
//  Copyright(C) Renesas Technology Corp. 2005. All rights reserved.
//
// LAN91C111 Network Driver for ITS-DS7
//
// FILE     : smsc111.c
// CREATED  : 2005.05.10
// MODIFIED : 
// AUTHOR   : Renesas Technology Corp.
// HARDWARE : RENESAS ITS-DS7
// HISTORY  : 
//            2005.05.10
//            - Created release code.
//                (based on SMSC100FD NETCARD driver for PUBLIC for WCE5.0)

//
// Copyright (c) Microsoft Corporation.  All rights reserved.
//
//
// Use of this source code is subject to the terms of the Microsoft end-user
// license agreement (EULA) under which you licensed this SOFTWARE PRODUCT.
// If you did not accept the terms of the EULA, you are not authorized to use
// this source code. For a copy of the EULA, please see the LICENSE.RTF on your
// install media.
//
/****************************************************************
 *																*
 * SMSC111 Ethernet Driver for Windows CE.						*
 *																*
 ****************************************************************/
#include <ndis.h>
#include "Smsc111.h"
#include <Smsc111Common.h>
#include <winreg.h>
#include <nkintr.h>

int glbl_tmp;
PVOID RegisterBase;
WORD  MAC0,MAC1,MAC2;

//static unsigned pVirtualRegisterBase;
//static unsigned uMultiplier;
//
// Read and Write word macros for accessing the SMSC111 Registers
//
_inline UINT16 ReadWord(PSMSC111_ADAPTER pAdapter,UINT wOffset) 
{
    USHORT usData;
    NdisReadRegisterUshort(
        (PUSHORT)((pAdapter->pVirtualRegisterBase) + (wOffset*pAdapter->uMultiplier)),
        &usData);
    return usData;
}
    
_inline DWORD ReadDWord(PSMSC111_ADAPTER pAdapter,UINT wOffset) 
{
    DWORD dwData;
    NdisReadRegisterUlong(
        (PULONG)((pAdapter->pVirtualRegisterBase) + (wOffset*pAdapter->uMultiplier)),
        &dwData);
    return dwData;
};

_inline void WriteWord(PSMSC111_ADAPTER pAdapter,UINT wOffset, UINT16 Value) 
{
    NdisWriteRegisterUshort(
        (PUSHORT)((pAdapter->pVirtualRegisterBase) + (wOffset*pAdapter->uMultiplier)),
        Value);
}

#define SelectBank(x,Bank) WriteWord (x,BANK_SELECT, Bank)
void	printregs(IN PSMSC111_ADAPTER pAdapter);

//
// The global Miniport driver block.
//
DRIVER_BLOCK gSmsc111MiniportBlock = {0};

#if DBG
DBGPARAM dpCurSettings = {
    TEXT("Smsc111"), {
    TEXT("Errors"),TEXT("Warnings"),TEXT("Functions"),TEXT("Init"),
    TEXT("Interrupts"),TEXT("Receives"),TEXT("Transmits"),TEXT("Link"),
    TEXT("Undefined"),TEXT("Undefined"),TEXT("Undefined"),TEXT("Undefined"),
    TEXT("Undefined"),TEXT("Undefined"),TEXT("Undefined"),TEXT("Undefined") },
	ZONE_INIT_MASK | ZONE_ERROR_MASK
	};
#endif

// Values for [HKEY_LOCAL_MACHINE\Comm\CELAN]
REG_VALUE_DESCR CommSmsc111KeyValues[] = {
	{(TEXT ("DisplayName")),		REG_SZ,			(PBYTE)(TEXT ("SMSC111 Ethernet Driver"))},
	{(TEXT ("Group")),				REG_SZ,			(PBYTE)(TEXT ("NDIS"))},
	{(TEXT ("ImagePath")),			REG_SZ,			(PBYTE)(TEXT ("celan.dll"))},
	{NULL,							0,				NULL}};

// Values for [HKEY_LOCAL_MACHINE\Comm\CELAN\Linkage]
REG_VALUE_DESCR CommSmsc111LinkageKeyValues[] = {
	{(TEXT ("Route")),				REG_MULTI_SZ,	(PBYTE)(TEXT ("CELAN1"))},
	{NULL,							0,				NULL}};

// Values for [HKEY_LOCAL_MACHINE\Comm\CELAN1]
REG_VALUE_DESCR CommSmsc1111KeyValues[] = {
	{(TEXT ("DisplayName")),		REG_SZ,			(PBYTE)(TEXT ("SMSC111 Ethernet Driver"))},
	{(TEXT ("Group")),				REG_SZ,			(PBYTE)(TEXT ("NDIS"))},
	{(TEXT ("ImagePath")),			REG_SZ,			(PBYTE)(TEXT ("celan.dll"))},
	{NULL,							0,				NULL}};

// Values for [HKEY_LOCAL_MACHINE\Comm\CELAN1\Parms]
REG_VALUE_DESCR CommSmsc1111ParmsKeyValues[] = {
	{(TEXT ("BusNumber")),			REG_SZ,			(PBYTE)(TEXT ("SMSC111 Ethernet Driver"))},
	{(TEXT ("BusType")),			REG_SZ,			(PBYTE)(TEXT ("NDIS"))},
	{NULL,							0,				NULL}};

// Values for [HKEY_LOCAL_MACHINE\Comm\CELAN1\Parms\TcpIp]
REG_VALUE_DESCR CommSmsc1111ParmsTcpIpKeyValues[] = {
	{(TEXT ("EnableDHCP")),			REG_DWORD,		(PBYTE)1},
	{(TEXT ("DefaultGateway")),		REG_MULTI_SZ,	(PBYTE)(TEXT ("0.0.0.0"))},
	{(TEXT ("IpAddress")),			REG_MULTI_SZ,	(PBYTE)(TEXT ("0.0.0.0"))},
	{(TEXT ("Subnetmask")),			REG_MULTI_SZ,	(PBYTE)(TEXT ("0.0.0.0"))},
	{(TEXT ("WINS")),				REG_MULTI_SZ,	(PBYTE)(TEXT (""))},
	{(TEXT ("DNS")),				REG_MULTI_SZ,	(PBYTE)(TEXT (""))},
	{NULL,							0,				NULL}};

// Values for [HKEY_LOCAL_MACHINE\Comm\CELAN1\Parms\TcpIp]
REG_VALUE_DESCR CommTcpIpLinkageKeyValues[] = {
	{(TEXT ("Bind")),				REG_MULTI_SZ,	(PBYTE)(TEXT ("CELAN1"))},
	{NULL,							0,				NULL}};

PREG_VALUE_DESCR Values[] = {
    CommSmsc111KeyValues,
    CommSmsc111LinkageKeyValues,
    CommSmsc1111KeyValues,
	CommSmsc1111ParmsKeyValues,
	CommSmsc1111ParmsTcpIpKeyValues,
	CommTcpIpLinkageKeyValues,
	};

LPWSTR KeyNames[] = {
    (TEXT ("Comm\\CELAN")),
    (TEXT ("Comm\\CELAN\\Linkage")),
    (TEXT ("Comm\\CELAN1")),
    (TEXT ("Comm\\CELAN1\\Parms")),
    (TEXT ("Comm\\CELAN1\\Parms\\TcpIp")),
    (TEXT ("Comm\\TcpIp\\Linkage")),
	};

/*
 * Description:
 *	The Install_Driver routine sets up the registry keys and values required to install this
 *	DLL as a Windows CE driver.
 *
 * Arguments:
 *	lpPnpId - The device's plug and play identifier string.
 *			  An install function can use lpPnpId to set up a key HKEY_LOCAL_MACHINE\Drivers\PCMCIA\<lpPnpId> under the
 *			  assumption that the user will continue to use the same device that generates the same plug and play
 *			  id string. If there is a general detection method for the card, then lpPnpId can be ignored and a
 *			  detection function can be registered under HKEY_LOCAL_MACHINE\Drivers\PCMCIA\Detect.
 *	lpRegPath - Buffer to contain the newly installed driver's device key under HKEY_LOCAL_MACHINE in the registry.
 *			  Windows CE will attempt to load the the newly installed device driver upon completion of its
 *			  Install_Driver function.
 *	cRegPathSize - Number of bytes in lpRegPath.
 *
 * Return Value:
 *	lpRegPath if successful, NULL for failure.
 *
 */
LPWSTR
Install_Driver (LPWSTR lpPnpId, LPWSTR lpRegPath, DWORD  cRegPathSize)
	{
    UINT uiIndex;
//	NKDbgPrintfW (L"CELAN: Install_Driver\r\n");
    DEBUGMSG (ZONE_INIT, (TEXT ("+CELAN: Install_Driver (%s, %s, %d)\r\n"), lpPnpId, lpRegPath, cRegPathSize));

    for (uiIndex = 0; uiIndex < (sizeof (KeyNames) / sizeof (LPWSTR)); uiIndex++)
		{
        if (!AddKeyValues (KeyNames[uiIndex], Values[uiIndex]))
			{
			//
			// Clean up after failure.
			//
			for (uiIndex = 0; uiIndex < (sizeof (KeyNames) / sizeof (LPWSTR)); uiIndex++)
				RegDeleteKey (HKEY_LOCAL_MACHINE, KeyNames[uiIndex]);
		    DEBUGMSG (ZONE_INIT, (TEXT ("-CELAN: Install_Driver: Failed\r\n")));
			return (NULL);
			}
	    }

    //
    // Return "HKEY_LOCAL_MACHINE\Drivers\SMSC111"
    //
    wcscpy (lpRegPath, KeyNames[0]);
    DEBUGMSG (ZONE_INIT, (TEXT ("-CELAN: Install_Driver: Success\r\n")));
    return (lpRegPath);
	}

/*
 * Description:
 *	Add the specified key and its values to the registry under HKEY_LOCAL_MACHINE
 *
 * Arguments:
 *	KeyName - The key name under HKLM.
 *	Vals - The kays values.
 *
 * Return Value:
 *	TRUE if successful, else FALSE.
 *
 */
BOOL
AddKeyValues (LPWSTR KeyName, PREG_VALUE_DESCR Vals)
	{
    DWORD Status;
    DWORD dwDisp;
    HKEY hKey;
    PREG_VALUE_DESCR pValue;
    DWORD ValLen;
    PBYTE pVal;
    DWORD dwVal;
    LPWSTR pStr;

    Status = RegCreateKeyEx (HKEY_LOCAL_MACHINE, KeyName, 0, NULL, REG_OPTION_NON_VOLATILE, 0, NULL, &hKey, &dwDisp);

    if (Status != ERROR_SUCCESS)
        return (FALSE);

    pValue = Vals;
    while (pValue->val_name)
		{
		switch (pValue->val_type)
			{
			case REG_DWORD:
				pVal = (PBYTE)&dwVal;
				dwVal = (DWORD)pValue->val_data;
				ValLen = sizeof (DWORD);
				break;
			case REG_SZ:
				pVal = (PBYTE)pValue->val_data;
				ValLen = (wcslen ((LPWSTR)pVal) + 1) * sizeof (WCHAR);
				break;
			case REG_MULTI_SZ:
				dwVal = wcslen ((LPWSTR)pValue->val_data);
				ValLen = (dwVal + 2) * sizeof (WCHAR);
				pVal = LocalAlloc (LPTR, ValLen);
				if (pVal == NULL)
					{
					RegCloseKey (hKey);
					return (FALSE);
					}
				wcscpy ((LPWSTR)pVal, (LPWSTR)pValue->val_data);
				pStr = (LPWSTR)pVal + dwVal;
				pStr[1] = 0;
				break;
			}
		Status = RegSetValueEx (hKey, pValue->val_name, 0, pValue->val_type, pVal, ValLen);
		if (pValue->val_type == REG_MULTI_SZ)
			LocalFree (pVal);
        if (Status != ERROR_SUCCESS)
			{
            RegCloseKey (hKey);
            return (FALSE);
			}
        pValue++;
	    }
    RegCloseKey (hKey);
    return (TRUE);
	}

/*
 * Description:
 *	Standard Windows DLL entrypoint.
 *
 * Arguments:
 *	hDLL - Handle to the DLL.
 *	dwReason - Reason for DllEntry call.
 *	lpReserved - Reserved.
 *
 * Return Value:
 *	TRUE.
 *
 */
BOOL __stdcall
DllEntry (HANDLE hDLL, DWORD dwReason, LPVOID lpReserved)
	{
    DEBUGMSG (ZONE_FUNCTION, (TEXT ("+CELAN: DllEntry\r\n")));
    switch (dwReason)
		{
		case DLL_PROCESS_ATTACH:
			DEBUGREGISTER (hDLL);
			DEBUGMSG (ZONE_INIT, (TEXT (" CELAN: DLL_PROCESS_ATTACH\r\n")));
			DisableThreadLibraryCalls((HMODULE) hDLL);
			break;
		case DLL_PROCESS_DETACH:
			DEBUGMSG (ZONE_INIT, (TEXT (" CELAN: DLL_PROCESS_DETACH\r\n")));
			break;
		}
    DEBUGMSG (ZONE_FUNCTION, (TEXT ("-CELAN: DllEntry\r\n")));
	return (TRUE);
	}

//
// List of supported OID for this the SMSC111 driver.
//
static UINT Smsc111SupportedOids[] = {
    OID_GEN_SUPPORTED_LIST,
    OID_GEN_HARDWARE_STATUS,
    OID_GEN_MEDIA_SUPPORTED,
    OID_GEN_MEDIA_IN_USE,
    OID_GEN_MAXIMUM_LOOKAHEAD,
    OID_GEN_MAXIMUM_FRAME_SIZE,
    OID_GEN_MAXIMUM_TOTAL_SIZE,
    OID_GEN_MAC_OPTIONS,
    OID_GEN_PROTOCOL_OPTIONS,
    OID_GEN_LINK_SPEED,
    OID_GEN_TRANSMIT_BUFFER_SPACE,
    OID_GEN_RECEIVE_BUFFER_SPACE,
    OID_GEN_TRANSMIT_BLOCK_SIZE,
    OID_GEN_RECEIVE_BLOCK_SIZE,
    OID_GEN_VENDOR_DESCRIPTION,
    OID_GEN_VENDOR_ID,
    OID_GEN_DRIVER_VERSION,
    OID_GEN_CURRENT_PACKET_FILTER,
    OID_GEN_CURRENT_LOOKAHEAD,
    OID_GEN_XMIT_OK,
    OID_GEN_RCV_OK,
    OID_GEN_XMIT_ERROR,
    OID_GEN_RCV_ERROR,
    OID_GEN_RCV_NO_BUFFER,
    OID_802_3_PERMANENT_ADDRESS,
    OID_802_3_CURRENT_ADDRESS,
    OID_802_3_MULTICAST_LIST,
    OID_802_3_MAXIMUM_LIST_SIZE,
    OID_802_3_RCV_ERROR_ALIGNMENT,
    OID_802_3_XMIT_ONE_COLLISION,
#ifndef UNDER_CE    
    OID_802_3_XMIT_MORE_COLLISIONS
#else
     OID_802_3_XMIT_MORE_COLLISIONS,
     OID_GEN_MEDIA_CONNECT_STATUS,
     OID_GEN_MAXIMUM_SEND_PACKETS,
     OID_GEN_VENDOR_DRIVER_VERSION   
#endif
    };

/*
 * Description:
 *	The Smsc111QueryInformation processes a Query request for NDIS_OIDs that are specific to the Driver.
 *
 * Arguments:
 *	hMiniportAdapterContext - A pointer to the adapter.
 *	Oid - The NDIS_OID to process.
 *	InformationBuffer - A pointer to where to put the result of the query.
 *	InformationBufferLength - A pointer to the number of bytes left in the InformationBuffer.
 *	BytesWritten - A pointer to the number of bytes written into the InformationBuffer.
 *	BytesNeeded - If there is not enough room in the information buffer then this will contain the number
 *				  of bytes needed to complete the request.
 *
 * Return Value:
 *	The status of the operation.
 *
 */
NDIS_STATUS
Smsc111QueryInformation (IN NDIS_HANDLE hMiniportAdapterContext, IN NDIS_OID Oid, IN PVOID pInformationBuffer, IN ULONG ulInformationBufferLength, OUT PULONG pulBytesWritten, OUT PULONG pulBytesNeeded)
	{
    //
    // Pointer to the adapter structure.
    //
	PSMSC111_ADAPTER pAdapter = (PSMSC111_ADAPTER)(hMiniportAdapterContext);
    //
    //   General Algorithm:
    //
    //      Switch(Request)
    //         Get requested information
    //         Store results in a common variable.
    //      default:
    //         Try protocol query information
    //         If that fails, fail query.
    //
    //      Copy result in common variable to result buffer.
    //   Finish processing

	NDIS_STATUS StatusToReturn = NDIS_STATUS_SUCCESS;
	NDIS_HARDWARE_STATUS HardwareStatus = NdisHardwareStatusReady;
	NDIS_MEDIUM Medium = NdisMedium802_3;
	UCHAR VendorString[] = "SMSC91C111 Ethernet Controller.";
    //
    // These variables holds the result of the query
    //
    ULONG ulGeneric;
    USHORT usGeneric;
    UCHAR ucGenericArray[6];
    ULONG ulMoveBytes = sizeof (ULONG);
    PVOID pMoveSource = (PVOID)(&ulGeneric);

    DEBUGMSG (ZONE_FUNCTION, (TEXT ("+CELAN: QueryInformation OID = 0x%x pAdapter = 0x%x hMiniportAdapterContext = 0x%x\r\n"), Oid, pAdapter, hMiniportAdapterContext));
    //
    // Make sure that an int is 4 bytes. Else GenericULong must change
    // to something of size 4.
    //
    ASSERT(sizeof (ULONG) == 4);

    //
    // Switch on request type
    //
    switch (Oid)
		{
		case OID_GEN_MAC_OPTIONS:

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
99久久免费精品高清特色大片| 免费在线一区观看| 亚洲一区国产视频| 另类调教123区| 99久久精品国产一区二区三区| 欧美日韩国产综合一区二区| 久久精品人人爽人人爽| 午夜视频一区二区| 91在线观看成人| 久久综合狠狠综合久久激情 | 日韩精品中文字幕一区二区三区| 亚洲国产精品av| 老司机精品视频在线| 欧美伊人精品成人久久综合97| 91精品国产高清一区二区三区 | 91在线免费视频观看| 日韩精品最新网址| 午夜精品久久久久久不卡8050| 成人性生交大片免费| 精品国产一区二区三区不卡| 亚洲h动漫在线| 欧美亚洲国产怡红院影院| 亚洲欧美综合色| 成人午夜电影小说| 欧美国产一区二区| 国产成人精品免费一区二区| 精品国产一区久久| 极品少妇一区二区| 久久久久久久久蜜桃| 久久机这里只有精品| 欧美一级电影网站| 免费看日韩精品| 精品国偷自产国产一区| 美女脱光内衣内裤视频久久影院| 色综合天天视频在线观看 | 国产精品第13页| 激情综合色播激情啊| 欧美xxxx在线观看| 久久电影国产免费久久电影| 精品国产欧美一区二区| 精品中文av资源站在线观看| 精品国产精品一区二区夜夜嗨| 久久精品国产亚洲aⅴ| 欧美一区二区久久久| 蜜桃一区二区三区在线观看| 日韩一区二区三区四区| 国产在线精品一区二区不卡了| 久久综合久久鬼色| 国产精品123| 亚洲婷婷综合久久一本伊一区| 92国产精品观看| 亚洲aaa精品| 日韩欧美国产午夜精品| 五月天欧美精品| 日韩精品一区二区三区视频在线观看| 蜜桃av一区二区| 日本一区二区三区国色天香| 99精品视频中文字幕| 亚洲最大成人网4388xx| 精品免费日韩av| 成人免费看的视频| 亚洲福利一二三区| 精品久久一区二区三区| 成人国产视频在线观看 | 亚洲日本一区二区三区| 在线影视一区二区三区| 蜜臀av一区二区在线观看| 中文字幕日韩一区二区| 欧美三区在线观看| 国产一区二区视频在线| 一区二区三区在线看| 欧美一级理论性理论a| 国产91综合一区在线观看| 亚洲图片一区二区| 精品福利一二区| 91老师片黄在线观看| 麻豆国产欧美日韩综合精品二区| 国产精品三级视频| 91精品国产丝袜白色高跟鞋| 成人av网站免费观看| 日本不卡的三区四区五区| 国产精品成人免费| 日韩精品一区二区三区四区| 在线观看免费一区| 国产成人精品亚洲777人妖| 亚洲电影一级片| 成人欧美一区二区三区黑人麻豆 | 中文字幕一区二区不卡| 欧美一区二区三区免费大片| 99re66热这里只有精品3直播| 蜜臀av一区二区在线观看| 亚洲午夜精品17c| 一区视频在线播放| 欧美精品一区二区三区蜜桃 | 美国欧美日韩国产在线播放| 亚洲少妇屁股交4| 国产日韩欧美不卡| 欧美大片拔萝卜| 宅男在线国产精品| 欧美色综合天天久久综合精品| 成人免费va视频| 懂色一区二区三区免费观看| 久久精品99国产国产精| 日本91福利区| 奇米一区二区三区| 五月婷婷久久丁香| 亚洲成人你懂的| 亚洲一区自拍偷拍| 亚洲一区二区视频在线| 亚洲人成伊人成综合网小说| 国产精品欧美久久久久无广告| 久久久久国产精品麻豆| 精品免费国产一区二区三区四区| 日韩一区二区三区在线视频| 91精品久久久久久久99蜜桃| 91精品国产综合久久久久久久 | 亚洲黄色免费电影| 亚洲色图欧美在线| 国产精品国产三级国产有无不卡| 久久久久9999亚洲精品| 国产午夜精品一区二区三区四区 | 午夜日韩在线观看| 午夜电影久久久| 日本aⅴ亚洲精品中文乱码| 麻豆精品视频在线观看| 奇米影视7777精品一区二区| 麻豆精品视频在线观看免费| 国产精品自拍一区| 成人性生交大合| 色综合中文字幕国产 | 日本一区二区在线不卡| 国产女同互慰高潮91漫画| 国产精品美女久久久久久久久 | 精品一区二区在线视频| 国产在线视频不卡二| 成人午夜精品一区二区三区| 91麻豆国产香蕉久久精品| 欧美在线免费视屏| 91精品国产一区二区三区| 久久精品亚洲国产奇米99 | 久久精品夜夜夜夜久久| 国产精品不卡在线| 亚洲18影院在线观看| 免费在线看一区| 国产不卡免费视频| 日本精品一区二区三区高清 | 国产激情一区二区三区| 99久久国产综合精品色伊| 欧美日韩一区二区三区在线| 欧美一级高清大全免费观看| 中文字幕av不卡| 午夜伊人狠狠久久| 国产精品亚洲视频| 91福利社在线观看| 精品国产免费久久| 亚洲另类春色国产| 狠狠色丁香婷婷综合| 91豆麻精品91久久久久久| 日韩欧美一二三四区| 最好看的中文字幕久久| 青青青伊人色综合久久| 91女厕偷拍女厕偷拍高清| 日韩免费高清视频| 国产精品久久久久9999吃药| 青青草伊人久久| 91小视频免费看| 久久久久久久久久美女| 91.xcao| 国产免费成人在线视频| 婷婷开心激情综合| bt7086福利一区国产| 日韩欧美一区二区在线视频| |精品福利一区二区三区| 老司机精品视频导航| 在线看国产一区| 日本一区二区三区国色天香| 久久66热偷产精品| 欧美性色欧美a在线播放| 久久在线免费观看| 日韩中文欧美在线| 欧洲一区二区三区免费视频| 国产欧美日韩精品一区| 久久精品国产久精国产| 欧美日韩精品一区二区三区蜜桃| 国产精品久久毛片a| 精品亚洲国产成人av制服丝袜| 色综合一个色综合| 中文成人av在线| 激情欧美一区二区| 99r精品视频| 国产精品污污网站在线观看| 日韩精品91亚洲二区在线观看| 91丝袜国产在线播放| 久久精品视频在线看| 极品少妇xxxx精品少妇偷拍 | 91视视频在线观看入口直接观看www| 91精品国产综合久久婷婷香蕉| 亚洲精品视频自拍| 色综合视频一区二区三区高清| 国产精品色哟哟|