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

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

?? camera.cpp

?? share-2440 wince5.0 of LCD drivers 源代碼
?? CPP
?? 第 1 頁(yè) / 共 3 頁(yè)
字號(hào):

#include <windows.h>

#include <nkintr.h>
#include <oalintr.h>
//#include <p2.h> 
#include <pm.h>
#include "pmplatform.h"

#include "s2440.h"
#include "camif.h"
#include "camera.h"

#define MSG_EN_1	0
#define MSG_EN_2	0
//#define RETAILMSG(a,b)	RETAILMSG(1,b)	

#define DOTNET_DRIVER 1 // 0:PPC, 1:CE.NET

#define CAPTURE_TIME		30
#define DISPLAY_SCHEDULE	0

#define U8	unsigned char
#define U16	unsigned short
#define U32	unsigned int

#define	PORT_A 1
#define	PORT_B 0

// Added 25 May 2004 for debug
#ifdef DEBUG
#define ZONE_INIT	1
#define ZONE_THREAD	1
#endif

#define	YCbCrtoR(Y,Cb,Cr)	(1000*Y + 1540*(Cr-128))/1000
#define	YCbCrtoG(Y,Cb,Cr)	(1000*Y - 459*(Cb-128) - 183*(Cr-128))/1000
#define	YCbCrtoB(Y,Cb,Cr)	(1000*Y + 1856*(Cb-128))/1000

volatile IOPreg 	*s2440IOP = (IOPreg *)IOP_BASE;
volatile CAMreg 	*s2440CAM = (CAMreg *)CAM_BASE;
volatile INTreg 	*s2440INT = (INTreg *)INT_BASE;
volatile CLKPWRreg	*s2440PWR = (CLKPWRreg *)CLKPWR_BASE;
volatile IICreg		*s2440IIC = (IICreg *)IIC_BASE;;

unsigned int DisplayTime = INFINITE;
//unsigned char DisplayEnable=0;
unsigned char buffer_num=0xff;		// ping pong buffer

unsigned char image_size = 2;				// 1: QCIF, 2:CIF (default)

//#define DRIVER_PREVIEW_ENABLE		2	// 0: onTimeTek, 1: Preview, 2:Samsung Camcorder
unsigned char DRIVER_PREVIEW_ENABLE = 2;	// 0: onTimeTek, 1: Preview, 2:Samsung Camcorder	

unsigned int frame_count=0;			// for MPEG4
DWORD Tick_GET_FRAME_CUR;
DWORD Tick_GET_FRAME_PREV;
DWORD Tick_COPY_FRAME;

HANDLE CameraThread;
HANDLE CameraEvent;
static BOOL mInitialized = FALSE;

unsigned char codec_flag=0;
unsigned char rgb_flag=0;
unsigned int y_address,cb_address,cr_address;
unsigned int rgb_address;
extern void Camera_Initialize();
extern volatile IOPreg *s2440IOP;
extern volatile IICreg *s2440IIC;

extern void ReadCameraProductID(void);

void Virtual_Alloc();						// Virtual allocation
void Camera_Clock(unsigned char divide);	// set default value
void Camif_Capture(int cap_a, int cap_b);	// A port, B port
void Display_Cam_Image(U32 pos_x, U32 pos_y, U32 size_x, U32 size_y, U8 port);
void Copy_Cam_Image(U8 * pBufOut, U32 size_x, U32 size_y, U8 port);
void Samsung_camcoder(U8 *pBufOut);
void Samsung_camcoder_pr(U8 *pBufOut);
void Buffer_codec_info_update();
void Buffer_preview_info_update();
BOOL Cam_Init();
BOOL CamClockOn(BOOL bOnOff);
//void CamCaptureStart(U32 mode);

void CamInit(U32 CoDstWidth, U32 CoDstHeight, U32 PrDstWidth, U32 PrDstHeight, 
			U32 WinHorOffset, U32 WinVerOffset,  U32 CoFrameBuffer, U32 PrFrameBuffer);

DWORD CameraCaptureThread(void);
BOOL InitInterruptThread();

CEDEVICE_POWER_STATE m_Dx;

#ifdef DEBUG
DBGPARAM dpCurSettings = {
    TEXT("CAMERA"), {
        TEXT("0"),TEXT("1"),TEXT("2"),TEXT("3"),
        TEXT("4"),TEXT("5"),TEXT("6"),TEXT("7"),
        TEXT("8"),TEXT("9"),TEXT("10"),TEXT("11"),
        TEXT("12"),TEXT("Function"),TEXT("Init"),TEXT("Error")},
    0x8000  // Errors only, by default
}; 
#endif


static void Delay(USHORT count)
{
	volatile int i, j = 0;
	volatile static int loop = S2440FCLK/100000;
	
	for(;count > 0;count--)
		for(i=0;i < loop; i++) { j++; }
}


/********************************************************
 CalculateBurstSize - Calculate the busrt lengths
 
 Description:	
 - dstHSize: the number of the byte of H Size.
 
*/
void CalculateBurstSize(unsigned int hSize,unsigned int *mainBurstSize,unsigned int *remainedBurstSize)
{
	unsigned int tmp;	
	tmp=(hSize/4)%16;
	switch(tmp) {
		case 0:
			*mainBurstSize=16;
			*remainedBurstSize=16;
			break;
		case 4:
			*mainBurstSize=16;
			*remainedBurstSize=4;
			break;
		case 8:
			*mainBurstSize=16;
			*remainedBurstSize=8;
			break;
		default: 
			tmp=(hSize/4)%8;
			switch(tmp) {
				case 0:
					*mainBurstSize=8;
					*remainedBurstSize=8;
					break;
				case 4:
					*mainBurstSize=8;
					*remainedBurstSize=4;
				default:
					*mainBurstSize=4;
					tmp=(hSize/4)%4;
					*remainedBurstSize= (tmp) ? tmp: 4;
					break;
			}
			break;
	}		    	    		
}

/********************************************************
 CalculatePrescalerRatioShift - none
 
 Description:	
 - none
 
*/
void CalculatePrescalerRatioShift(unsigned int SrcSize, unsigned int DstSize, unsigned int *ratio,unsigned int *shift)
{
	if(SrcSize>=64*DstSize) {
//		Uart_Printf("ERROR: out of the prescaler range: SrcSize/DstSize = %d(< 64)\r\n",SrcSize/DstSize);
		while(1);
	}
	else if(SrcSize>=32*DstSize) {
		*ratio=32;
		*shift=5;
	}
	else if(SrcSize>=16*DstSize) {
		*ratio=16;
		*shift=4;
	}
	else if(SrcSize>=8*DstSize) {
		*ratio=8;
		*shift=3;
	}
	else if(SrcSize>=4*DstSize) {
		*ratio=4;
		*shift=2;
	}
	else if(SrcSize>=2*DstSize) {
		*ratio=2;
		*shift=1;
	}
	else {
		*ratio=1;
		*shift=0;
	}    	
}

void Camera_Clock(unsigned char divide)
{
	unsigned int camclk;
	
	// Set camera clock for camera processor
	s2440PWR->rCAMDIVN = (s2440PWR->rCAMDIVN & ~(0x1f)) | (1<<4) | (divide & 0xf); // CAMCLK is divided..
	camclk = 48000000/(((s2440PWR->rCAMDIVN&0xf) + 1)*2);

	RETAILMSG(1,(TEXT("CAM clock:%d\r\n"),camclk));
}

/*
void CamCaptureStart(unsigned int mode)
{ 
	if(mode&CAM_CODEC_SCALER_CAPTURE_ENABLE_BIT) {
		s2440CAM->rCICOSCCTRL|=CAM_CODEC_SACLER_START_BIT;
	}
	
	if(mode&CAM_PVIEW_SCALER_CAPTURE_ENABLE_BIT) {
		s2440CAM->rCIPRSCCTRL|=CAM_PVIEW_SACLER_START_BIT;
	}
    
	s2440CAM->rCIIMGCPT|=(CAM_CAMIF_GLOBAL_CAPTURE_ENABLE_BIT|mode);
}
*/

void Camif_Capture(int cap_a, int cap_b)
{
	//RETAILMSG(1,(_T("Camif_Capture(%d, %d)\r\n"), cap_a, cap_b));
	// S3C2440A

	s2440CAM->rCIIMGCPT &= ~(CAM_CAMIF_GLOBAL_CAPTURE_ENABLE_BIT);

	if(cap_b == CAPTURE_ON) 
	{
		//Codec capture start
		s2440CAM->rCICOSCCTRL |=(CAM_CODEC_SACLER_START_BIT);
		s2440CAM->rCIIMGCPT |=(CAM_CAMIF_GLOBAL_CAPTURE_ENABLE_BIT)|(CAM_CODEC_SCALER_CAPTURE_ENABLE_BIT);
	} 
	else if (cap_b == CAPTURE_OFF)
	{
		s2440CAM->rCICOSCCTRL &= ~(CAM_CODEC_SACLER_START_BIT);
		s2440CAM->rCIIMGCPT &= ~(CAM_CODEC_SCALER_CAPTURE_ENABLE_BIT);
	}

	if(cap_a == CAPTURE_ON) 
	{  
		// Preview capture Start
		s2440CAM->rCIPRSCCTRL |=(CAM_PVIEW_SACLER_START_BIT);
		s2440CAM->rCIIMGCPT |=(CAM_CAMIF_GLOBAL_CAPTURE_ENABLE_BIT)|(CAM_PVIEW_SCALER_CAPTURE_ENABLE_BIT);
	}
	else if (cap_a == CAPTURE_OFF)
	{
		s2440CAM->rCIPRSCCTRL &= ~(CAM_PVIEW_SACLER_START_BIT);
		s2440CAM->rCIIMGCPT &= ~(CAM_PVIEW_SCALER_CAPTURE_ENABLE_BIT);
	}
	
	if ((cap_a == CAPTURE_ON) || (cap_b == CAPTURE_ON))
	{
		s2440CAM->rCIIMGCPT |= (CAM_CAMIF_GLOBAL_CAPTURE_ENABLE_BIT);
	}
	
}

DWORD CameraCaptureThread(void)
{
	unsigned char tmp=0;
	static unsigned int time,old_time;
	static unsigned int cam_intr;
	
	while(1)
	{
		WaitForSingleObject(CameraEvent, DisplayTime);
		
		//RETAILMSG(MSG_EN_1,(_T("CameraCaptureThread(%d)++\r\n"), frame_count));

		//RETAILMSG(1,(_T("CameraCaptureThread(%d)++\r\n"), frame_count));

#if 0
		if (frame_count <= 2) {
			frame_count++;
			// Enable camera interrupt
			s2440INT->rINTSUBMSK &= ~(BIT_SUB_CAM_P|BIT_SUB_CAM_C);
			s2440INT->rINTMSK &= ~BIT_CAM;
			
			continue;
		}
#endif
		
		//if( DisplayEnable )
		{

			frame_count++;

			if (s2440INT->rINTSUBMSK & BIT_SUB_CAM_C)
			{
				cam_intr = BIT_SUB_CAM_C;
				//RETAILMSG(1,(_T("CAM_C, ts %d\r\n"), GetTickCount()));
			}
			else if (s2440INT->rINTSUBMSK & BIT_SUB_CAM_P)
			{
				cam_intr = BIT_SUB_CAM_P;
				//RETAILMSG(1,(_T("CAM_P, ts %d\r\n"), GetTickCount()));
			}
			
			
			// EINT20 to measure time
//			s2440IOP->rGPGDAT |= (1<<12);
//			time = GetTickCount();
//			RETAILMSG(1,(TEXT("+time:%d\r\n"),(time - old_time)));

			// delay for capture
			//Sleep(CAPTURE_TIME);			// polling mode

                     //liudiping
			// display the image	
			//if ((DRIVER_PREVIEW_ENABLE == 1) & (cam_intr == BIT_SUB_CAM_P))
				{
				//RETAILMSG(1,(TEXT("-------------------\r\n")));
				Display_Cam_Image(64, 64, QCIF_XSIZE, QCIF_YSIZE, PORT_A);
				//Display_Cam_Image(0,0, QCIF_XSIZE, QCIF_YSIZE, PORT_A);
				}

			//else if (DRIVER_PREVIEW_ENABLE == 2)	
			if (cam_intr == BIT_SUB_CAM_C)
			{
				Buffer_codec_info_update();
			}

			if (cam_intr == BIT_SUB_CAM_P)
			{
				Buffer_preview_info_update();
			}
				
			// Enable camera interrupt
			s2440INT->rINTSUBMSK &= ~(BIT_SUB_CAM_P|BIT_SUB_CAM_C);
			s2440INT->rINTMSK &= ~BIT_CAM;

/*
			if (DRIVER_PREVIEW_ENABLE == 1)
				Camif_Capture(CAPTURE_ON, CAPTURE_OFF);
			else if (DRIVER_PREVIEW_ENABLE == 2)	
				Camif_Capture(CAPTURE_OFF, CAPTURE_ON);
*/
			
			// EINT20 to measure time			
//			s2440IOP->rGPGDAT &= ~(1<<12);
//			old_time = GetTickCount();
//			RETAILMSG(1,(TEXT("-time:%d\r\n"),(old_time-time)));
			
		}
	}
}



void Virtual_Alloc()
{

    // GPIO Virtual alloc
	s2440IOP = (volatile IOPreg *) VirtualAlloc(0,sizeof(IOPreg),MEM_RESERVE, PAGE_NOACCESS);
	if(s2440IOP == NULL) {
		RETAILMSG(1,(TEXT("For s2440IOP: VirtualAlloc failed!\r\n")));
	}
	else {
		if(!VirtualCopy((PVOID)s2440IOP,(PVOID)(IOP_BASE),sizeof(IOPreg),PAGE_READWRITE | PAGE_NOCACHE )) {
			RETAILMSG(1,(TEXT("For s2440IOP: VirtualCopy failed!\r\n")));
		}
	}
    // IIC Virtual alloc
	s2440IIC = (volatile IICreg *) VirtualAlloc(0,sizeof(IICreg),MEM_RESERVE, PAGE_NOACCESS);
	if(s2440IIC == NULL) {
		RETAILMSG(1,(TEXT("For s2440IIC: VirtualAlloc failed!\r\n")));
	}
	else {
		if(!VirtualCopy((PVOID)s2440IIC,(PVOID)(IIC_BASE),sizeof(IICreg),PAGE_READWRITE | PAGE_NOCACHE )) {
			RETAILMSG(1,(TEXT("For s2440IIC: VirtualCopy failed!\r\n")));
		}
	}
	
    // Camera Virtual alloc
	s2440CAM = (volatile CAMreg *) VirtualAlloc(0,sizeof(CAMreg),MEM_RESERVE, PAGE_NOACCESS);
	if(s2440CAM == NULL) {
		RETAILMSG(1,(TEXT("For s2440CAM: VirtualAlloc failed!\r\n")));
	}
	else {
		if(!VirtualCopy((PVOID)s2440CAM,(PVOID)(CAM_BASE),sizeof(CAMreg),PAGE_READWRITE | PAGE_NOCACHE )) {
			RETAILMSG(1,(TEXT("For s2440CAM: VirtualCopy failed!\r\n")));
		}
	}

	// Interrupt Virtual alloc
	s2440INT = (volatile INTreg *) VirtualAlloc(0,sizeof(INTreg),MEM_RESERVE, PAGE_NOACCESS);
	if(s2440INT == NULL) {
		RETAILMSG(1,(TEXT("For s2440INT: VirtualAlloc failed!\r\n")));
	}
	else {
		if(!VirtualCopy((PVOID)s2440INT,(PVOID)(INT_BASE),sizeof(INTreg),PAGE_READWRITE | PAGE_NOCACHE )) {
			RETAILMSG(1,(TEXT("For s2440INT: VirtualCopy failed!\r\n")));
		}
	}
	// PWM clock Virtual alloc
	s2440PWR = (volatile CLKPWRreg *) VirtualAlloc(0,sizeof(CLKPWRreg),MEM_RESERVE, PAGE_NOACCESS);
	if(s2440PWR == NULL) {
		RETAILMSG(1,(TEXT("For s2440PWR: VirtualAlloc failed!\r\n")));
	}
	else {
		if(!VirtualCopy((PVOID)s2440PWR,(PVOID)(CLKPWR_BASE),sizeof(CLKPWRreg),PAGE_READWRITE | PAGE_NOCACHE )) {
			RETAILMSG(1,(TEXT("For s2440PWR: VirtualCopy failed!\r\n")));
		}
	}
}

void Display_Cam_Image(U32 pos_x, U32 pos_y, U32 size_x, U32 size_y, U8 port)
{
	U8 *buffer_rgb;
	U32 y;
	int temp;
	
	//unsigned short *ptr = (unsigned short *)(FRAMEBUF_BASE+0x5dc0);
	
	static unsigned short transfer_data[QCIF_XSIZE*QCIF_YSIZE];
	static unsigned int time,old_time;
	
	//RETAILMSG(1,(_T("Display_Cam_Image()\r\n")));
	
//	if (port)
	{
		temp = (s2440CAM->rCIPRSTATUS>>26)&3;
		temp = (temp + 2) % 4;
		
		switch (temp)
		{
		case 0:
			buffer_rgb = (U8 *)s2440CAM->rCIPRCLRSA1;
			break;
		case 1:
			buffer_rgb = (U8 *)s2440CAM->rCIPRCLRSA2;
			break;
		case 2:
			buffer_rgb = (U8 *)s2440CAM->rCIPRCLRSA3;
			break;
		case 3:
			buffer_rgb = (U8 *)s2440CAM->rCIPRCLRSA4;
			break;
		default :
			buffer_rgb = (U8 *)s2440CAM->rCIPRCLRSA1;
			break;
		}
	}
	RETAILMSG(MSG_EN_1,(_T("preview buf index = %d\r\n"), temp));

#if (DOTNET_DRIVER)
	SetKMode(TRUE);
#endif
	
	buffer_rgb += VIRTUAL_OFFSET;

//	time = GetTickCount();
//	RETAILMSG(1,(TEXT("+:%d\r\n"),(time - old_time)));


#if 1
	for (y=0;y<(size_y-2);y++) // YCbCr 4:2:0 format
	{
		//memcpy((void *)(FRAMEBUF_BASE+0x5e00+y*240*2),(void *)buffer_rgb,(QCIF_XSIZE)*2);
		memcpy((void *)(FRAMEBUF_BASE+ (240*pos_y + pos_x) + y*240*2),(void *)buffer_rgb,(QCIF_XSIZE)*2);
		//memcpy((void *)(FRAMEBUF_BASE+ (640*pos_y + pos_x) + y*640*2),(void *)buffer_rgb,(QCIF_XSIZE)*2);
		buffer_rgb += (QCIF_XSIZE*2);
	}
#endif

#if (DOTNET_DRIVER)
	SetKMode(FALSE);
#endif

//	old_time = GetTickCount();
//	RETAILMSG(1,(TEXT("-:%d\r\n"),(old_time - time)));

}



BOOL WINAPI  
DllEntry(HANDLE	hinstDLL, 
			DWORD dwReason, 
			LPVOID /* lpvReserved */)
{
	switch(dwReason)
	{
	case DLL_PROCESS_ATTACH:
		DEBUGREGISTER((HINSTANCE)hinstDLL);
		DEBUGMSG(ZONE_INIT,(TEXT("CAMERA: DLL_PROCESS_ATTACH\r\n")));
		//liudiping
		//RETAILMSG(1,(TEXT("CAMERA: DLL_PROCESS_ATTACH\r\n")));
		return TRUE;
	case DLL_THREAD_ATTACH:
		DEBUGMSG(ZONE_THREAD,(TEXT("CAMERA: DLL_THREAD_ATTACH\r\n")));
		//RETAILMSG(1,(TEXT("CAMERA: DLL_THREAD_ATTACH\r\n")));
		break;
	case DLL_THREAD_DETACH:
		DEBUGMSG(ZONE_THREAD,(TEXT("CAMERA: DLL_THREAD_DETACH\r\n")));
		break;
	case DLL_PROCESS_DETACH:
		DEBUGMSG(ZONE_INIT,(TEXT("CAMERA: DLL_PROCESS_DETACH\r\n")));
		break;
#ifdef UNDER_CE
	case DLL_PROCESS_EXITING:
		DEBUGMSG(ZONE_INIT,(TEXT("CAMERA: DLL_PROCESS_EXITING\r\n")));
		break;
	case DLL_SYSTEM_STARTED:
		DEBUGMSG(ZONE_INIT,(TEXT("CAMERA: DLL_SYSTEM_STARTED\r\n")));
		break;
#endif

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
eeuss鲁片一区二区三区在线观看 eeuss鲁片一区二区三区在线看 | 制服丝袜亚洲色图| 东方欧美亚洲色图在线| 国产精品影视在线| 国产suv精品一区二区883| 国产东北露脸精品视频| 久久99精品久久久久久久久久久久 | 日本亚洲电影天堂| 亚洲成国产人片在线观看| 亚洲一区二区精品视频| 中文字幕视频一区二区三区久| 久久久久国产精品麻豆| 国产欧美一区二区精品秋霞影院| 久久精品视频在线看| 国产日产精品1区| 久久久久国产精品人| 国产精品欧美一级免费| 1区2区3区国产精品| 亚洲人午夜精品天堂一二香蕉| 亚洲精品免费视频| 亚洲第四色夜色| 婷婷亚洲久悠悠色悠在线播放| 蜜桃视频免费观看一区| 国产激情91久久精品导航| 99精品国产热久久91蜜凸| 91成人免费网站| 在线综合视频播放| 精品国产3级a| 中文字幕日本不卡| 午夜欧美视频在线观看 | 2023国产精华国产精品| 国产精品伦理在线| 视频一区二区三区入口| 国产精品1区2区3区| 色婷婷综合久色| 91精品国产高清一区二区三区| 久久影音资源网| 夜夜精品浪潮av一区二区三区| 免费不卡在线视频| 91免费版在线看| 日韩欧美成人午夜| 亚洲激情一二三区| 国产精品一区二区在线播放| 欧美亚洲国产一区二区三区va| 精品国内二区三区| 亚洲电影视频在线| 不卡在线观看av| 日韩精品一区二区三区中文不卡 | 成人激情免费电影网址| 欧美日韩高清一区二区| 国产精品无人区| 精品一区免费av| 欧美艳星brazzers| 亚洲图片另类小说| 国产精品123| 久久先锋资源网| 日本欧美一区二区三区乱码| 91久久香蕉国产日韩欧美9色| 久久久不卡网国产精品二区| 日本午夜精品视频在线观看| 欧美亚洲尤物久久| 中文字幕一区二区在线播放| 国产精品一区二区无线| 精品国产网站在线观看| 奇米888四色在线精品| 欧美日本在线播放| 一级做a爱片久久| 91美女精品福利| 亚洲图片另类小说| 91网站视频在线观看| 国产精品视频一二| 成av人片一区二区| 亚洲品质自拍视频| av一区二区不卡| 综合久久久久久| 91最新地址在线播放| 18欧美乱大交hd1984| 99久久99久久精品免费观看| 中文字幕亚洲成人| 色综合久久久网| 亚洲欧美激情一区二区| 色综合久久久久| 一区二区三区丝袜| 欧美午夜精品久久久久久孕妇| 一区二区三区在线视频免费| 在线免费精品视频| 亚洲亚洲精品在线观看| 欧美人妖巨大在线| 奇米影视一区二区三区| 精品久久久久久久人人人人传媒 | 老司机午夜精品| 久久精品一区二区| 成人精品视频一区二区三区| 国产精品久久久久7777按摩 | 亚洲一区欧美一区| 8x8x8国产精品| 国产一区中文字幕| 亚洲欧美视频一区| 欧美日韩在线精品一区二区三区激情| 亚洲第一搞黄网站| 国产亚洲一区二区三区在线观看 | 久久蜜臀中文字幕| 99久久免费精品| 日精品一区二区| 久久久美女毛片| 欧美在线一区二区三区| 韩日欧美一区二区三区| 中文字幕日韩欧美一区二区三区| 在线视频一区二区免费| 久久国产乱子精品免费女| 亚洲免费av高清| 精品久久久久久综合日本欧美| 不卡的av电影| 日本亚洲最大的色成网站www| 欧美韩国日本一区| 欧美人妖巨大在线| 波多野结衣精品在线| 日韩成人免费电影| 国产精品嫩草久久久久| 欧美疯狂做受xxxx富婆| 高清日韩电视剧大全免费| 午夜精品久久一牛影视| 国产精品婷婷午夜在线观看| 欧美一区二区日韩一区二区| 成人高清在线视频| 久久99久久99| 天天做天天摸天天爽国产一区| 亚洲一二三级电影| 国产精品的网站| 精品国产一区二区三区av性色| 在线视频综合导航| 国产精品一区二区久激情瑜伽| 婷婷国产在线综合| 一区二区成人在线| 亚洲色图制服诱惑| 国产精品嫩草影院com| 久久综合成人精品亚洲另类欧美| 欧美日韩免费观看一区三区| av色综合久久天堂av综合| 国产在线不卡一区| 免费av成人在线| 亚洲成人动漫av| 亚洲精品美腿丝袜| 《视频一区视频二区| 国产日本亚洲高清| 国产午夜一区二区三区| 日韩精品专区在线影院重磅| 精品视频色一区| 欧美日韩在线综合| 精品视频免费在线| 欧美三级中文字幕在线观看| 色婷婷av一区二区| 欧美日韩中文字幕一区二区| 91美女蜜桃在线| 一本色道综合亚洲| 在线视频欧美区| 欧美三片在线视频观看| 欧美日韩国产一级二级| 在线播放视频一区| 制服.丝袜.亚洲.中文.综合| 69堂成人精品免费视频| 欧美一区二区三区性视频| 欧美一区二区三区在线观看| 日韩免费视频一区二区| 精品国产sm最大网站| 国产视频一区二区三区在线观看| 国产欧美精品区一区二区三区| 国产精品天干天干在观线| 亚洲欧美综合色| 亚洲综合色区另类av| 亚洲第一福利视频在线| 秋霞国产午夜精品免费视频| 激情五月婷婷综合网| 国产成人午夜精品影院观看视频 | 日本中文一区二区三区| 裸体歌舞表演一区二区| 高清shemale亚洲人妖| 色婷婷精品大视频在线蜜桃视频 | 九九九久久久精品| 盗摄精品av一区二区三区| 91视频精品在这里| 日韩一区二区视频在线观看| 2020国产精品自拍| 国产精品久久久久久亚洲毛片| 一区二区三区在线影院| 老司机一区二区| 99riav一区二区三区| 91精品欧美福利在线观看| 26uuu欧美| 一区二区在线观看免费| 久久99国内精品| 一道本成人在线| 精品人在线二区三区| 亚洲欧洲日韩女同| 美腿丝袜亚洲一区| 91同城在线观看| 精品1区2区在线观看| 一区二区三区在线观看欧美| 精品一区在线看| 欧美日本一区二区三区|