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

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

?? car6k.cpp

?? Atheros Communications AR6001 WLAN Driver for SDIO installation Read Me March 26,2007 (based on
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
	if (A_OK != status)
		goto done;
    
	status = configTargetParams();

done:
	NDIS_DEBUG_PRINTF(ATH_LOG_TRC, "AR6K: -StartEndpoints status=%u", status);
	return status;
}

void
CAR6KMini::StopEndpoints()
//
//  Undoes the initialization done by StartEndpoints.
//
{
	NDIS_DEBUG_PRINTF(ATH_LOG_TRC, "AR6K: +StopEndpoints");
	if (m_HTCStarted) {
		HTCStop(m_pHTCTarget);
		m_HTCStarted = false;
	}

	if (!m_Config.byPassWmi) {
		if (m_pWMI) {
			wmi_shutdown((wmi_t *)m_pWMI);
			m_WMIReady = false;
			m_pWMI = NULL;
		}
	}

	NDIS_DEBUG_PRINTF(ATH_LOG_TRC, "AR6K: -StopEndpoints");
}

void
ResetPowerWorkItemFunction(
	PNDIS_WORK_ITEM WorkItem,
	PVOID           Context)
{
	CAR6KMini *pAdapter = (CAR6KMini *)Context;

    pAdapter->ResetPowerWorkItem();
}

void
AR6KWorkItemFunction(
	PNDIS_WORK_ITEM WorkItem,
	PVOID           Context)
//
//  This function is called after NdisScheduleWorkItem is called in MiniportInitialize.
//
{
	CAR6KMini *pAdapter = (CAR6KMini *)Context;

	pAdapter->IndicateReceivePackets();
}

/* Set the internal state variables based on the registry parameters */
A_STATUS
CAR6KMini::configRegistryParameters()
{
    switch(m_Config.powerSaveMode) {
        case 0:
            m_80211_PowerMode = Ndis802_11PowerModeCAM;
		    break;
        case 1:
		    m_ListenInterval = MAX_LISTEN_INTERVAL;
            m_80211_PowerMode = Ndis802_11PowerModeMAX_PSP;
		    break;
	    case 2:
		    m_ListenInterval = MIN_LISTEN_INTERVAL;
            m_80211_PowerMode = Ndis802_11PowerModeFast_PSP;
		    break;
        default:
            return A_ERROR;
	}

    return A_OK;
}

/* Configure the target from the registry settings only in wmi mode */
A_STATUS
CAR6KMini::configTargetParams()
{
	A_STATUS   wmiStatus = A_OK;
	A_UINT8 powerMode = 0;


	if (!m_Config.byPassWmi) {
		if (m_Config.bkScanEnable) {
			wmiStatus = wmi_scanparams_cmd((wmi_t *)m_pWMI,0,0,(A_UINT16)m_Config.bkScanPeriod,
										70,0,WMI_SHORTSCANRATIO_DEFAULT);
		} else {
			wmiStatus = wmi_scanparams_cmd((wmi_t *)m_pWMI,0,0,0,
										70,0,WMI_SHORTSCANRATIO_DEFAULT);
		}
		if (wmiStatus == A_OK) {
			if (m_Config.discTimeout) {
				wmiStatus = wmi_disctimeout_cmd((wmi_t *)m_pWMI, m_Config.discTimeout);
			}
		}

		/* restore the target Power Save settings */
		
		if ( wmiStatus == A_OK ) {
			
			switch( m_80211_PowerMode ) {

			case Ndis802_11PowerModeCAM:

				powerMode = MAX_PERF_POWER;
				break;
			case Ndis802_11PowerModeMAX_PSP:

				powerMode = REC_POWER;
				break;
			case Ndis802_11PowerModeFast_PSP:

				powerMode = REC_POWER;
				break;
			default:
				// this will never occur.
				break;
			}

			wmiStatus = wmi_powermode_cmd((struct wmi_t *)m_pWMI, powerMode);
		}
	}

	return wmiStatus;
}

#ifdef WINDOWS_MOBILE
A_STATUS setWiFiStator()
{
	HKEY handle;
	LONG result;
	DWORD data;
	A_STATUS status = A_ERROR;

	result = RegOpenKeyEx(HKEY_LOCAL_MACHINE,_T("SYSTEM\\STATE\\HARDWARE"),0,0,&handle);
	if (result == ERROR_SUCCESS) {
		data = 0x1; //Start with WLAN module available
		result = RegSetValueEx(handle,_T("WiFi"),0,REG_DWORD,(LPBYTE)&data,sizeof(DWORD));
		if (result == ERROR_SUCCESS) {
			status = A_OK;
		}
      	RegCloseKey(handle);
	}

	return status;
}
#endif

A_UINT32 
CAR6KMini::getResetPowerState()
{
#ifdef WINDOWS_MOBILE
	BOOL          wirelessState;
#endif
	A_UINT32      powerState;

	// Read the reset state configured thru the registry
	powerState = m_Config.resetPowerState;
        
#ifdef WINDOWS_MOBILE
	// For windows mobile read the flight mode status
	if (GetWirelessState(&wirelessState) == ERROR_SUCCESS) {
		powerState = powerState & (wirelessState ? 1 : 0);   
	}
#endif
	NDIS_DEBUG_PRINTF(ATH_LOG_INF,"Reset Power State = %d \n",powerState);

	return powerState;
}

#if defined CF
#ifdef WINDOWS_MOBILE
#define AR6K_DEVICE_POWER_NAME TEXT("SYSTEM\\netui-AR6K1")
#else
#define AR6K_DEVICE_POWER_NAME _T("{98C5250D-C29A-4985-AE5F-AFE5367E5006}\\AR6K_CF1")
#endif
#elif defined SDIO
#define AR6K_DEVICE_POWER_NAME _T("{98C5250D-C29A-4985-AE5F-AFE5367E5006}\\AR6K_SD1")
#else
#error "Bus type not defined"
#endif

void
CAR6KMini::ResetPowerWorkItem()
{
	A_UINT32      powerState;
#ifdef WINDOWS_MOBILE
	RDD * pDevice = NULL;
	RDD * pTD;
	HRESULT hr = S_OK;
	HANDLE driverStateEvent;
#else
	CEDEVICE_POWER_STATE cePowerState;
	DWORD         status;
#endif
	A_STATUS      athStatus=A_ERROR;

	NDIS_DEBUG_PRINTF(ATH_LOG_TRC,"ResetPowerWorkItem :: Entry\n");

	NdisResetEvent(&m_ResetPowerWorkItemExitedEvent);

	if (!m_Config.byPassWmi) {
		// Dual-Purpose workitem 
		// Indicate disconnect after the MiniportInit complete successfully
		// This is needed for 802.11 miniports
		while (m_Halting == false) {
			NdisMSleep(1000);
			if ((m_InitComplete) && (m_WMIReady)) {
				NdisMIndicateStatus(m_MiniportAdapterHandle, NDIS_STATUS_MEDIA_DISCONNECT, 0, 0);
				NdisMIndicateStatusComplete(m_MiniportAdapterHandle);
				break;
			}
		}
        
		powerState = getResetPowerState();
		if ((!powerState) && (m_Halting == false)) {    
#ifdef WINDOWS_MOBILE
			// Windows mobile notifies this event when the driver has completed initalization
			driverStateEvent = CreateEvent(NULL, FALSE, FALSE, AR6K_DEVICE_POWER_NAME);
			if (driverStateEvent != NULL) {
				WaitForSingleObject(driverStateEvent, INFINITE);
				CloseHandle(driverStateEvent);
			}
				
			// Wait till the WiFi entry is created
			while (m_Halting == false) {
				hr = GetWirelessDevices(&pDevice, 0);
				if (hr == S_OK) {
					if (pDevice) {
						pTD = pDevice;
						// loop through the linked list of devices
						while (pTD) { 								
							if (pTD->DeviceType==POWER_MANAGED) {
								hr=ChangeRadioState(pTD, 0, POWER_POST_SAVE);
								if (hr == S_OK) {
									athStatus = A_OK;
									// Update the registry state
									UpdateRadioStoredState(pTD,0);	
								}
							}								
							pTD = pTD->pNext;
						}
	
						// Free the list of devices retrieved with GetWirelessDevices()
						FreeDeviceList(pDevice);
						pDevice = NULL;
						break;
					}
				} else {
					break;
				}
				NdisMSleep(1000);
			} 
					
			if (pDevice) {
				FreeDeviceList(pDevice);
			}
#else //WINDOWS_MOBILE
			// Don't call the Power Manager APIs directly. 
			// Doing so assumes the PM is sysgen'ed into every image.
			typedef DWORD DevicePowerNotifyProto(PVOID, CEDEVICE_POWER_STATE, DWORD);
			typedef DWORD GetDevicePowerProto   (PVOID, DWORD, PCEDEVICE_POWER_STATE);
			DevicePowerNotifyProto *pfnDevicePowerNotify = NULL;
			GetDevicePowerProto    *pfnGetDevicePower    = NULL;
	            
			HMODULE hCoreDll = (HMODULE) LoadLibrary(TEXT("coredll.dll"));
			if (NULL != hCoreDll) {
				pfnDevicePowerNotify = (DevicePowerNotifyProto *)
					GetProcAddress(hCoreDll, TEXT("DevicePowerNotify"));
				pfnGetDevicePower = (GetDevicePowerProto *)
					GetProcAddress(hCoreDll, TEXT("GetDevicePower"));
			}
	            
			if ((NULL == pfnDevicePowerNotify) || (NULL == pfnGetDevicePower))
			{
				athStatus = A_ERROR;
			} else {
				// Improper way to find whether NDIS has created the power
				// reletionship for the miniport using RegisterPowerRelationship
				// with the power manager
				while (m_Halting == false) {
					status= pfnGetDevicePower((PVOID)AR6K_DEVICE_POWER_NAME, POWER_NAME, &cePowerState);
					if (status != ERROR_FILE_NOT_FOUND) {
						break;
					}
					NdisMSleep(1000);
				} 
            
	
				if ((status == ERROR_SUCCESS) && (m_Halting == false)) {
					cePowerState = D4;
					status = pfnDevicePowerNotify((PVOID)AR6K_DEVICE_POWER_NAME,cePowerState,POWER_NAME);
					if (status == ERROR_SUCCESS) {
						athStatus = A_OK;
					}
				}
			}
	
			if (NULL != hCoreDll) {
				FreeLibrary(hCoreDll);
			}
#endif
			if (athStatus == A_ERROR) {
				NDIS_DEBUG_PRINTF(ATH_LOG_ERR,"ResetPowerWorkItem :: Reset power state set failed\n");
			}  else {
				NDIS_DEBUG_PRINTF(ATH_LOG_INF,"ResetPowerWorkItem :: Reset power state set success\n");
			}
		}
	}

	NdisSetEvent(&m_ResetPowerWorkItemExitedEvent);
    
	NDIS_DEBUG_PRINTF(ATH_LOG_TRC,"ResetPowerWorkItem :: Exit\n");

	return;
}

NDIS_STATUS
CAR6KMini::Initialize(
	IN NDIS_HANDLE MiniportAdapterHandle,
	IN NDIS_HANDLE ConfigHandle)
//
//  This function is called by NDIS when a new adapter
//  instance is being instantiated.
//
//  Read configuration settings from the registry and
//  initialize the AR6000 adapter.
//
{
	NDIS_STATUS   Status;
	A_STATUS      athStatus = A_OK;

	NDIS_DEBUG_PRINTF(ATH_LOG_TRC, "AR6K: +Initialize");

	NdisInitializeEvent(&m_tgtReadyEvent);
	NdisInitializeEvent(&m_WMIReadyEvent);
	NdisInitializeEvent(&m_RxPendingEvent);
	NdisInitializeEvent(&m_RxWorkItemExitedEvent);
	NdisInitializeEvent(&m_tgtStatsEvent);
	NdisInitializeEvent(&m_ResetPowerWorkItemExitedEvent);
    
	NdisSetEvent(&m_RxWorkItemExitedEvent);
	NdisSetEvent(&m_ResetPowerWorkItemExitedEvent);
	NdisResetEvent(&m_tgtReadyEvent);

	m_MaxTransmitBuffers = DEFAULT_MAX_TRANSMIT_BUFFERS;
	m_MaxTransmitBufferPayloadDataLength = DEFAULT_MAX_TRANSMIT_BUFFER_PAYLOAD_DATA_LENGTH;
	InitializeListHead(&m_TransmitBufferList);
	InitializeListHead(&m_TransmitNdisPacketList);
	InitializeListHead(&m_RxPendingPacketList);

	memset(m_DesiredAPBSSID, 0xFF, sizeof(m_DesiredAPBSSID));

	m_PowerChangeEvent = CreateEvent(NULL, FALSE, FALSE, TEXT("AR6K_PowerChange"));
	if (m_PowerChangeEvent == NULL) {
		goto done;
	}

	// Perform base class initialization first
	Status = CMiniport::Initialize(MiniportAdapterHandle, ConfigHandle);
	if (NDIS_STATUS_SUCCESS != Status)
		goto done;

	Status = ParseRegistryParameters(ConfigHandle, &m_Config);
	if (NDIS_STATUS_SUCCESS != Status)
		goto done;

    if (configRegistryParameters() != A_OK)
        goto done;

	//
	// If the SDIO component is uninitialized, then we should not be
	// getting called. If we do, for some reason, then return an error.
	//

	Status = TransmitBufferListAllocate();
	if (NDIS_STATUS_SUCCESS != Status)
		goto done;

	NdisAllocatePacketPool(&Status, &m_RxPacketPool, AR6000_MAX_RX_BUFFERS, 16);
	if (NDIS_STATUS_SUCCESS != Status)
		goto done;

	// Create a work item to peform receive packet indications
	NdisInitializeWorkItem(&m_WorkItem, AR6KWorkItemFunction, this);
	Status = NdisScheduleWorkItem(&m_WorkItem);
	if (NDIS_STATUS_SUCCESS != Status)
		goto done;

    // Create a work item to power off wlan upon reset
	NdisInitializeWorkItem(&m_ResetPowerWorkItem, ResetPowerWorkItemFunction, this);
	Status = NdisScheduleWorkItem(&m_ResetPowerWorkItem);
	if (NDIS_STATUS_SUCCESS != Status)
		goto done;

	// Register with HTC
	athStatus = HTCInit();
	if (athStatus != A_OK)
		goto done;
	m_HTCInited = true;

	athStatus = HTCEventReg(NULL, ENDPOINT_UNUSED, HTC_TARGET_AVAILABLE, AR6KTargetAvailableEventHandler, this);
	if (athStatus != A_OK)
		goto done;

	athStatus = HTCEventReg(NULL, ENDPOINT_UNUSED, HTC_TARGET_UNAVAILABLE, AR6KTargetUnavailableEventHandler, this);
	if (athStatus != A_OK)
		goto done;

	NdisWaitEvent(&m_tgtReadyEvent, AR6K_DEFAULT_MS_TO_WAIT_FOR_TGT_READY);
	if (!m_tgtReady)
	{
		NDIS_DEBUG_PRINTF(ATH_LOG_ERR, "AR6K: ERROR - No TGT_READY event after %u ms, failing initialization\n", AR6K_DEFAULT_MS_TO_WAIT_FOR_TGT_READY);
		athStatus = A_ERROR;
		goto done;
	}

#ifdef WINDOWS_MOBILE
	athStatus = setWiFiStator();
	if (athStatus != A_OK) {
		athStatus = A_ERROR;
		goto done;
    }
#endif

	m_InitComplete = true;

done:
	if (athStatus != A_OK)
		Status = NDIS_STATUS_FAILURE;

	if (NDIS_STATUS_SUCCESS != Status)
	{
		// If we fail Initialize, then our Halt won't be called by NDIS,
		// so clean up all resources allocated by Initialize.
		Halt();
	}

	NDIS_DEBUG_PRINTF(ATH_LOG_TRC, "AR6K: -Initialize status=%x", Status);

	return Status;
}

void
CAR6KMini::Halt()
//
// This function undoes Initialize.
// It stops the adapter and frees resources
//
{
	NDIS_DEBUG_PRINTF(ATH_LOG_TRC, "AR6K: +Halt");

	m_Halting = true;
	if (m_Connected) {
		NdisMIndicateStatus(m_MiniportAdapterHandle, NDIS_STATUS_MEDIA_DISCONNECT, 0, 0);
		NdisMIndicateStatusComplete(m_MiniportAdapterHandle);
		m_Connected = FALSE;
	}
    
	// Wakeup the Rx Work Item thread so it can exit
	NdisSetEvent(&m_RxPendingEvent);
	NdisWaitEvent(&m_RxWorkItemExitedEvent, 0);

	// Wakeup the Get Stats thread if any
	NdisSetEvent(&m_tgtStatsEvent);

	NdisWaitEvent(&m_ResetPowerWorkItemExitedEvent, 0);

	NdisFreeEvent(&m_tgtReadyEvent);
	NdisFreeEvent(&m_WMIReadyEvent);
	NdisFreeEvent(&m_RxPendingEvent);
	NdisFreeEvent(&m_RxWorkItemExitedEvent);
	NdisFreeEvent(&m_tgtStatsEvent);
	NdisFreeEvent(&m_ResetPowerWorkItemExitedEvent);

#ifdef SUPPORT_WPA2
	if( m_pPMKID ) {
		A_FREE(m_pPMKID);
		m_pPMKID = NULL;
	}
#endif //SUPPORT_WPA2
    
	if (m_pAssocInfo != NULL) {
		A_FREE(m_pAssocInfo);
        m_pAssocInfo = NULL;
    }

	if (m_PowerChangeEvent) {
		CloseHandle(m_PowerChangeEvent);
		m_PowerChangeEvent = NULL;
	}

	if (m_HTCInited) {
		HTCShutDown(m_pHTCTarget);
        m_HTCInited = false;
	}
    
	CMiniport::Halt();

	if (m_pTransmitBufferArray)
		A_FREE(m_pTransmitBufferArray);

	if (m_RxPacketPool)
		NdisFreePacketPool(m_RxPacketPool);

	NDIS_DEBUG_PRINTF(ATH_LOG_TRC, "AR6K: -Halt");
}

BOOLEAN
CAR6KMini::CheckForHang()
//
//  This function is called periodically (default every 2 seconds) by NDIS
//  to check whether the adapter is in a hung state in which it is no longer
//  sending/receiving. If this function returns TRUE, then NDIS will reset
//  the adapter.
//
{
	return FALSE;
}

NDIS_STATUS
CAR6KMini::Reset(
	OUT PBOOLEAN pAddressingReset)
//
//  This function is called by NDIS to reset the adapter.
//  If addressing information needs to be reset (e.g. the multicast list),
//  then *pAddressingReset should be set to TRUE.
//
{
	return NDIS_STATUS_SUCCESS;
}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91精品福利视频| caoporn国产精品| 亚洲午夜在线视频| 亚洲欧美日韩久久| 成人欧美一区二区三区1314| 精品日韩99亚洲| 国产午夜精品美女毛片视频| 久久―日本道色综合久久| 26uuu国产一区二区三区| 精品欧美乱码久久久久久1区2区| 欧美一区二区三区播放老司机| 欧美日韩国产系列| 欧美一卡在线观看| 欧美一区二区三区日韩视频| 538在线一区二区精品国产| 7777精品伊人久久久大香线蕉 | 成人精品免费看| 成人久久18免费网站麻豆| 成人激情免费电影网址| 91网页版在线| 884aa四虎影成人精品一区| 91精品国产91综合久久蜜臀| 精品国产91久久久久久久妲己 | 亚洲国产综合在线| 日本美女一区二区三区| 国产iv一区二区三区| 91亚洲精品一区二区乱码| 欧美三级蜜桃2在线观看| 精品久久一区二区三区| 亚洲国产精品成人综合| 亚洲高清中文字幕| 国产麻豆午夜三级精品| 99re6这里只有精品视频在线观看| 91久久精品一区二区二区| 欧美哺乳videos| 亚洲欧洲综合另类| 免费成人在线视频观看| av福利精品导航| 这里只有精品电影| 欧美国产欧美综合| 日韩国产成人精品| 91视频www| 精品国产一区二区在线观看| 一区二区久久久久久| 久久国产精品露脸对白| 91免费国产视频网站| xf在线a精品一区二区视频网站| 亚洲人成网站在线| 国产一区在线观看视频| 欧美日韩国产天堂| 自拍偷拍欧美激情| 国产精品99久久久久久久vr | 美女网站视频久久| 色妞www精品视频| 久久夜色精品国产噜噜av| 亚洲综合色噜噜狠狠| 成人性视频免费网站| 欧美成人国产一区二区| 亚洲gay无套男同| 色哟哟国产精品| 国产精品萝li| 国产一二三精品| 欧美成人性福生活免费看| 亚洲午夜在线观看视频在线| 99久久国产综合精品女不卡| 久久久99精品免费观看| 日韩成人一区二区三区在线观看| 色综合天天视频在线观看| 国产精品另类一区| 成人免费视频一区| 久久久精品国产99久久精品芒果| 久久机这里只有精品| 91精品国产综合久久久蜜臀粉嫩| 亚洲国产另类av| 欧美性大战久久久| 亚洲成人一区二区在线观看| 在线视频你懂得一区二区三区| 亚洲老司机在线| 一本大道综合伊人精品热热| 亚洲天堂网中文字| 一本久久精品一区二区| 成人欧美一区二区三区白人| 91丨porny丨首页| 亚洲久草在线视频| 欧美日韩dvd在线观看| 视频一区国产视频| 日韩欧美色综合网站| 精品影视av免费| 国产日产欧美一区| 99精品国产热久久91蜜凸| 亚洲精品ww久久久久久p站| 色悠悠亚洲一区二区| 亚洲大尺度视频在线观看| 911国产精品| 国产一区二区三区久久悠悠色av | 亚洲美腿欧美偷拍| 欧美高清精品3d| 精品综合免费视频观看| 国产精品久久久久毛片软件| 欧美亚洲免费在线一区| 卡一卡二国产精品| 亚洲丝袜制服诱惑| 日韩一区二区视频| av在线综合网| 久久国产麻豆精品| 亚洲欧美一区二区在线观看| 欧美亚男人的天堂| 日日夜夜免费精品视频| 欧美另类z0zxhd电影| 国产最新精品免费| 中文字幕av一区 二区| 99re热这里只有精品视频| 亚洲免费观看高清完整版在线 | 亚洲另类春色国产| 欧美性受xxxx| 久久av老司机精品网站导航| 中文在线资源观看网站视频免费不卡| 成人激情免费电影网址| 亚洲一区二区中文在线| 69堂亚洲精品首页| 国产一区欧美二区| 综合自拍亚洲综合图不卡区| 欧美一卡在线观看| 成人福利电影精品一区二区在线观看| 亚洲欧洲国产专区| 欧美一级淫片007| 成人国产免费视频| 亚洲高清视频中文字幕| 国产精品日韩成人| 91麻豆精品国产91久久久久久| 国产综合色精品一区二区三区| 国产精品免费久久久久| 欧美午夜精品一区| 综合激情成人伊人| 中文字幕国产一区二区| 69久久99精品久久久久婷婷| 成人国产精品免费网站| 老司机精品视频线观看86| 亚洲女厕所小便bbb| 中文字幕在线免费不卡| 精品少妇一区二区三区在线播放 | 国产精品18久久久久| 午夜精品福利视频网站| 国产精品久久久久久久裸模| 欧美一区二区三区影视| 色婷婷精品久久二区二区蜜臀av | 久久午夜羞羞影院免费观看| 91成人免费网站| 国产91富婆露脸刺激对白| 青青草原综合久久大伊人精品 | 懂色中文一区二区在线播放| 日日骚欧美日韩| 亚洲乱码国产乱码精品精98午夜 | 国产美女精品人人做人人爽| 亚洲线精品一区二区三区| 日韩一区日韩二区| 国产人成一区二区三区影院| 欧美一二区视频| 精品处破学生在线二十三| 3751色影院一区二区三区| 欧美性猛片aaaaaaa做受| 99久久婷婷国产综合精品电影| 国产福利精品一区| 奇米精品一区二区三区四区| 蜜臀av一区二区在线免费观看 | 国产一区二区在线观看视频| 蜜臀av一级做a爰片久久| 日韩av一区二区三区四区| 午夜婷婷国产麻豆精品| 亚洲国产精品一区二区www在线| 亚洲欧洲精品一区二区三区不卡| 日本一区二区免费在线 | 亚洲成人激情自拍| 亚洲国产精品久久久久婷婷884 | 精品成人私密视频| 久久蜜桃av一区精品变态类天堂 | 中文字幕欧美区| 亚洲欧美日韩国产手机在线| 日韩一区在线看| 亚洲已满18点击进入久久| 亚洲成人7777| 欧美aaaaaa午夜精品| 国产91高潮流白浆在线麻豆| 国产成a人亚洲精品| 波多野结衣一区二区三区| 不卡的看片网站| 91亚洲精华国产精华精华液| 福利一区二区在线观看| 在线精品观看国产| 欧美电影影音先锋| 久久尤物电影视频在线观看| 国产欧美久久久精品影院| 国产精品乱码久久久久久| 日本少妇一区二区| 国产乱妇无码大片在线观看| 国产91富婆露脸刺激对白| 在线观看一区不卡| 日韩美女一区二区三区四区| 亚洲精品美国一| 九九**精品视频免费播放|