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

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

?? fmd.cpp

?? Samsung公司S3C2443芯片的BSP源碼包
?? CPP
?? 第 1 頁 / 共 4 頁
字號(hào):
			break;
		case 2:	// Multiple Error
			RETAILMSG(1,(TEXT("%cECC Uncorrectable error(0x%x)\r\n"), ((nType==ECC_CORRECT_MAIN)?'M':'S'), sectoraddr));
			bRet = FALSE;			
			break;
		case 3:	// ECC area Error
			RETAILMSG(1,(TEXT("%cECC area error\r\n"), ((nType==ECC_CORRECT_MAIN)?'M':'S')));
		default:
			bRet = FALSE;			
			break;
	}

	return bRet;
}

BOOL FMD_LB_ReadSector(SECTOR_ADDR startSectorAddr, LPBYTE pSectorBuff, PSectorInfo pSectorInfoBuff, DWORD dwNumSectors,int mode)
{
	ULONG SectorAddr = (ULONG)startSectorAddr;
	DWORD       i;
	volatile DWORD		rddata;	
	UINT32 nRetEcc = 0;
	DWORD MECCBuf[4];
	UINT16 nSectorLoop;
	int NewSpareAddr = 2048;
	int NewDataAddr = 0;
	int NewSectorAddr = startSectorAddr;
#if CHECK_SPAREECC
	DWORD SECCBuf;
#endif

	//RETAILMSG(1, (TEXT("#### FMD_DRIVER:::FMD_LB_READSECTOR %x %x\r\n"), startSectorAddr, NewDataAddr));

	if (!pSectorBuff && !pSectorInfoBuff)
		return(FALSE);

	if ( dwNumSectors > 1 )
	{
		RETAILMSG(1, (TEXT("######## FATAL ERROR => FMD::FMD_ReadSector->dwNumsectors is bigger than 1. \r\n")));
		return FALSE;
	}

	BOOL bLastMode = SetKMode(TRUE);

	if (!pSectorBuff)
	{
		if (!NAND_LB_ReadSectorInfo(startSectorAddr, pSectorInfoBuff, mode))
			return FALSE;

		return TRUE;
	}

    //  Enable Chip
	NF_nFCE_L();
	
	NF_CLEAR_RB();

	NF_CMD(CMD_READ);
	//  Set up address
	NF_ADDR((NewSpareAddr)&0xff);
	NF_ADDR((NewSpareAddr>>8)&0xff);
	NF_ADDR((NewSectorAddr)&0xff);
	NF_ADDR((NewSectorAddr>>8)&0xff);
	if (LB_NEED_EXT_ADDR)
		NF_ADDR((NewSectorAddr>>16)&0xff);  

	NF_CMD(CMD_READ3);

	NF_DETECT_RB();								// Wait for command to complete.

	if (pSectorInfoBuff)
	{
#if CHECK_SPAREECC
		NF_RSTECC();
		NF_SECC_UnLock();
#endif

		pSectorInfoBuff->dwReserved1 = NF_RDDATA_WORD();
		pSectorInfoBuff->bOEMReserved = NF_RDDATA_BYTE();
		pSectorInfoBuff->bBadBlock = NF_RDDATA_BYTE();
#if CHECK_SPAREECC
		NF_SECC_Lock();
#endif
		pSectorInfoBuff->wReserved2 = NF_RDDATA_BYTE();
		pSectorInfoBuff->wReserved2 |= (NF_RDDATA_BYTE()<<8);
	}
	else
	{
		 for(i=0; i<sizeof(SectorInfo)/sizeof(DWORD); i++) 
			rddata = (DWORD) NF_RDDATA_WORD();		// read and trash the data
	}

	for (nSectorLoop = 0; nSectorLoop < SECTORS_PER_PAGE; nSectorLoop++)
	{
		MECCBuf[nSectorLoop] = NF_RDDATA_WORD();
	}

#if CHECK_SPAREECC
	if (pSectorInfoBuff)
	{
		SECCBuf = NF_RDDATA_WORD();
		NF_WRSECCD((SECCBuf&0xff)|((SECCBuf<<8)&0xff0000));

		nRetEcc = NF_ECC_ERR0;

		if (!ECC_CorrectData(startSectorAddr, (LPBYTE)pSectorInfoBuff, nRetEcc, ECC_CORRECT_SPARE))
			return FALSE;
	}
#endif

	for (nSectorLoop = 0; nSectorLoop < SECTORS_PER_PAGE; nSectorLoop++)
	{
		NewDataAddr = nSectorLoop * SECTOR_SIZE;
		
		NF_CMD(CMD_RDO);							// Send read command.
		NF_ADDR((NewDataAddr)&0xff);
		NF_ADDR((NewDataAddr>>8)&0xff);
		NF_CMD(CMD_RDO2);	// 2nd command

		NF_RSTECC();
		NF_MECC_UnLock();

		if( ((DWORD) (pSectorBuff+nSectorLoop*SECTOR_SIZE)) & 0x3) 
		{
			for(i=0; i<SECTOR_SIZE/sizeof(DWORD); i++) {
				rddata = (DWORD) NF_RDDATA_WORD();
				(pSectorBuff+nSectorLoop*SECTOR_SIZE)[i*4+0] = (BYTE)(rddata & 0xff);
				(pSectorBuff+nSectorLoop*SECTOR_SIZE)[i*4+1] = (BYTE)(rddata>>8 & 0xff);
				(pSectorBuff+nSectorLoop*SECTOR_SIZE)[i*4+2] = (BYTE)(rddata>>16 & 0xff);
				(pSectorBuff+nSectorLoop*SECTOR_SIZE)[i*4+3] = (BYTE)(rddata>>24 & 0xff);
			}
		}
		else 
		{
			RdPage512(pSectorBuff+nSectorLoop*SECTOR_SIZE);					// Read page/sector data.
		}

		NF_MECC_Lock();

		NF_WRMECCD0( ((MECCBuf[nSectorLoop]&0xff00)<<8)|(MECCBuf[nSectorLoop]&0xff) );
		NF_WRMECCD1( ((MECCBuf[nSectorLoop]&0xff000000)>>8)|((MECCBuf[nSectorLoop]&0xff0000)>>16) );

		nRetEcc = NF_ECC_ERR0;

		if (!ECC_CorrectData(startSectorAddr, pSectorBuff+nSectorLoop*SECTOR_SIZE, nRetEcc, ECC_CORRECT_MAIN))
			return FALSE;
	}

	NF_nFCE_H();

	SetKMode (bLastMode);

	return TRUE;
}	

BOOL NAND_LB_ReadSectorInfo(SECTOR_ADDR sectorAddr, PSectorInfo pInfo, int mode)
{
	BOOL bRet = TRUE;
	int NewSpareAddr = 2048;
	int NewSectorAddr = sectorAddr;
#if CHECK_SPAREECC
	DWORD SECCBuf;
	UINT32 nRetEcc = 0;
#endif

	BOOL bLastMode = SetKMode(TRUE);

	//RETAILMSG(1, (TEXT("#### FMD_DRIVER:::NAND_LB_ReadSectorInfo %x %x\r\n"), NewSectorAddr, NewSpareAddr));

	NF_nFCE_L();

	NF_CLEAR_RB();

	NF_CMD(CMD_READ);							// Send read confirm command.

	NF_ADDR((NewSpareAddr)&0xff);
	NF_ADDR((NewSpareAddr>>8)&0xff);
	NF_ADDR((NewSectorAddr)&0xff);
	NF_ADDR((NewSectorAddr>>8)&0xff);
	if (LB_NEED_EXT_ADDR)
		NF_ADDR((NewSectorAddr>>16)&0xff);  

	NF_CMD(CMD_READ3);

	NF_DETECT_RB();

#if CHECK_SPAREECC
	NF_RSTECC();
	NF_SECC_UnLock();
#endif

	pInfo->dwReserved1  = NF_RDDATA_WORD();
	pInfo->bOEMReserved = NF_RDDATA_BYTE();
	pInfo->bBadBlock = NF_RDDATA_BYTE();
#if CHECK_SPAREECC
	NF_SECC_Lock();
#endif
	pInfo->wReserved2 = NF_RDDATA_BYTE();
	pInfo->wReserved2 |= (NF_RDDATA_BYTE()<<8);

#if CHECK_SPAREECC
	SECCBuf = NF_RDSECC();
	NF_WRSECCD((SECCBuf&0xff)|((SECCBuf<<8)&0xff0000));

	nRetEcc = NF_ECC_ERR0;

	bRet = ECC_CorrectData(sectorAddr, (LPBYTE)pInfo, nRetEcc, ECC_CORRECT_SPARE);
#endif

	NF_nFCE_H();
	
	SetKMode(bLastMode);

	return bRet;
}		


BOOL FMD_SB_ReadSector(SECTOR_ADDR startSectorAddr, LPBYTE pSectorBuff, PSectorInfo pSectorInfoBuff, DWORD dwNumSectors,int mode)
{
	ULONG SectorAddr = (ULONG)startSectorAddr;
	ULONG MECC;
	UINT32 nRet = TRUE;
	UINT32 nRetEcc = 0;

	if (!pSectorBuff && !pSectorInfoBuff)
		return(FALSE);

	BOOL bLastMode = SetKMode(TRUE);

	//RETAILMSG(1, (TEXT("FMD::FMD_SB_ReadSector 0x%x \r\n"), startSectorAddr));

	while (dwNumSectors--)
	{
		NF_RSTECC();
		NF_MECC_UnLock();
		NF_nFCE_L();
		
		if (!pSectorBuff)
		{
			NF_CLEAR_RB();
			NF_CMD(CMD_READ2);							// Send read confirm command.

			NF_ADDR(0);									// Ignored.
			NF_ADDR(SectorAddr		 & 0xff);			// Page address.
			NF_ADDR((SectorAddr >>  8) & 0xff);
			if (SB_NEED_EXT_ADDR)
				NF_ADDR((SectorAddr >> 16) & 0xff);  

			NF_DETECT_RB();
			
			RdPageInfo((PBYTE)pSectorInfoBuff);			// Read page/sector information.

			pSectorInfoBuff++;
		}
		else
		{
			NF_CLEAR_RB();

			NF_CMD(CMD_READ);							// Send read command.

			NF_ADDR(0);									// Column = 0.
			NF_ADDR(SectorAddr		 & 0xff);			// Page address.
			NF_ADDR((SectorAddr >>  8) & 0xff);
			if (SB_NEED_EXT_ADDR)
				NF_ADDR((SectorAddr >> 16) & 0xff);  

			NF_DETECT_RB();								// Wait for command to complete.
			
			if( ((DWORD) pSectorBuff) & 0x3) 
			{
				RdPage512Unalign (pSectorBuff);
			}
			else 
			{
				RdPage512(pSectorBuff);					// Read page/sector data.
			}
			NF_MECC_Lock();

			if (pSectorInfoBuff)
			{
				RdPageInfo((PBYTE)pSectorInfoBuff);		// Read page/sector information.
				pSectorInfoBuff ++;
			}
			else
			{
				BYTE TempInfo[8];
				RdPageInfo(TempInfo);				   	// Read page/sector information.
			}

			MECC  = NF_RDDATA_BYTE() << 0;
			MECC |= NF_RDDATA_BYTE() << 8;
			MECC |= NF_RDDATA_BYTE() << 16;
			MECC |= (NF_RDMECC0() &0xff000000);
			//MECC |= NF_RDDATA_BYTE() << 24;
			
			NF_WRMECCD0( ((MECC&0xff00)<<8)|(MECC&0xff) );
	 		NF_WRMECCD1( ((MECC&0xff000000)>>8)|((MECC&0xff0000)>>16) );

	 		nRetEcc = NF_ECC_ERR0;

			switch(nRetEcc & 0x3)
			{
				case 0:	// No Error
					nRet = TRUE;
					break;
				case 1:	// 1-bit Error(Correctable)
					RETAILMSG(1,(TEXT("ECC correctable error(0x%x)\r\n"), SectorAddr));
					(pSectorBuff)[(nRetEcc>>7)&0x7ff] ^= (1<<((nRetEcc>>4)&0x7));
					nRet = TRUE;		
					break;
				case 2:	// Multiple Error
					RETAILMSG(1,(TEXT("ECC Uncorrectable error(0x%x)\r\n"), SectorAddr));
					nRet = FALSE;			
					break;
				case 3:	// ECC area Error
					RETAILMSG(1,(TEXT("ECC area error\r\n")));
				default:
					nRet = FALSE;			
					break;
			}
			pSectorBuff += NAND_SECTOR_SIZE;
		}
		NF_nFCE_H();
		++SectorAddr;
	}

	SetKMode (bLastMode);

	return(nRet);
}

BOOL FMD_LB_WriteSector(SECTOR_ADDR startSectorAddr, LPBYTE pSectorBuff, PSectorInfo pSectorInfoBuff, DWORD dwNumSectors, int mode)
{
    DWORD   i;
    BOOL    bRet = TRUE;
	volatile DWORD	wrdata;
	DWORD MECCBuf[4];
	UINT16 nSectorLoop;
	int NewSpareAddr = 2048;
	int NewDataAddr = 0;
	int NewSectorAddr = startSectorAddr;
#if CHECK_SPAREECC
	DWORD SECCBuf;
#endif

	//RETAILMSG(1, (TEXT("FMD::FMD_LB_WriteSector 0x%x \r\n"), startSectorAddr));

	if (!pSectorBuff && !pSectorInfoBuff)
		return(FALSE);

	if ( dwNumSectors > 1 )
	{
		RETAILMSG(1, (TEXT("######## FATAL ERROR => FMD::FMD_WriteSector->dwNumsectors is bigger than 1. \r\n")));
		return FALSE;
	}

    BOOL bLastMode = SetKMode(TRUE);
	
	if (!pSectorBuff)
	{
		NAND_LB_WriteSectorInfo(startSectorAddr, pSectorInfoBuff, mode);
		return TRUE;
	}

    //  Enable Chip
    NF_nFCE_L();
    
    NF_CLEAR_RB();

    //  Issue command
    NF_CMD(CMD_WRITE);

    //  Setup address
    NF_ADDR((NewDataAddr)&0xff);
    NF_ADDR((NewDataAddr>>8)&0xff);
    NF_ADDR((NewSectorAddr)&0xff);
    NF_ADDR((NewSectorAddr>>8)&0xff);
    if (LB_NEED_EXT_ADDR)
        NF_ADDR((NewSectorAddr>>16)&0xff);

	for (nSectorLoop = 0; nSectorLoop < SECTORS_PER_PAGE; nSectorLoop++)
	{
	    //  Initialize ECC register
	    NF_RSTECC();
		NF_MECC_UnLock();

	    //  Special case to handle un-aligned buffer pointer.
	    //
	    if( ((DWORD) (pSectorBuff+nSectorLoop*SECTOR_SIZE)) & 0x3) {
	        //  Write the data
	        for(i=0; i<SECTOR_SIZE/sizeof(DWORD); i++) {
				wrdata = (pSectorBuff+nSectorLoop*SECTOR_SIZE)[i*4+0];
				wrdata |= (pSectorBuff+nSectorLoop*SECTOR_SIZE)[i*4+1]<<8;
				wrdata |= (pSectorBuff+nSectorLoop*SECTOR_SIZE)[i*4+2]<<16;
				wrdata |= (pSectorBuff+nSectorLoop*SECTOR_SIZE)[i*4+3]<<24;
	            NF_WRDATA_WORD(wrdata);
	        }
	    }
	    else {
	        WrPage512(pSectorBuff+nSectorLoop*SECTOR_SIZE);
	    }

	    //  Read out the ECC value generated by HW
		NF_MECC_Lock();

		MECCBuf[nSectorLoop] = NF_RDMECC0();
	}

    NF_CMD(CMD_RDI);
    NF_ADDR((NewSpareAddr)&0xff);
    NF_ADDR((NewSpareAddr>>8)&0xff);
	// Write the SectorInfo data to the media
	// NOTE: This hardware is odd: only a byte can be written at a time and it must reside in the
	//       upper byte of a USHORT.
	if(pSectorInfoBuff)
	{
#if CHECK_SPAREECC
		NF_RSTECC();
		NF_SECC_UnLock();
#endif

        //  Write the first reserved field (DWORD)
        NF_WRDATA_WORD(pSectorInfoBuff->dwReserved1);
		NF_WRDATA_BYTE(pSectorInfoBuff->bOEMReserved);
		NF_WRDATA_BYTE(pSectorInfoBuff->bBadBlock);
#if CHECK_SPAREECC
		NF_SECC_Lock();
#endif
		NF_WRDATA_BYTE(pSectorInfoBuff->wReserved2&0xff);
		NF_WRDATA_BYTE((pSectorInfoBuff->wReserved2>>8)&0xff);
	}
	else
	{
		// Make sure we advance the Flash's write pointer (even though we aren't writing the SectorInfo data)
		for(i=0; i<sizeof(SectorInfo)/sizeof(DWORD); i++)
		{
            NF_WRDATA_WORD(0xffffffff);
		}
	}

    //  Write the ECC value to the flash
	NF_WRDATA_WORD(MECCBuf[0]);
	NF_WRDATA_WORD(MECCBuf[1]);
	NF_WRDATA_WORD(MECCBuf[2]);
	NF_WRDATA_WORD(MECCBuf[3]);

#if CHECK_SPAREECC
	if(pSectorInfoBuff)
	{
		SECCBuf = NF_RDSECC();
		NF_WRDATA_WORD(SECCBuf);
	}
#endif

    //  Finish up the write operation
	NF_CMD(CMD_WRITE2);

    //  Wait for RB
	NF_DETECT_RB();	 // Wait tR(max 12us)

	if ( NF_RDSTAT & STATUS_ILLACC )
	{
		RETAILMSG(1, (TEXT("FMD_WriteSector() ######## Error Programming page (Illigar Access) %d!\n"), startSectorAddr));
		s2443NAND->NFSTAT =  STATUS_ILLACC;	// Write 1 to clear.
		bRet = FALSE;
	}
	else
	{
		//  Check the status
		NF_CMD(CMD_STATUS);

		if(NF_RDDATA_BYTE() & STATUS_ERROR) {
			RETAILMSG(1, (TEXT("FMD_WriteSector() ######## Error Programming page %d!\n"), startSectorAddr));
			bRet = FALSE;
		}
	}

    //  Disable the chip
	NF_nFCE_H();

	SetKMode(bLastMode);

	return bRet;
}

BOOL NAND_LB_WriteSectorInfo(SECTOR_ADDR sectorAddr, PSectorInfo pInfo, int mode)
{
	BOOL    bRet = TRUE;
	int NewSpareAddr = 2048;
	int NewSectorAddr = sectorAddr;
#if CHECK_SPAREECC
	DWORD SECCBuf;
#endif

	BOOL bLastMode = SetKMode(TRUE);

	//RETAILMSG(1, (TEXT("FMD::NAND_LB_WriteSectorInfo 0x%x \r\n"), NewSectorAddr));

    //  Chip enable
	NF_nFCE_L();

	NF_CLEAR_RB();

    //  Write the command
    //  First, let's point to the spare area
	NF_CMD(CMD_WRITE);

    //  Write the address
	NF_ADDR((NewSpareAddr)&0xff);
	NF_ADDR((NewSpareAddr>>8)&0xff);
	NF_ADDR((NewSectorAddr)&0xff);
	NF_ADDR((NewSectorAddr>>8)&0xff);
	if (LB_NEED_EXT_ADDR)
		NF_ADDR((NewSectorAddr>>16)&0xff);

#if CHECK_SPAREECC
	NF_RSTECC();
	NF_SECC_UnLock();
#endif

    //  Now let's write the SectorInfo data
    //
    //  Write the first reserved field (DWORD)
	NF_WRDATA_WORD(pInfo->dwReserved1);
	NF_WRDATA_BYTE(pInfo->bOEMReserved);
	NF_WRDATA_BYTE(pInfo->bBadBlock);
#if CHECK_SPAREECC
	NF_SECC_Lock();
#endif
	NF_WRDATA_BYTE(pInfo->wReserved2&0xff);
	NF_WRDATA_BYTE((pInfo->wReserved2>>8)&0xff);

	NF_WRDATA_WORD(0xffffffff);  // Mecc[0]
	NF_WRDATA_WORD(0xffffffff);  // Mecc[1]
	NF_WRDATA_WORD(0xffffffff);  // Mecc[2]
	NF_WRDATA_WORD(0xffffffff);  // Mecc[3]

#if CHECK_SPAREECC
	SECCBuf = NF_RDSECC();

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美欧美欧美欧美| 一区二区三区加勒比av| 精品粉嫩超白一线天av| 欧美丰满少妇xxxxx高潮对白| 在线观看欧美日本| 在线视频国内自拍亚洲视频| 91国偷自产一区二区三区成为亚洲经典 | 91精品国产91综合久久蜜臀| 一本久道中文字幕精品亚洲嫩| 91在线小视频| 一本大道久久a久久综合| 99国内精品久久| 色综合久久久久综合体桃花网| 色菇凉天天综合网| 欧美日韩亚洲综合在线| 欧美精选一区二区| 日韩精品自拍偷拍| 久久午夜色播影院免费高清 | 亚洲一级二级在线| 日韩综合在线视频| 玖玖九九国产精品| 国产福利一区二区| 91在线视频网址| 欧美日韩不卡视频| 欧美精品一区二区久久久| 国产亚洲欧美激情| 一区精品在线播放| 亚洲va欧美va人人爽| 久久99久国产精品黄毛片色诱| 国产盗摄一区二区三区| 91免费小视频| 欧美一区二区三区在线看| 久久伊99综合婷婷久久伊| 国产精品欧美极品| 亚洲r级在线视频| 国产伦精一区二区三区| 91啪九色porn原创视频在线观看| 欧美伦理影视网| 国产欧美日韩视频在线观看| 亚洲制服丝袜在线| 国产一区二区三区蝌蚪| 色综合久久精品| 欧美大片在线观看一区二区| 日本一二三四高清不卡| 午夜在线成人av| 国产成人自拍在线| 欧美日韩国产美| 久久精品视频免费| 午夜激情一区二区| 国产不卡在线视频| 在线观看91av| 国产精品国产自产拍高清av| 亚洲国产婷婷综合在线精品| 国产精品亚洲午夜一区二区三区| 色婷婷久久一区二区三区麻豆| 日韩精品在线一区二区| 一级中文字幕一区二区| 精品无人区卡一卡二卡三乱码免费卡 | a4yy欧美一区二区三区| 日韩欧美在线网站| 亚洲国产中文字幕在线视频综合| 国产高清不卡一区二区| 91精品欧美一区二区三区综合在| 国产欧美一区二区精品忘忧草| 婷婷亚洲久悠悠色悠在线播放| 成人性色生活片免费看爆迷你毛片| 在线播放91灌醉迷j高跟美女 | 国产精品久久免费看| 免费的国产精品| 在线一区二区三区四区五区| 欧美国产精品劲爆| 麻豆精品精品国产自在97香蕉| 欧美在线观看一区| 国产精品亲子伦对白| 国产资源在线一区| 91精品欧美一区二区三区综合在| 一区二区三区在线视频免费| 成人国产视频在线观看| 精品国产伦一区二区三区观看体验 | 国产蜜臀97一区二区三区| 精油按摩中文字幕久久| 欧美精品一二三区| 亚洲一区二区三区自拍| 色综合欧美在线视频区| 国产精品国产三级国产普通话蜜臀 | 日本高清免费不卡视频| 欧美激情艳妇裸体舞| 国产精品一区免费视频| 欧美大尺度电影在线| 视频在线观看91| 色哟哟一区二区在线观看| 国产精品久久久久久久久久免费看 | 欧美一级高清片在线观看| 日韩视频在线观看一区二区| 中文字幕一区二区三区精华液 | 免费在线视频一区| 欧美欧美欧美欧美| 亚洲成人av在线电影| 欧美亚洲综合在线| 一区二区三区免费| 色激情天天射综合网| 亚洲免费三区一区二区| 97se亚洲国产综合自在线| 成人免费视频在线观看| 丁香婷婷综合激情五月色| 日韩欧美中文字幕一区| 国产精品白丝jk黑袜喷水| 亚洲激情图片小说视频| 99国产精品国产精品久久| 中文av一区特黄| 91香蕉视频黄| 一区二区久久久久| 色呦呦国产精品| 日韩免费视频一区| 蜜桃精品在线观看| 国产乱子伦一区二区三区国色天香| 久久99精品国产.久久久久久| 日本最新不卡在线| 欧美性高清videossexo| 久久国产精品第一页| 国产精品美女久久久久高潮| 欧美影片第一页| 激情丁香综合五月| 亚洲精品成人悠悠色影视| 日韩一区二区免费视频| 色综合天天综合网国产成人综合天| 亚洲国产一二三| 中文乱码免费一区二区| 欧美一区二区三级| 91丨九色porny丨蝌蚪| 久久精品国产99久久6| 亚洲精品国产品国语在线app| 精品国产91久久久久久久妲己| 色欧美乱欧美15图片| 国产盗摄一区二区三区| 日韩精品午夜视频| 韩国理伦片一区二区三区在线播放| 亚洲日本青草视频在线怡红院 | 午夜久久久影院| 国产精品美女久久久久久久久久久 | 亚洲美女在线一区| 久久九九久久九九| 91精品国产手机| 日本道精品一区二区三区| 国产成人午夜精品5599| 日本欧美一区二区三区| 亚洲免费资源在线播放| 国产欧美日韩在线看| 欧美一区二区三区啪啪| 色综合一个色综合亚洲| 高清不卡一区二区| 久久激情综合网| 日韩和欧美一区二区三区| 亚洲精品五月天| 亚洲国产高清aⅴ视频| 337p粉嫩大胆噜噜噜噜噜91av | 免费在线一区观看| 亚洲午夜私人影院| 亚洲精品免费在线播放| 中文字幕av不卡| 久久久亚洲精华液精华液精华液 | 激情综合亚洲精品| 性久久久久久久| 亚洲国产裸拍裸体视频在线观看乱了| 国产精品欧美极品| 国产人妖乱国产精品人妖| 日韩美一区二区三区| 91精品国产综合久久精品麻豆| 在线日韩国产精品| 一本大道久久a久久综合| 99久久精品费精品国产一区二区| 国产在线精品一区在线观看麻豆| 蜜桃91丨九色丨蝌蚪91桃色| 午夜免费欧美电影| 天天影视色香欲综合网老头| 性欧美大战久久久久久久久| 午夜在线成人av| 日韩高清在线观看| 日本麻豆一区二区三区视频| 亚洲国产日韩av| 亚洲成人av一区二区三区| 亚洲18色成人| 午夜视频一区在线观看| 亚洲小少妇裸体bbw| 亚洲123区在线观看| 日韩va欧美va亚洲va久久| 日韩精品一区第一页| 日韩av中文字幕一区二区| 视频一区二区三区入口| 视频精品一区二区| 日本怡春院一区二区| 麻豆免费精品视频| 另类小说综合欧美亚洲| 精品无人码麻豆乱码1区2区 | 国产日韩欧美精品电影三级在线| 欧美成人精品高清在线播放| 精品人伦一区二区色婷婷| 精品久久久网站| 国产亚洲综合在线| 国产精品久久毛片a|