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

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

?? ata_test.cpp

?? 三星公司S3c2443的測試程序源碼
?? CPP
字號:
#include <stdio.h>
#include "2443addr.h"
#include "console.h"
#include "system.h"
#include "etc.h"
#include "ata.h"
#include "cf.h"


#define CODEC_MEM_ST 0x31000000

static ATA  oAta;
//static INTC oIntc;

static bool bIsDone;
static bool bIsXferDone;


void __irq Isr_Ata(void) 
{
	U32 nthBit;
	bool status;

printf("[I]");		
	if (!oAta.FindInterruptRequest(nthBit)) {
		ClearPending(BIT_CFCON);
		//Assert(0);
	}

	oAta.Clear_Pending(nthBit);

	if (nthBit == 0 || nthBit == 1)
	{
		oAta.IsDmaDone();
		bIsXferDone = true;
//		Dbg("x");
	}
	else if (nthBit == 2)
	{
		bIsDone = true;
//		Dbg("b");
	}

	ClearPending(BIT_CFCON);	

	if (nthBit == 3)
	{
//		Dbg("t");
		oAta.IsTBufFullContinue(status);
		if (status) 
			oAta.SetTransferCommand(ATA_CMD_CONTINUE);
	}
	else if (nthBit == 4)
	{
//		Dbg("s");
		oAta.IsSBufEmptyContinue(status);
		if (status) 
			oAta.SetTransferCommand(ATA_CMD_CONTINUE);
	}

}


void TestReset(void)
{
	oAta.ResetAll();
}


void TestChangeModeToAta(void)
{
	oAta.ChangeMode();
}


// No need to select mode in OpenMedia()
void TestBasicWriteRead(void)
{
	U32 uWriteBuf, uReadBuf;
	U32 deviceLBA;
	U32 uSector;
	U32 uDeviceMaxSectors;

	uWriteBuf = CODEC_MEM_ST;
	uReadBuf = CODEC_MEM_ST + 0x400000;
	
	oAta.OpenMedia();

	oAta.GetMaxSectors(uDeviceMaxSectors);

	printf("\nInput device sector address[max: 0x%x]\n",uDeviceMaxSectors);
	deviceLBA = (U32)GetIntNum();

	printf("Input sector count[max: 0x%x]\n",uDeviceMaxSectors-deviceLBA);
	uSector = (U32)GetIntNum();

	for (U32 i=0; i<uSector*512; i++)
	{
		Outp8(uWriteBuf+i, (i+0)%256);
		Outp8(uReadBuf+i, 0);
	}

	printf("Press Enter \n");	
	getchar();
	
	oAta.WriteBlocks(deviceLBA, uSector, uWriteBuf);
	oAta.ReadBlocks( deviceLBA, uSector, uReadBuf);

	if (Compare32(uWriteBuf, uReadBuf, uSector*128) == false)
	{
		printf("Error detected\n");
		Dump32(uReadBuf, uSector*128);
	}
	else
	{
		printf("Write/Read operation is OK\n");
	}
	oAta.CloseMedia();
}


void TestPioCpuMode(void)
{
	U32 uWriteBuf, uReadBuf;
	U32 deviceLBA;
	U32 uSector;
	U32 uDeviceMaxSectors;

	uWriteBuf = CODEC_MEM_ST;
	uReadBuf = CODEC_MEM_ST + 0x400000;
	
	oAta.OpenMedia(PIO_CPU);

	oAta.GetMaxSectors(uDeviceMaxSectors);

	printf("\nInput device sector address[max: 0x%x]\n",uDeviceMaxSectors);
	deviceLBA = (U32)GetIntNum();

	printf("Input sector count[max: 0x%x]\n",uDeviceMaxSectors-deviceLBA);
	uSector = (U32)GetIntNum();

	for (U32 i=0; i<uSector*512; i++)
	{
		Outp8(uWriteBuf+i, (i+1)%256);
		Outp8(uReadBuf+i, 0);
	}
	
	oAta.WriteBlocks(deviceLBA, uSector, uWriteBuf);
	oAta.ReadBlocks( deviceLBA, uSector, uReadBuf);

	if (Compare32(uWriteBuf, uReadBuf, uSector*128) == false)
	{
		printf("Error detected\n");
		Dump32(uReadBuf, uSector*128);
	}
	else
	{
		printf("Write/Read in PIO_CPU mode is OK\n");
	}
	
	oAta.CloseMedia();
}


void TestPioCpuModeRead(void)
{
	U32 uReadBuf;
	U32 deviceLBA;
	U32 uSector;
	U32 uDeviceMaxSectors;

	uReadBuf = CODEC_MEM_ST + 0x400000;
	
	oAta.OpenMedia(PIO_CPU);
	oAta.GetMaxSectors(uDeviceMaxSectors);

	printf("\nInput device sector address[max: 0x%x]\n",uDeviceMaxSectors);
	deviceLBA = (U32)GetIntNum();

	printf("Input sector count[max: 0x%x]\n",uDeviceMaxSectors-deviceLBA);
	uSector = (U32)GetIntNum();

	for (U32 i=0; i<uSector*512; i=i+4)
	{
		Outp32(uReadBuf+i, 0);
	}
	
	oAta.ReadBlocks( deviceLBA, uSector, uReadBuf);
	
	Dump32(uReadBuf, uSector*128);

	oAta.CloseMedia();
}


void TestPioDmaMode(void)
{
	U32 uWriteBuf, uReadBuf;
	U32 deviceLBA;
	U32 uSector;
	U32 uDeviceMaxSectors;

	uWriteBuf = CODEC_MEM_ST;
	uReadBuf = CODEC_MEM_ST + 0x400000;

	oAta.OpenMedia(PIO_DMA);
	oAta.GetMaxSectors(uDeviceMaxSectors);
	
	printf("\nInput device sector address[max: 0x%x]\n",uDeviceMaxSectors);
	deviceLBA = (U32)GetIntNum();

	printf("Input sector count[max: 0x%x]\n",uDeviceMaxSectors-deviceLBA);
	uSector = (U32)GetIntNum();

	for (U32 i=0; i<uSector*512; i++)
	{
		Outp8(uWriteBuf+i, (i+2)%256);
		Outp8(uReadBuf+i, 0);
	}

	printf("Get Ready\n");
	getchar();

	oAta.WriteBlocks(deviceLBA, uSector, uWriteBuf);
//	printf("Write Done\n");

	oAta.ReadBlocks( deviceLBA, uSector, uReadBuf);
//	printf("Read Done\n");
	
	if (Compare32(uWriteBuf, uReadBuf, uSector*128) == false)
	{
		printf("Error detected\n");
		Dump32(uReadBuf, uSector*128);
	}
	else
	{
		printf("Write/Read in PIO DMA mode is OK\n");
	}	

	oAta.CloseMedia();
}

void TestPioDmaModeRead(void)
{
	U32 uReadBuf;
	U32 deviceLBA;
	U32 uSector;
	U32 uDeviceMaxSectors;

	uReadBuf = CODEC_MEM_ST + 0x400000;

	oAta.OpenMedia(PIO_DMA);
	oAta.GetMaxSectors(uDeviceMaxSectors);
	
	printf("\nInput device sector address[max: 0x%x]\n",uDeviceMaxSectors);
	deviceLBA = (U32)GetIntNum();

	printf("Input sector count[max: 0x%x]\n",uDeviceMaxSectors-deviceLBA);
	uSector = (U32)GetIntNum();

	for (U32 i=0; i<uSector*512; i=i+4)
	{
		Outp32(uReadBuf+i, 0);
	}

	oAta.ReadBlocks( deviceLBA, uSector, uReadBuf);

	Dump32(uReadBuf, uSector*128);

	oAta.CloseMedia();
}

void TestUdmaMode(void)
{
	U32 uWriteBuf, uReadBuf;
	U32 deviceLBA;
	U32 uSector;
	U32 uDeviceMaxSectors;

	uWriteBuf = CODEC_MEM_ST;
	uReadBuf = CODEC_MEM_ST + 0x400000;

	oAta.OpenMedia(UDMA);
	oAta.GetMaxSectors(uDeviceMaxSectors);

	printf("\nInput device sector address[max: 0x%x]\n",uDeviceMaxSectors);
	deviceLBA = (U32)GetIntNum();

	printf("Input sector count[max: 0x%x]\n",uDeviceMaxSectors-deviceLBA);
	uSector = (U32)GetIntNum();

	for (U32 i=0; i<uSector*512; i++)
	{
		Outp8(uWriteBuf+i, (i+3)%256);
		Outp8(uReadBuf+i, 0);
	}

	oAta.WriteBlocks(deviceLBA, uSector, uWriteBuf);

	printf("Write Done\n");
	getchar();
	oAta.ReadBlocks( deviceLBA, uSector, uReadBuf);

	printf("Read Done\n");
	
	if (Compare32(uWriteBuf, uReadBuf, uSector*128) == false)
	{
		printf("Error detected\n");
		Dump32(uReadBuf, uSector*128);
	}
	else
	{
		printf("Write/Read in UDMA mode is OK\n");
	}	

	printf("Reset added dip SW for general SMC mode! Press Enter\n");
	getchar();

	oAta.CloseMedia();
}

void TestUdmaModeRead(void)
{
	U32 uReadBuf;
	U32 deviceLBA;
	U32 uSector;
	U32 uDeviceMaxSectors;

	uReadBuf = CODEC_MEM_ST + 0x400000;		

	oAta.OpenMedia(UDMA);
	oAta.GetMaxSectors(uDeviceMaxSectors);

	printf("\nInput device sector address[max: 0x%x]\n",uDeviceMaxSectors);
	deviceLBA = (U32)GetIntNum();

	printf("Input sector count[max: 0x%x]\n",uDeviceMaxSectors-deviceLBA);
	uSector = (U32)GetIntNum();

	for (U32 i=0; i<uSector*512; i=i+4)
	{
		Outp32(uReadBuf+i, 0);
	}
	
	oAta.ReadBlocks( deviceLBA, uSector, uReadBuf);

	Dump32(uReadBuf, uSector*128);

	oAta.CloseMedia();
}

void TestPioDmaMode_Int(void)
{
	U32 uWriteBuf, uReadBuf;
	U32 deviceLBA;
	U32 uSector;
	U32 uDeviceMaxSectors;

	uWriteBuf = CODEC_MEM_ST;
	uReadBuf = CODEC_MEM_ST + 0x400000;

	oAta.OpenMedia(PIO_DMA);
	oAta.GetMaxSectors(uDeviceMaxSectors);
	
	printf("\nInput device sector address[max: 0x%x]\n",uDeviceMaxSectors);
	deviceLBA = (U32)GetIntNum();

	printf("Input sector count[max: 0x%x]\n",uDeviceMaxSectors-deviceLBA);
	uSector = (U32)GetIntNum();

	for (U32 i=0; i<uSector*512; i++)
	{
		Outp8(uWriteBuf+i, (i+4)%256);
		Outp8(uReadBuf+i, 0);
	}

	bIsDone = false;
	bIsXferDone = false;

//	oIntc.Init();		
	oAta.ClearAllInterrupt();
	pISR_CFCON = (unsigned)Isr_Ata;  
	rINTMSK &= (~BIT_CFCON); // unmask cfcon 
	
//    oIntc.SetHandlerAndUnmask(BIT_CFCON, Isr_Ata);
	
	for (U32 i=0; i<uSector; i++)
	{
		oAta.StartWritingBlocks(deviceLBA+i, 1, uWriteBuf+i*512);
		while(bIsXferDone != true) ;
		bIsXferDone = false;	
	}

	for (U32 i=0; i<uSector; i++)
	{
		oAta.StartReadingBlocks(deviceLBA+i, 1, uReadBuf+i*512);
		while(bIsXferDone != true) ;
		bIsXferDone = false;	
	}
	
	if (Compare32(uWriteBuf, uReadBuf, uSector*128) == false)
	{
		printf("Error detected\n");
		Dump32(uReadBuf, uSector*128);
	}
	else
	{
		printf("Write/Read in PIO DMA mode is OK\n");
	}
	
	rINTMSK |= BIT_CFCON; // mask cfcon 
	
	oAta.CloseMedia();
//	oIntc.Mask(BIT_CFCON);
}

void TestUDmaMode_Int(void)
{
	U32 uWriteBuf, uReadBuf;
	U32 deviceLBA;
	U32 uSector;
	U32 uDeviceMaxSectors;

	U32 uCurrentCount;
	U32 uRemainderCount;
	U32 uCurrentLba;
	U32 uCurrentAddr;
	U32 uRound;

	uWriteBuf = CODEC_MEM_ST;
	uReadBuf = CODEC_MEM_ST + 0x400000;

	oAta.OpenMedia(UDMA);
	oAta.GetMaxSectors(uDeviceMaxSectors);

	printf("\nInput device sector address[max: 0x%x]\n", uDeviceMaxSectors);
	deviceLBA = (U32)GetIntNum();

	printf("Input sector count[max: 0x%x]\n", uDeviceMaxSectors-deviceLBA);
	uSector = (U32)GetIntNum();

	for (U32 i=0; i<uSector*512; i++)
	{
		Outp8(uWriteBuf+i, (i+4)%256);
		Outp8(uReadBuf+i, 0);
	}

	bIsDone = false;
	bIsXferDone = false;

//	oIntc.Init();		
	oAta.ClearAllInterrupt();
	ClearPending(BIT_CFCON);  
	rINTMSK &= (~BIT_CFCON); // unmask cfcon 
	pISR_CFCON = (unsigned)Isr_Ata;
//    oIntc.SetHandlerAndUnmask(BIT_CFCON, Isr_Ata);

//	printf("Get Ready\n");
//	getchar();
	
	// Max transfer block count per command is 256.
	uRemainderCount = uSector;
	uRound = 0;	
	
	while(uRemainderCount != 0) {
		if(uRemainderCount>256) {
			uCurrentCount = 256; //0 means 256
			uRemainderCount -= 256;
		} else {
			uCurrentCount = uRemainderCount;
			uRemainderCount = 0;
		}
		uCurrentLba = deviceLBA + uRound*256;
		uCurrentAddr = uWriteBuf + uRound*256*512;
		
		oAta.StartWritingBlocks(uCurrentLba, uCurrentCount, uCurrentAddr);
		while(bIsXferDone != true) ;
		bIsXferDone = false;

		uRound++;
	}

	printf("Write Done\n");
	getchar();

	uRemainderCount = uSector;
	uRound = 0;	
	
	while(uRemainderCount != 0) {
		if(uRemainderCount>256) {
			uCurrentCount = 256; //0 means 256
			uRemainderCount -= 256;
		} else {
			uCurrentCount = uRemainderCount;
			uRemainderCount = 0;
		}
		uCurrentLba = deviceLBA + uRound*256;
		uCurrentAddr = uReadBuf + uRound*256*512;

		oAta.StartReadingBlocks(uCurrentLba, uCurrentCount, uCurrentAddr);
		while(bIsXferDone != true) ;
		bIsXferDone = false;	

		uRound++;
	}
	
	printf("Read Done\n");
	getchar();
	
	if (Compare32(uWriteBuf, uReadBuf, uSector*128) == false)
	{
		printf("Error detected\n");
		Dump32(uReadBuf, uSector*128);
	}
	else
	{
		printf("Write/Read in UDMA mode is OK\n");
	}
	
	rINTMSK |= BIT_CFCON; // mask cfcon 

	oAta.CloseMedia();
//	oIntc.Mask(BIT_CFCON);
}

void TestMultiPioDmaModeWrite(void)
{
	U32 k;
	U32 uWriteBuf, uReadBuf;
	U32 deviceLBA;
	U32 uSector;
	U32 uDeviceMaxSectors;
	U32 uDeviceMaxMultiple;
	U32 uQuotient, uRemainder;
	U32 uCurrentMultiple;
	U32 uCurrentLba, uCurrentBufAddr;

	uWriteBuf = CODEC_MEM_ST;
	uReadBuf = CODEC_MEM_ST + 0x400000;

	oAta.OpenMedia(PIO_DMA);
	oAta.GetMaxSectors(uDeviceMaxSectors);

	printf("\nInput device sector address[max: 0x%x]\n",uDeviceMaxSectors);
	deviceLBA = (U32)GetIntNum();

	printf("Input sector count[max: 0x%x]\n",uDeviceMaxSectors-deviceLBA);
	uSector = (U32)GetIntNum();

	for (U32 i=0; i<uSector*512; i++)
	{
		Outp8(uWriteBuf+i, (i+6)%256);
		Outp8(uReadBuf+i, 0);
	}

	oAta.SetAtaMode(PIO_DMA);

	oAta.GetMaxMultiple(uDeviceMaxMultiple);
	//Assert(uDeviceMaxMultiple > 1);  // not support for CF card
/*
	if (uDeviceMaxMultiple > 6) 
		uDeviceMaxMultiple = 6;  // may be bug	   -> hang
*/
	if (uDeviceMaxMultiple > 5) 
		uDeviceMaxMultiple = 5;  // may be bug.
	uQuotient = uSector/uDeviceMaxMultiple;
	uRemainder = uSector%uDeviceMaxMultiple;
	uCurrentLba = deviceLBA;
	uCurrentBufAddr = uWriteBuf;
	
	do
	{
		uCurrentMultiple = (uQuotient > 0) ? uDeviceMaxMultiple : uRemainder;
		if (uCurrentLba == deviceLBA || uQuotient == 0)
		{
			oAta.SetMultiple(uCurrentMultiple);
		}
	
		oAta.WriteSectors_MultiplePioDma(uCurrentLba, uCurrentBufAddr);
		uCurrentLba += uCurrentMultiple;
		uCurrentBufAddr += uCurrentMultiple*512;
	} while (uQuotient--);
	
	oAta.SetAtaMode(PIO_CPU);
	oAta.ReadBlocks( deviceLBA, uSector, uReadBuf);
	
	if (Compare32(uWriteBuf, uReadBuf, uSector*128) == false)
	{
		printf("Error detected\n");
		Dump32(uReadBuf, uSector*128);
	}
	else
	{
		printf("Write/Read in Multiple PIO DMA mode is OK\n");
	}	

	oAta.CloseMedia();
}

void TestMultiPioDmaModeRead(void)
{
	U32 uReadBuf;
	U32 deviceLBA;
	U32 uSector;
	U32 uDeviceMaxSectors;
	U32 uDeviceMaxMultiple;
	U32 uQuotient, uRemainder;
	U32 uCurrentMultiple;
	U32 uCurrentLba, uCurrentBufAddr;

	uReadBuf = CODEC_MEM_ST + 0x400000;

	oAta.OpenMedia(PIO_DMA);
	oAta.GetMaxSectors(uDeviceMaxSectors);

	printf("\nInput device sector address[max: 0x%x]\n",uDeviceMaxSectors);
	deviceLBA = (U32)GetIntNum();

	printf("Input sector count[max: 0x%x]\n",uDeviceMaxSectors-deviceLBA);
	uSector = (U32)GetIntNum();

	for (U32 i=0; i<uSector*512; i=i+4)
	{
		Outp32(uReadBuf+i, 0);
	}

	oAta.GetMaxMultiple(uDeviceMaxMultiple);
	//Assert(uDeviceMaxMultiple > 1);  // not support for CF card
	if (uDeviceMaxMultiple > 4) 
	{
		uDeviceMaxMultiple = 4;  // may be bug
	}
	uQuotient = uSector/uDeviceMaxMultiple;
	uRemainder = uSector%uDeviceMaxMultiple;
	uCurrentLba = deviceLBA;
	uCurrentBufAddr = uReadBuf;
	
	do
	{
		uCurrentMultiple = (uQuotient > 0) ? uDeviceMaxMultiple : uRemainder;
		if (uCurrentLba == deviceLBA || uQuotient == 0)
		{
			oAta.SetMultiple(uCurrentMultiple);
		}
	
		oAta.ReadSectors_MultiplePioDma(uCurrentLba, uCurrentBufAddr);
		uCurrentLba += uCurrentMultiple;
		uCurrentBufAddr += uCurrentMultiple*512;
	} while (uQuotient--);
	
	Dump32(uReadBuf, uSector*128);	

	oAta.CloseMedia();
}


void Test_ATA(void)
{
	int i, sel;

	const FUNC_MENU menu[]=
	{
		NULL,							"Exit",
		TestChangeModeToAta,			"Change mode to ATA",	
		TestReset,						"Reset ATA device\n",
		
		TestBasicWriteRead,				"Basic Write/Read test\n",
		
		TestPioCpuMode,					"PIO_CPU mode Write/Read test",
		TestPioCpuModeRead,				"PIO_CPU mode Read test",		
		TestPioDmaMode,					"PIO_DMA mode Write/Read test [Polling mode]",
		TestPioDmaModeRead,				"PIO_DMA mode Read test [Polling mode]",
		TestUdmaMode,					"UDMA mode Write/Read test [Polling mode]",
		TestUdmaModeRead,				"UDMA mode Read test [Polling mode]\n",

		TestPioDmaMode_Int,				"PIO_DMA Write/Read test [Interrupt mode]",
		TestUDmaMode_Int,				"UDMA Write/Read test [Interrupt mode]\n",
// Additional test
		TestMultiPioDmaModeWrite,		"PIO DMA Multiple Write/Read test [MicroDrive only]",
		TestMultiPioDmaModeRead,		"PIO DMA Multiple Read test [MicroDrive only]",

		0,0
	};

	while(1)
	{
		printf("\n");
		for (i=0; (int)(menu[i].desc)!=0; i++)
			printf("%2d: %s\n", i, menu[i].desc);

		printf("\nSelect the function to test : ");
		sel = GetIntNum();
		printf("\n");

		if (sel == 0)
			break;
		else if (sel>0 && sel<(sizeof(menu)/8-1))
			(menu[sel].func)();
	}	
}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美午夜理伦三级在线观看| 精品国产乱码久久久久久免费| 亚洲国产日韩一级| 精品国产亚洲在线| 91精品1区2区| 国产99精品国产| 麻豆视频观看网址久久| 亚洲欧美偷拍三级| 中文字幕久久午夜不卡| 日韩欧美亚洲一区二区| 欧洲一区在线观看| 成人晚上爱看视频| 久久精品噜噜噜成人av农村| 亚洲午夜久久久久久久久久久| 亚洲国产高清在线观看视频| 欧美一级一级性生活免费录像| 日本国产一区二区| 不卡的av在线| 国产成人免费高清| 久久国产综合精品| 日韩av一区二| 五月天久久比比资源色| 夜夜精品视频一区二区| 国产精品久久毛片| 国产欧美一区二区三区网站| 欧美成va人片在线观看| 欧美一区二区三区啪啪| 欧美日韩视频在线观看一区二区三区| 97se亚洲国产综合自在线| 国产在线看一区| 国产一区福利在线| 激情图片小说一区| 麻豆成人综合网| 老司机精品视频一区二区三区| 亚洲国产精品久久人人爱蜜臀| 亚洲天堂2014| 中文字幕亚洲不卡| 日韩一区在线播放| 国产精品亲子伦对白| 国产性色一区二区| 国产喷白浆一区二区三区| 亚洲国产成人在线| 中文av字幕一区| 国产精品二三区| 国产精品久久久久久久第一福利| 专区另类欧美日韩| 亚洲欧美日韩系列| 亚洲图片自拍偷拍| 天天综合色天天| 美女精品自拍一二三四| 国产一区二区视频在线播放| 国产成人av在线影院| 成人av午夜电影| 欧美性生活影院| 宅男噜噜噜66一区二区66| 精品999在线播放| 日本一区二区三区高清不卡 | 欧美丰满高潮xxxx喷水动漫| 欧美日韩精品欧美日韩精品一| 欧美久久一二三四区| 欧美一卡在线观看| 国产丝袜欧美中文另类| 成人激情动漫在线观看| 91亚洲大成网污www| 欧美日韩在线播放三区| 精品蜜桃在线看| 综合激情成人伊人| 亚洲最新在线观看| 久久精品国产久精国产爱| 国产尤物一区二区| 色狠狠桃花综合| 日韩视频一区在线观看| 精品成人a区在线观看| 中文字幕在线观看一区| 免费欧美在线视频| 国产成人鲁色资源国产91色综 | 成人午夜视频在线| 91九色最新地址| 日韩限制级电影在线观看| 欧美经典一区二区| 亚洲一区二区3| 国产在线播放一区| 欧美视频一区二区三区| 久久久久久夜精品精品免费| 亚洲精品福利视频网站| 另类小说一区二区三区| 色哟哟国产精品免费观看| 91精品国产全国免费观看| 亚洲三级免费电影| 久久精品av麻豆的观看方式| 日本精品裸体写真集在线观看| 亚洲精品在线电影| 五月婷婷激情综合| 99re在线精品| 精品国产成人在线影院| 亚洲午夜日本在线观看| www.av亚洲| 精品国产伦一区二区三区观看方式| 亚洲欧美韩国综合色| 国产乱子伦一区二区三区国色天香| 日本丰满少妇一区二区三区| 久久久精品2019中文字幕之3| 亚洲成av人片在www色猫咪| 波多野结衣中文一区| 26uuu精品一区二区| 日韩一区精品视频| 91在线播放网址| 久久久www成人免费毛片麻豆 | av电影在线不卡| 日韩欧美国产精品| 亚洲午夜视频在线| 91最新地址在线播放| 国产视频一区二区在线观看| 久久成人久久鬼色| 4438x亚洲最大成人网| 夜夜嗨av一区二区三区四季av| av资源网一区| 国产精品三级在线观看| 国模一区二区三区白浆| 日韩一区二区在线观看| 视频在线观看一区二区三区| 欧美性色aⅴ视频一区日韩精品| 亚洲女同ⅹxx女同tv| 成人av动漫在线| 日本一二三不卡| 成人午夜碰碰视频| 国产日韩欧美制服另类| 国产成人丝袜美腿| 欧美韩日一区二区三区| 国产精品99久久久久| 久久久亚洲欧洲日产国码αv| 老司机精品视频在线| 欧美大尺度电影在线| 久久精品久久精品| 欧美大片在线观看一区| 蜜桃视频在线观看一区二区| 91精品国产福利在线观看| 男人操女人的视频在线观看欧美| 欧美一级片在线观看| 日韩二区三区四区| 日韩女优视频免费观看| 久久精品99国产精品日本| 精品福利二区三区| 国产成人午夜电影网| 中文字幕欧美激情一区| 成人精品高清在线| 亚洲天堂福利av| 精品视频一区三区九区| 蜜臀久久99精品久久久久宅男 | 激情综合网av| 久久久久久久久久久久久夜| 成人久久久精品乱码一区二区三区| 国产欧美日韩另类一区| 91偷拍与自偷拍精品| 亚洲va韩国va欧美va| 日韩欧美在线观看一区二区三区| 精品在线播放午夜| 欧美国产禁国产网站cc| 色婷婷精品久久二区二区蜜臂av| 午夜在线电影亚洲一区| 欧美一区二区不卡视频| 风间由美一区二区av101 | 最新欧美精品一区二区三区| 91久久精品一区二区| 免费成人小视频| 国产精品美女久久久久aⅴ| 91麻豆蜜桃一区二区三区| 日韩一区精品视频| 国产欧美精品一区aⅴ影院 | 精品黑人一区二区三区久久| 不卡的av在线| 日韩激情中文字幕| 国产欧美精品一区二区色综合| 色欧美片视频在线观看| 理论片日本一区| 亚洲免费在线观看| 欧美日韩高清不卡| 国产精品资源站在线| 一级日本不卡的影视| 日韩欧美黄色影院| 91在线码无精品| 麻豆精品视频在线观看视频| 最新欧美精品一区二区三区| 日韩欧美的一区| 91网站在线观看视频| 老司机午夜精品| 亚洲一级电影视频| 国产欧美一区二区三区沐欲| 欧美日韩精品一二三区| 成人免费看的视频| 久久成人羞羞网站| 亚洲国产另类av| 中文字幕一区免费在线观看| 亚洲精品在线一区二区| 欧美性大战xxxxx久久久| 成人三级伦理片| 久久99国产精品久久99果冻传媒| 亚洲一区在线观看免费观看电影高清| 久久久久99精品国产片| 制服.丝袜.亚洲.另类.中文|