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

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

?? d12testdlg.cpp

?? USB VC測試程序 周立功的USB板調試源碼
?? CPP
?? 第 1 頁 / 共 3 頁
字號:
/*
//*************************************************************************
//
//                  P H I L I P S   P R O P R I E T A R Y
//
//           COPYRIGHT (c)   1998 BY PHILIPS SINGAPORE.
//                     --  ALL RIGHTS RESERVED  --
//
// File Name:	D12TestDlg.CPP
// Author:		Wenkai Du
// Created:		14 Jan 98
// Modified:
// Revision:		1.4
//
//*************************************************************************
//
//*************************************************************************
*/

// D12TestDlg.cpp : implementation file
//
#include "stdafx.h"

#include <mmsystem.h>
#include "D12Test.h"
#include "D12TestDlg.h"
#include "devioctl.h"
#include "process.h"
#include "rwbulk.h"
#include "ioctl.h"
#include <afxmt.h>
#include "timer.h"

#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif

BOOL DevIOCtrl(HANDLE hDevice, DWORD dwIoControlCode, LPVOID lpInBuffer, 
			   DWORD nInBufferSize, LPVOID lpOutBuffer, DWORD nOutBufferSize, 
			   LPDWORD lpBytesReturned);


BOOL Read(HANDLE hFile, LPVOID lpBuffer, DWORD nNumberOfBytesToRead, LPDWORD lpNumberOfBytesRead)
{
	OVERLAPPED os;
	memset(&os,0,sizeof(OVERLAPPED));
	os.hEvent=::CreateEvent(NULL,TRUE,FALSE,NULL);
	int err=0;
	BOOL bResult = ReadFile(hFile,lpBuffer,nNumberOfBytesToRead,
				lpNumberOfBytesRead,&os);
	*lpNumberOfBytesRead=0;
	if(!bResult)
	{
		if(::GetLastError()==ERROR_IO_PENDING)
		{
			switch(::WaitForSingleObject(os.hEvent,2000))
			{
			case WAIT_OBJECT_0:
				if(!::GetOverlappedResult(hFile,&os,lpNumberOfBytesRead,FALSE))
				{
					err=::GetLastError();
				}
				break;
			case WAIT_TIMEOUT:
				::CancelIo(hFile);
				err=ERROR_TIMEOUT;
				break;
			default:
				err=::GetLastError();
				break;
			}
		}
		else
		{
			*lpNumberOfBytesRead=-1;
			err=1;
		}
	}
	CloseHandle(os.hEvent);
	DWORD nBytes;
	if(err)
		DevIOCtrl(hFile,IOCTL_D12_RESET_PIPE,0,0,0,0,&nBytes);

	return err==0;
}
BOOL Write(HANDLE hFile, LPVOID lpBuffer, DWORD nNumberOfBytesToWrite, LPDWORD lpNumberOfBytesWrite)
{
	OVERLAPPED os;
	memset(&os,0,sizeof(OVERLAPPED));
	os.hEvent=::CreateEvent(NULL,TRUE,FALSE,NULL);
	int err=0;
	BOOL bResult = WriteFile(hFile,lpBuffer,nNumberOfBytesToWrite,
				lpNumberOfBytesWrite,&os);
	if(!bResult)
	{
		if(::GetLastError()==ERROR_IO_PENDING)
		{
			switch(::WaitForSingleObject(os.hEvent,2000))
			{
			case WAIT_OBJECT_0:
				if(!::GetOverlappedResult(hFile,&os,lpNumberOfBytesWrite,FALSE))
				{
					err=::GetLastError();
				}
				break;
			case WAIT_TIMEOUT:
				::CancelIo(hFile);
				err=ERROR_TIMEOUT;
				break;
			default:
				err=::GetLastError();
				break;
			}
		}
		else
			err=1;
	}
	CloseHandle(os.hEvent);
	DWORD nBytes;
	if(err)
		DevIOCtrl(hFile,IOCTL_D12_RESET_PIPE,0,0,0,0,&nBytes);
	return err==0;
}
CCriticalSection m_sec;
BOOL DevIOCtrl(HANDLE hDevice, DWORD dwIoControlCode, LPVOID lpInBuffer, 
			   DWORD nInBufferSize, LPVOID lpOutBuffer, DWORD nOutBufferSize, 
			   LPDWORD lpBytesReturned)
{
	m_sec.Lock();
	OVERLAPPED os;
	memset(&os,0,sizeof(OVERLAPPED));
	os.hEvent=::CreateEvent(NULL,TRUE,FALSE,NULL);
	int err=0;

	BOOL bResult = DeviceIoControl(hDevice,
			dwIoControlCode,
			lpInBuffer,
			nInBufferSize,
			lpOutBuffer,
			nOutBufferSize,
			lpBytesReturned,
			&os);

	if(!bResult)
	{
		if(::GetLastError()==ERROR_IO_PENDING)
		{
			switch(::WaitForSingleObject(os.hEvent,1000))
			{
			case WAIT_OBJECT_0:
				if(!::GetOverlappedResult(hDevice,&os,lpBytesReturned,FALSE))
				{
					err=::GetLastError();
				}
				break;
			case WAIT_TIMEOUT:
				::CancelIo(hDevice);
				err=ERROR_TIMEOUT;
				break;
			default:
				err=::GetLastError();
				break;
			}
		}
		else
			err=1;
	}
	CloseHandle(os.hEvent);
	m_sec.Unlock();
	return err==0;
}


UINT InterruptIn(void * pParam)
{  
	char cc[180], c;
    BOOLEAN bResult = FALSE;
    ULONG nBytes = 0;
	struct CThreadParam * threadParam;
	HANDLE hFile, hDevice;
	CD12TestDlg* testDlg;
	IO_BLOCK ioBlock;
	
	threadParam=(struct CThreadParam *)pParam;
	threadParam->bInThread = TRUE;
	
	testDlg = threadParam->testDlg;
	
	threadParam->pcIoBuffer = (unsigned char *)malloc (threadParam->uiLength + 16); 
				
	do 
	{
		do
		{
			Sleep(2000);
			
			hFile = open_file(threadParam->pipe_name);
			
			if(hFile != INVALID_HANDLE_VALUE)
			{
				hDevice = open_dev();
		
				ioBlock.uOffset = 0;
				ioBlock.uLength = 1;
				ioBlock.pbyData = (PUCHAR)&c;
				ioBlock.uIndex = GET_FIRMWARE_VERSION;
				
				//DWORD t=IOCTL_READ_REGISTERS;
				bResult=DevIOCtrl(hDevice,
					IOCTL_READ_REGISTERS,
					(PVOID)&ioBlock,
					sizeof(IO_BLOCK),
					(PVOID)&c,
					1,
					&nBytes);
//				bResult = DeviceIoControl(hDevice,
//					IOCTL_READ_REGISTERS,
//					(PVOID)&ioBlock,
//					sizeof(IO_BLOCK),
//					(PVOID)&c,
//					1,
//					&nBytes,
//					NULL);
				
				if (bResult != TRUE)
				{
					CloseHandle(hFile);
					CloseHandle(hDevice);
					
					threadParam->bInThread = FALSE;
					wsprintf (cc, "固件版本不支持本測試。\r\n請升級仿真板固件。");
					testDlg->MessageBox((LPCSTR)cc, "固件不兼容", MB_ICONSTOP);
					testDlg->EndDialog(0);
					
					return 0;
				}
			}
		} while(hFile == INVALID_HANDLE_VALUE && threadParam->bInThread == TRUE);
		
		threadParam->ulData[0] = D12_DRIVERLOAD;
		threadParam->ulData[1] = c;
		threadParam->bUpdate = TRUE;
		
		if (hFile != INVALID_HANDLE_VALUE) 
		{
			threadParam->threadFile1=hFile;
			while(threadParam->bInThread == TRUE)
			{
				bResult=Read(hFile,
					threadParam->pcIoBuffer,
					threadParam->uiLength,
					&nBytes);
//				bResult = ReadFile(hFile,
//					threadParam->pcIoBuffer,
//					threadParam->uiLength,
//					&nBytes,
//					NULL);
				
				if (bResult == TRUE)
				{
					threadParam->ulData[0] |= D12_KEYSTATUS;
					threadParam->ulData[2] = *(threadParam->pcIoBuffer);
					if(threadParam->ulData[2])
						threadParam->testDlg->m_KeyStatus = _T("已松開按鍵");
					else
						threadParam->testDlg->m_KeyStatus = _T("已按下按鍵");
					threadParam->testDlg->SendMessage(0x405,0,0);
				} 
				else if(nBytes==(DWORD)-1)
				{
					break;
//					DevIOCtrl(hFile,IOCTL_D12_RESET_PIPE,0,0,0,0,&nBytes);
////					DeviceIoControl(hFile,
////						IOCTL_D12_RESET_PIPE,
////						0,
////						0,
////						0,
////						0,
////						&nBytes,
////						NULL);
//					
//					threadParam->ulData[0] |= D12_DRIVERUNLOAD;
//					threadParam->bUpdate = TRUE;
//					
//					break;
				}// else ioctl failed
			};
			
			CloseHandle(hFile);
			CloseHandle(hDevice);
			
		} // if valid hDevice
		
	} while(threadParam->bInThread == TRUE);
	
	free(threadParam->pcIoBuffer);
	threadParam->pcIoBuffer = NULL;
	
	threadParam->bInThread = FALSE;
	
    return 0; 
} 

UINT GenericOut(void * pParam)
{  
    char temp [80],cc[80];
    BOOLEAN bResult = FALSE;
    ULONG nBytes = 0;
	struct CThreadParam * threadParam;
	HANDLE hFile;
	CD12TestDlg* testDlg;
	
	threadParam=(struct CThreadParam *)pParam;
	threadParam->bInThread = FALSE;
	testDlg = threadParam->testDlg;
	
	hFile = open_file(threadParam->pipe_name);
	if(hFile == INVALID_HANDLE_VALUE) {
		free(threadParam->pcIoBuffer);
		threadParam->pcIoBuffer = NULL;
		
		strcpy(temp, "驅動程序打開失敗! 不能寫數據到 ");
		strcat(temp, threadParam->pipe_name);
		strcat(temp, "。");
		testDlg->MessageBox((LPCSTR)temp, "測試錯誤");
		return 0;
	}
	
    if (hFile != INVALID_HANDLE_VALUE) {
		
		threadParam->bInThread = TRUE;
		bResult=Write(hFile,
			threadParam->pcIoBuffer,
			threadParam->uiLength,
			&nBytes);
//		bResult = WriteFile(hFile,
//			threadParam->pcIoBuffer,
//			threadParam->uiLength,
//			&nBytes,
//			NULL);
		
		if (bResult != TRUE) {
			DevIOCtrl(hFile,IOCTL_D12_RESET_PIPE,0,0,0,0,&nBytes);
//			DeviceIoControl(hFile,
//				IOCTL_D12_RESET_PIPE,
//				0,
//				0,
//				0,
//				0,
//				&nBytes,
//				NULL);
			wsprintf (cc, "寫 ");
			strcat( cc, threadParam->pipe_name);
			strcat( cc, " 失敗! 已放棄.");
			testDlg->MessageBox((LPCSTR)cc, "測試錯誤");
		}/* else ioctl failed */
		
		
    }// if valid hDevice
	
	//The thread terminated by itself, delete resources
	
	CloseHandle(hFile);
	
	free(threadParam->pcIoBuffer);
	threadParam->pcIoBuffer = NULL;
	
	threadParam->bInThread = FALSE;
	
    return 0; 
} 


UINT ReadPipe(void * pParam) 
{  
    char temp [80],cc[80];
    BOOLEAN bResult = FALSE;
    ULONG nBytes = 0;
	struct CThreadParam * threadParam;
	CD12TestDlg* testDlg;
	HANDLE hFile, hDevice;
	DWORD time0, time1;
	IO_BLOCK ioBlock;
	IO_REQUEST ioRequest;
	CTIMER tmcount;
	
	threadParam=(struct CThreadParam *)pParam;
	threadParam->bInThread = FALSE;
	testDlg = threadParam->testDlg;
	threadParam->bUpdate = FALSE;
	
	hFile = open_file(threadParam->pipe_name);
	if(hFile == INVALID_HANDLE_VALUE) {
		strcpy(temp, "驅動程序打開失敗! 不能從 ");
		strcat(temp, threadParam->pipe_name);
		strcat(temp, " 中讀出數據。");
		testDlg->MessageBox((LPCSTR)temp, "測試錯誤");
		return 0;
	}
	
	hDevice = open_dev();
	if(hDevice == INVALID_HANDLE_VALUE) {
		CloseHandle(hFile);
		strcpy(temp, "設備句柄打開失敗! 不能讀 ");
		strcat(temp, threadParam->pipe_name);
		strcat(temp, "。");
		testDlg->MessageBox((LPCSTR)temp, "Test Error");
		return 0;
	}
	
    threadParam->pcIoBuffer = (unsigned char *)malloc (threadParam->uiLength + 16); 
	threadParam->ulCount = 0;
	threadParam->total_time = 0;
	threadParam->cur_rate = 0;
	threadParam->max_rate = 0;
	
    if (hFile != INVALID_HANDLE_VALUE) {
		
		threadParam->bInThread = TRUE;
		threadParam->threadFile1=hFile;
		testDlg->m_InStartBtn.EnableWindow(FALSE);
		testDlg->m_InStopBtn.EnableWindow(TRUE);
		testDlg->m_LoopStartBtn.EnableWindow(FALSE);
		testDlg->m_LoopStopBtn.EnableWindow(FALSE);
		threadParam->Last_time=timeGetTime();
		
		do{
			ioRequest.uAddressL = 0;
			ioRequest.bAddressH = 0;
			ioRequest.uSize = threadParam->uiLength;
			ioRequest.bCommand = 0x81;	//start, read
			
			ioBlock.uOffset = 0;
			ioBlock.uLength = sizeof(IO_REQUEST);
			ioBlock.pbyData = (PUCHAR)&ioRequest;
			ioBlock.uIndex = SETUP_DMA_REQUEST;
		
			TRACE("READPIPE:before DeviceIoControl1\n");
			bResult=DevIOCtrl(hDevice,
				IOCTL_WRITE_REGISTERS,
				(PVOID)&ioBlock,
				sizeof(IO_BLOCK),
				NULL,
				0,
				&nBytes);
			TRACE("READPIPE:after DeviceIoControl1\n");
			
			if (bResult != TRUE) {
				threadParam->bInThread = FALSE;
				wsprintf (cc, "在 ");
				strcat( cc, threadParam->pipe_name);
				strcat( cc, " 上請求數據傳送失敗! 已放棄。");
				testDlg->MessageBox((LPCSTR)cc, "測試錯誤");
				break;
			}
			
			tmcount.Start();
			TRACE("READPIPE:before ReadFile1\n");
			bResult=Read(hFile,threadParam->pcIoBuffer,threadParam->uiLength,
				&nBytes);
			TRACE("READPIPE:after ReadFile1\n");
			tmcount.Stop();

			if (bResult != TRUE) {
			} 
			else
			{
				threadParam->ulCount += nBytes;
				threadParam->total_time += tmcount.OutputTime()*1000;
				threadParam->cur_rate = (nBytes*1000*1000)/(tmcount.OutputTime()*1000*1000);
				if(threadParam->cur_rate > threadParam->max_rate)
					threadParam->max_rate = threadParam->cur_rate;
				threadParam->bUpdate = TRUE;
			}
		}while(threadParam->bInThread == TRUE);
		
		
    }// if valid hDevice
	
	//The thread terminated by itself, delete resources
	
	CloseHandle(hFile);
	CloseHandle(hDevice);
	threadParam->threadFile1=NULL;
	threadParam->hThread=NULL;
	
	free(threadParam->pcIoBuffer);
	threadParam->pcIoBuffer = NULL;
	
	testDlg->m_InStartBtn.EnableWindow(TRUE);
	testDlg->m_InStopBtn.EnableWindow(FALSE);

	if (testDlg->m_MainWrite.bInThread==FALSE) {
		testDlg->m_LoopStartBtn.EnableWindow(TRUE);
	}
    return 0; 
} 

UINT WritePipe(void * pParam)
{  
    char temp [80],cc[80];
    BOOLEAN bResult = FALSE;
    ULONG nBytes = 0, ulCount = 0, index, cnt, seq;
	struct CThreadParam * threadParam;
	CD12TestDlg* testDlg;
	unsigned char rNum;
	HANDLE hFile, hDevice;
	DWORD time0, time1;
	IO_BLOCK ioBlock;
	IO_REQUEST ioRequest;
	CTIMER tmcount;
	
	
	threadParam=(struct CThreadParam *)pParam;
	threadParam->bInThread = FALSE;
	testDlg = threadParam->testDlg;
	threadParam->bUpdate = FALSE;
	
	hFile = open_file(threadParam->pipe_name);
	if(hFile == INVALID_HANDLE_VALUE)
	{
		strcpy(temp, "驅動程序打開失敗! 不能寫數據到 ");
		strcat(temp, threadParam->pipe_name);
		strcat(temp, " 。");
		testDlg->MessageBox((LPCSTR)temp, "測試錯誤");
		return 0;
		
	}
	
	hDevice = open_dev();
	if(hDevice == INVALID_HANDLE_VALUE)
	{
		CloseHandle(hFile);
		strcpy(temp, "設備句柄打開失敗! 不能寫入 ");
		strcat(temp, threadParam->pipe_name);
		strcat(temp, "。");
		testDlg->MessageBox((LPCSTR)temp, "Test Error");
		return 0;
	}
	
    threadParam->pcIoBuffer = (unsigned char *)malloc (threadParam->uiLength + 16); 
	threadParam->ulCount = 0;
	threadParam->total_time = 0;
	threadParam->cur_rate = 0;
	threadParam->max_rate = 0;
	
    if (hFile != INVALID_HANDLE_VALUE) 
	{
		int buffLen;
		

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲h在线观看| 欧美一激情一区二区三区| 精品视频一区二区不卡| 国产精品的网站| 波多野结衣亚洲| 国产精品成人一区二区艾草 | 国产精品主播直播| 欧美不卡一二三| 成人免费视频caoporn| 亚洲视频在线观看一区| 日韩欧美在线网站| 精品国产一区二区三区av性色| 国产sm精品调教视频网站| 亚洲综合成人在线| 久久久美女毛片| 91黄色在线观看| 国产精品一区二区男女羞羞无遮挡| 国产一区二区三区久久久| 亚洲h动漫在线| 麻豆91精品91久久久的内涵| 国产三级欧美三级日产三级99| 国产乱子伦视频一区二区三区| 国产黑丝在线一区二区三区| 婷婷中文字幕综合| 夜夜嗨av一区二区三区网页| 久久久久久久综合| 亚洲欧美视频一区| 国产精品国产三级国产aⅴ无密码| 亚洲美女精品一区| 毛片av一区二区三区| 国产成人精品免费网站| 91福利视频在线| 久久久久久久久97黄色工厂| 成人欧美一区二区三区| 国产农村妇女精品| 亚洲国产一二三| 亚洲图片欧美视频| 国产99精品在线观看| 欧美三级在线视频| 中文字幕永久在线不卡| 免费在线观看日韩欧美| 午夜免费久久看| 国产成a人亚洲| 在线播放日韩导航| 欧美日韩精品欧美日韩精品一综合| 色呦呦日韩精品| 日本伦理一区二区| 欧美经典一区二区三区| 精品少妇一区二区三区在线视频| 亚洲欧美日韩国产一区二区三区 | 蜜桃av一区二区在线观看 | 日韩av网站免费在线| 亚洲午夜久久久久久久久电影网| 狠狠久久亚洲欧美| 国产一区在线观看麻豆| 欧美精品九九99久久| 亚洲视频一二三区| 久久国产成人午夜av影院| 国产成人久久精品77777最新版本| 在线亚洲一区二区| 这里只有精品电影| 欧美白人最猛性xxxxx69交| 在线一区二区三区四区五区| 欧美亚日韩国产aⅴ精品中极品| 91麻豆高清视频| 91丨porny丨首页| 国产欧美在线观看一区| 老司机午夜精品| 欧美日韩国产三级| 亚洲午夜私人影院| 一本大道av一区二区在线播放| 亚洲国产精品成人综合色在线婷婷| 国产真实乱偷精品视频免| 日韩视频中午一区| 免费成人在线视频观看| 欧美一级二级三级乱码| 免费高清视频精品| 精品少妇一区二区三区视频免付费| 美女国产一区二区| 精品久久人人做人人爽| 国产综合色视频| 久久一夜天堂av一区二区三区| 亚洲裸体xxx| 蜜桃一区二区三区四区| 制服.丝袜.亚洲.另类.中文| 久久精品理论片| 久久青草欧美一区二区三区| 国产精品 欧美精品| 日本一区二区三区视频视频| 成人免费av网站| 亚洲人成小说网站色在线| 在线观看欧美日本| 蜜臀a∨国产成人精品| 欧美成人一区二区三区片免费 | 久久综合999| 国产91精品入口| 一区二区三区在线视频观看| 欧美日韩一区二区三区在线看| 婷婷综合另类小说色区| 久久久噜噜噜久久人人看| 不卡高清视频专区| 国产视频一区二区三区在线观看| 成人爱爱电影网址| 午夜精品福利视频网站| 久久人人爽人人爽| 91色综合久久久久婷婷| 日产国产欧美视频一区精品| 久久综合色婷婷| 91免费精品国自产拍在线不卡| 亚洲国产日产av| 日韩精品一区二区三区swag| 日韩激情中文字幕| 欧美日韩综合色| 激情欧美日韩一区二区| 一区二区三区四区不卡在线| 欧美成人精精品一区二区频| 色一情一乱一乱一91av| 免费的成人av| 亚洲卡通欧美制服中文| 久久影院午夜片一区| 在线看国产日韩| 成人精品在线视频观看| 日本不卡中文字幕| 亚洲精品欧美二区三区中文字幕| 日韩免费观看高清完整版| 色就色 综合激情| 成人影视亚洲图片在线| 日本欧洲一区二区| 亚洲欧美日韩国产综合在线| 久久久久久久性| 日韩精品专区在线影院观看| 91老司机福利 在线| 国产麻豆精品在线| 久久精品久久综合| 婷婷综合久久一区二区三区| 亚洲精品国产精品乱码不99| 国产欧美日韩不卡免费| 久久免费视频一区| 欧美变态tickle挠乳网站| 91精品久久久久久久99蜜桃| 91麻豆国产香蕉久久精品| 国产伦精品一区二区三区视频青涩| 亚洲图片欧美色图| 亚洲一二三区视频在线观看| 国产精品水嫩水嫩| 欧美偷拍一区二区| 91国产免费观看| www.亚洲在线| 色综合天天做天天爱| 亚洲3atv精品一区二区三区| 亚洲欧洲另类国产综合| 国产精品久久一级| 国产精品理论片在线观看| 国产精品色哟哟| 综合av第一页| 亚洲三级在线观看| 亚洲免费高清视频在线| 亚洲日本乱码在线观看| 一区二区三区久久| 伊人开心综合网| 亚洲激情综合网| 天天色 色综合| 美女视频网站黄色亚洲| 黄色日韩三级电影| 国产精品69毛片高清亚洲| 国产精品一区二区在线观看不卡 | 亚洲福中文字幕伊人影院| 性欧美大战久久久久久久久| 日韩中文字幕不卡| 精品亚洲欧美一区| 亚洲一区在线播放| 日韩av网站免费在线| 久久精品国产99国产| 国产一区二区三区日韩| 成人h精品动漫一区二区三区| av电影在线观看完整版一区二区| 色香色香欲天天天影视综合网 | 久久精品国产99久久6| 国产精品18久久久久| 99re免费视频精品全部| 国产成人精品www牛牛影视| 粉嫩aⅴ一区二区三区四区五区| 色综合久久久久久久久| 欧美肥妇bbw| 中文字幕欧美区| 一区二区三区毛片| 国内精品视频一区二区三区八戒| 成人一区二区三区视频| 欧美卡1卡2卡| 国产情人综合久久777777| 一区二区三区日韩精品| 国产自产v一区二区三区c| 91福利精品第一导航| 久久夜色精品国产噜噜av| 一区二区在线免费| 国产a视频精品免费观看| 欧美剧情片在线观看| 亚洲欧美一区二区三区极速播放 | 视频一区国产视频| 成人黄色网址在线观看|