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

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

?? s3c6410_fil.c

?? 6410BSP3
?? C
?? 第 1 頁 / 共 5 頁
字號:
	// If FS_SCAN_RATIO value is 0, skip Scan.
	// OS_SCAN_RATIO means scan percentage of Total SPECIAL AREA size.
	// If OS_SCAN_RATIO value is 0, skip Scan.
    OS_SCAN_RATIO = 10;    // 10 means (100/10)% => 10%
	if ( stDEVInfo[nScanIdx].nNumOfBlocks <= 1024 )
	{
	    FS_SCAN_RATIO = 20;    // 10 means (100/10)% => 10%
	}
	else if ( stDEVInfo[nScanIdx].nNumOfBlocks <= 2048 )
	{
	    FS_SCAN_RATIO = 50;    // 20 means (100/20)% => 5%
	}
	else if ( stDEVInfo[nScanIdx].nNumOfBlocks <= 4096 )
	{
	    FS_SCAN_RATIO = 100;    // 50 means (100/50)% => 2%
	}
	else if ( stDEVInfo[nScanIdx].nNumOfBlocks <= 8192 )
	{
	    FS_SCAN_RATIO = 200;    // 100 means (100/100)% => 1%
	}
	else
	{
	    FS_SCAN_RATIO = 400;    // 200 means (100/200)% => 0.5%
	}

	// CRITICAL_READ_CNT value is used to avoid read disturbance problem.
	// This value is critical count value to determine the count of read for reclaim.
	// Every block have each read count value, this value is reset to 0 when boot up the system.
	// If each block is read more than CRITICAL_READ_CNT value after boot up, this block is enter to reclaim list.
	// This value is useful if the system is running long times without reboot.
	// But system have to calls FTL_Reclaim function during running the system.
	// If this CRITICAL_READ_CNT value is set to 0. It doesn't support Reclaim function using read count value.
	// If you support periodic scan and reclaim by OnDisk or other application, you don't need to use this function.
	CRITICAL_READ_CNT = 0;
	
	// This flag determin the scan function during boot up.
	BOOTING_SCAN = FALSE32;

	/* DDP */
	if (bInternalInterleaving)
	{
		for (nDevIdx = 0; nDevIdx < nDevCnt; nDevIdx++)
		{
			aNeedSync[nDevIdx * 2] = FALSE32;
			aNeedSync[nDevIdx * 2 + 1] = FALSE32;
		}
	}

	#if (WMR_MLC_LSB_RECOVERY)
	MLC_LSB_CLASS = GetMlcClass( stDEVInfo[nScanIdx].nDevID, 
								 stDEVInfo[nScanIdx].nHidID);
	#endif

	CalcGlobal(bInternalInterleaving);
	
	NAND_LOG((_T("[FIL] ##############################\r\n")));
	NAND_LOG((_T("[FIL]  FIL Global Information\r\n")));
	NAND_LOG((_T("[FIL]  BANKS_TOTAL = %d\r\n"), BANKS_TOTAL));
	NAND_LOG((_T("[FIL]  BLOCKS_PER_BANK = %d\r\n"), BLOCKS_PER_BANK));
	NAND_LOG((_T("[FIL]  TWO_PLANE_PROGRAM = %d\r\n"), TWO_PLANE_PROGRAM));
	NAND_LOG((_T("[FIL]  SUPPORT_INTERLEAVING = %d\r\n"), IS_SUPPORT_INTERLEAVING));
	NAND_LOG((_T("[FIL]  SUBLKS_TOTAL = %d\r\n"), SUBLKS_TOTAL));
	NAND_LOG((_T("[FIL]  PAGES_PER_SUBLK = %d\r\n"), PAGES_PER_SUBLK));
	NAND_LOG((_T("[FIL]  PAGES_PER_BANK = %d\r\n"), PAGES_PER_BANK));
	NAND_LOG((_T("[FIL]  SECTORS_PER_PAGE = %d\r\n"), SECTORS_PER_PAGE));
	NAND_LOG((_T("[FIL]  SECTORS_PER_SUPAGE = %d\r\n"), SECTORS_PER_SUPAGE));
	NAND_LOG((_T("[FIL]  SECTORS_PER_SUBLK = %d\r\n"), SECTORS_PER_SUBLK));
	NAND_LOG((_T("[FIL]  BYTES_PER_MAIN_PAGE = %d\r\n"), BYTES_PER_MAIN_PAGE));
	NAND_LOG((_T("[FIL]  USER_SECTORS_TOTAL = %d\r\n"), USER_SECTORS_TOTAL));
	NAND_LOG((_T("[FIL]  ADDRESS_CYCLE = %d\r\n"), DEV_ADDR_CYCLE));
	NAND_LOG((_T("[FIL] ##############################\r\n\r\n")));
	NAND_LOG((_T("[INFO] WMR_AREA_SIZE = %d\n"), WMR_AREA_SIZE));
	NAND_LOG((_T("[INFO] SPECIAL_AREA_START = %d\n"), SPECIAL_AREA_START));
	NAND_LOG((_T("[INFO] SPECIAL_AREA_SIZE = %d\n"), SPECIAL_AREA_SIZE));
	NAND_LOG((_T("[INFO] VFL_AREA_START = %d\n"), VFL_AREA_START));
	NAND_LOG((_T("[INFO] VFL_AREA_SIZE = %d\n"), VFL_AREA_SIZE));
	NAND_LOG((_T("[INFO] VFL_INFO_SECTION_START = %d\n"), VFL_INFO_SECTION_START));
	NAND_LOG((_T("[INFO] VFL_INFO_SECTION_SIZE = %d\n"), VFL_INFO_SECTION_SIZE));
	NAND_LOG((_T("[INFO] RESERVED_SECTION_START = %d\n"), RESERVED_SECTION_START));
	NAND_LOG((_T("[INFO] RESERVED_SECTION_SIZE = %d\n"), RESERVED_SECTION_SIZE));
	NAND_LOG((_T("[INFO] FTL_INFO_SECTION_START = %d\n"), FTL_INFO_SECTION_START));
	NAND_LOG((_T("[INFO] FTL_INFO_SECTION_SIZE = %d\n"), FTL_INFO_SECTION_SIZE));
	NAND_LOG((_T("[INFO] LOG_SECTION_SIZE = %d\n"), LOG_SECTION_SIZE));
	NAND_LOG((_T("[INFO] FREE_SECTION_START = %d\n"), FREE_SECTION_START));
	NAND_LOG((_T("[INFO] FREE_SECTION_SIZE = %d\n"), FREE_SECTION_SIZE));
	NAND_LOG((_T("[INFO] FREE_LIST_SIZE = %d\n"), FREE_LIST_SIZE));
	NAND_LOG((_T("[INFO] DATA_SECTION_START = %d\n"), DATA_SECTION_START));
	NAND_LOG((_T("[INFO] DATA_SECTION_SIZE = %d\n"), DATA_SECTION_SIZE));
	NAND_LOG((_T("[INFO] FTL_AREA_START = %d\n"), FTL_AREA_START));
	NAND_LOG((_T("[INFO] FTL_AREA_SIZE = %d\n"), FTL_AREA_SIZE));

	NAND_MSG((_T("[FIL]--NAND_Init()\r\n")));

	return FIL_SUCCESS;
}

/*****************************************************************************/
/*                                                                           */
/* NAME                                                                      */
/*      NAND_GetPlatformInfo                                                 */
/* DESCRIPTION                                                               */
/*      This function returns platform information                           */
/* PARAMETERS                                                                */
/*      pstFILPlantformInfo                                                  */
/*          Platform information                                             */
/* RETURN VALUES                                                             */
/*****************************************************************************/
VOID
NAND_GetPlatformInfo(FILPlatformInfo* pstFILPlatformInfo)
{
	NAND_LOG((_T("[INFO] ++NAND_GetPlatformInfo\n")));
    /* Warning : Do not change !!!! */
    pstFILPlatformInfo->nType = 1;
    /* Address of command register in MAP11 */
    pstFILPlatformInfo->nAddrOfCmdReg = 0xB0200008;
    /* Address of address register */
    pstFILPlatformInfo->nAddrOfAdrReg = 0xB020000C;
    /* Address of register for reading ID*/
    pstFILPlatformInfo->nAddrOfReadIDReg = 0xB0200010;
    /* Address of status register */
    pstFILPlatformInfo->nAddrOfStatusReg = 0xB0200028;
    /* Command of reading Device ID  */
    pstFILPlatformInfo->nCmdOfReadID = CMD_READ_ID;
    /* Command of read page */
    pstFILPlatformInfo->nCmdOfReadPage = CMD_READ;
    /* Command of read status */
    pstFILPlatformInfo->nCmdOfReadStatus = CMD_READ_STATUS;
    /* Mask value for Ready or Busy status */
    pstFILPlatformInfo->nMaskOfRnB = NF_RNB_READY;   

	// Must be set CE to low
	NF_CE_L(0);
	NF_WAIT_RnB(0);

	NAND_LOG((_T("[INFO] --NAND_GetPlatformInfo\n")));
    return;
}

INT32
NAND_Read_Retry(UINT32 nBank, UINT32 nPpn, UINT32 nSctBitmap, UINT32 nPlaneBitmap,
				UINT8* pDBuf, UINT8* pSBuf, BOOL32 bECCIn, BOOL32 bCleanCheck)
{
    INT32 dwRet;
    INT32 dwCnt;
    
    dwRet = NAND_Read( nBank, nPpn, nSctBitmap, nPlaneBitmap, pDBuf, pSBuf, bECCIn, bCleanCheck);
    
    if (bECCEngineError == TRUE32)
    {
        goto ECCPROBLEM;
    }
    // Try read again.
    for ( dwCnt = 0; dwCnt < 10; dwCnt++ )
    {
        if ( dwRet == FIL_U_ECC_ERROR )
        {
            NAND_LOG((_T("[FIL] NAND_Read Try to read again(%d)\n"), dwCnt));
            bReadSafeMode = TRUE32;
            dwRet = NAND_Read( nBank, nPpn, nSctBitmap, nPlaneBitmap, pDBuf, pSBuf, bECCIn, bCleanCheck);
            bReadSafeMode = FALSE32;
            if (bECCEngineError == TRUE32)
            {
                goto ECCPROBLEM;
            }
        }
        else
        {
            break;
        }
    }
    return dwRet;

ECCPROBLEM:
    {
       	nSctBitmap &= FULL_SECTOR_BITMAP_PAGE;

        if ( pDBuf != NULL )
        {
			if ((nSctBitmap & LEFT_SECTOR_BITMAP_PAGE) > 0 && (nSctBitmap & RIGHT_SECTOR_BITMAP_PAGE) > 0)
			{
                WMR_MEMSET(pDBuf, 0x0, BYTES_PER_MAIN_PAGE);
                WMR_MEMSET(pDBuf + BYTES_PER_MAIN_PAGE, 0x0, BYTES_PER_MAIN_PAGE);
			}
			else if ((nSctBitmap & LEFT_SECTOR_BITMAP_PAGE) > 0 && (nSctBitmap & RIGHT_SECTOR_BITMAP_PAGE) == 0)
			{
                WMR_MEMSET(pDBuf, 0x0, BYTES_PER_MAIN_PAGE);
			}
			else if ((nSctBitmap & LEFT_SECTOR_BITMAP_PAGE) == 0 && (nSctBitmap & RIGHT_SECTOR_BITMAP_PAGE) > 0)
			{
                WMR_MEMSET(pDBuf + BYTES_PER_MAIN_PAGE, 0x0, BYTES_PER_MAIN_PAGE);
			}
        }
        NAND_ERR((_T("[FIL] NAND_Write(0x%x)\n"), nPpn));
        NAND_Write( nBank, nPpn, nSctBitmap, nPlaneBitmap, pDBuf, pSBuf );

		// TODO:
        // Reset Device.
		// HCLK_IROM, HCLK_MEM1, HCLK_MEM0, HCLK_MFC Should be Always On for power Mode (Something coupled with BUS operation)
		pSYSConReg->HCLK_GATE |= ((1<<25)|(1<<22)|(1<<21)|(1<<0));
#if 0
	    _OEMSWReset();
#else
		pWTDogReg->WTCON = WTCON_PRESCALE(WD_PRESCALER) | WTCON_CLK_DIV128 | WTCON_RESET;
		pWTDogReg->WTDAT = WTDAT_CNT(0x1);
		pWTDogReg->WTCNT = WTCNT_CNT(0x1);
		pWTDogReg->WTCON |= WTCON_ENABLE;
#endif

        while(1);
    }    
}

/*****************************************************************************/
/*                                                                           */
/* NAME                                                                      */
/*      NAND_Read		                                                     */
/* DESCRIPTION                                                               */
/*      This function reads NAND page area							 		 */
/* PARAMETERS                                                                */
/*      nBank    	[IN] 	Physical device number			               	 */
/*      nPpn     	[IN] 	Physical page number				         	 */
/*      nSctBitmap  [IN] 	Physical sector bitmap in a page area        	 */
/*      nPlaneBitmap[IN]    The indicator of the plane  					 */
/*      pDBuf		[OUT]	Buffer pointer of main area to read          	 */
/*      pSBuf		[OUT]	Buffer pointer of spare area to read         	 */
/*      bECCIn		[IN] 	Whether read page with ECC value or not      	 */
/*      bCleanCheck [IN] 	When it's TRUE, checks the clean status        	 */
/*							of the page if the data of spare area is all	 */
/*							0xFF, returns PAGE_CLEAN						 */
/* RETURN VALUES                                                             */
/*		FIL_SUCCESS															 */
/*					NAND_Read is success.									 */
/*		FIL_SUCCESS_CLEAN													 */
/*					NAND_Read is success and all data is 0xFF.				 */
/*		FIL_U_ECC_ERROR														 */
/*					ECC value is not correct.								 */
/* NOTES                                                                     */
/*                                                                           */
/*****************************************************************************/
INT32
NAND_Read(UINT32 nBank, UINT32 nPpn, UINT32 nSctBitmap, UINT32 nPlaneBitmap,
				UINT8* pDBuf, UINT8* pSBuf, BOOL32 bECCIn, BOOL32 bCleanCheck)
{
	UINT32 nPbn;
	UINT32 nPOffset;

	UINT32 nPageReadStatus = 0;
	UINT32 nPageReadStatus1st = 0;
	UINT32 nPageReadStatus2nd = 0;
	UINT32 nCnt;
	UINT32 nRet = 0;

	BOOL32 bECCErr = FALSE32;
	BOOL32 bPageClean = TRUE32;		// When the data is all 0xFF, regard the page as clean
	BOOL32 bIsSBufNull = FALSE32;	// When the pSBuf is NULL, set to check whether the page is clean or not

	BOOL32 bSecondRead = FALSE32;	// In case of twice read
	BOOL32 bLoopNeed = FALSE32;		// Only for nSctOffset == 8
	BOOL32 bRetry = TRUE32;

	UINT32  nLoopCount;
	UINT32  nVBank;
	UINT32  nPairBank;

	UINT32  nSyncRet;

#ifdef	USE_SETKMODE
	BOOL bLastMode;
#endif

	NAND_MSG((_T("[FIL]++NAND_Read(%d, %d, 0x%02x, 0x%02x, %d)\r\n"), nBank, nPpn, nSctBitmap, nPlaneBitmap, bCleanCheck));
//	NAND_ERR((_T("[FIL]++NAND_Read(%d, %d, 0x%02x, 0x%02x, %d)\r\n"), nBank, nPpn, nSctBitmap, nPlaneBitmap, bCleanCheck));  // ksk dbg

	// pDBuf & pSBuf can't be the NULL at the same time
	if (nBank >= BANKS_TOTAL || nPpn >= PAGES_PER_BANK || (pDBuf == NULL && pSBuf == NULL))
	{	
		NAND_ERR((_T("[FIL:ERR]--NAND_Read() : Parameter overflow\r\n")));
		WMR_ASSERT(FALSE32);
		return FIL_CRITICAL_ERROR;
	}

	WMR_ASSERT((nPlaneBitmap == enuBOTH_PLANE_BITMAP) || (nPlaneBitmap == enuLEFT_PLANE_BITMAP)
	          || (nPlaneBitmap == enuRIGHT_PLANE_BITMAP) || (nPlaneBitmap == enuNONE_PLANE_BITMAP));

	nVBank = nBank;	// Do not change nBank before copy to nVBank
	// avoid r/b check error with internal interleaving
	if (bInternalInterleaving == TRUE32)
	{
		nPairBank = ((nBank & 0x1) == 1) ? (nBank - 1) : (nBank + 1);
	}

	/* 
	In case of Internal Interleaving, the first address of the second bank should be 
	the half of toal block number of NAND.
	For example, In 4Gbit DDP NAND, its total block number is 4096.
	So, the bank 0 has 2048 blocks (Physical number : 0 ~ 2047),
	the bank 1 has another 2048 blocks (Physical number : 2048 ~ 4095).
	therefore, first block address of Bank 1 could be the physically 2048th block.
	*/
	if (bInternalInterleaving == TRUE32)
	{
		if ((nBank & 0x1) == 1)
		{
			nPpn += PAGES_PER_BANK;
		}
		nBank /= 2;
	}
	nSctBitmap &= FULL_SECTOR_BITMAP_PAGE;

#if (WMR_STDLIB_SUPPORT)
	nPbn = nPpn / PAGES_PER_BLOCK;
	nPOffset = nPpn % PAGES_PER_BLOCK;
#else
	nPbn = DIV(nPpn, PAGES_PER_BLOCK_SHIFT);
	nPOffset = REM(nPpn, PAGES_PER_BLOCK_SHIFT);
#endif
	// In case of 2 Plane Program, re-calculate the page address
	if (TWO_PLANE_PROGRAM == TRUE32)
	{
		nPpn = nPbn * 2 * PAGES_PER_BLOCK + nPOffset;

		if (nPlaneBitmap == enuBOTH_PLANE_BITMAP)
		{
			if(pDBuf != NULL)
			{
				if ((nSctBitmap & LEFT_SECTOR_BITMAP_PAGE) > 0 && (nSctBitmap & RIGHT_SECTOR_BITMAP_PAGE) > 0)
				{
					// read from both plane
					bLoopNeed = TRUE32;
				}
				else if ((nSctBitmap & LEFT_SECTOR_BITMAP_PAGE) > 0 && (nSctBitmap & RIGHT_SECTOR_BITMAP_PAGE) == 0)
				{
					// read from left plane
					bLoopNeed = FALSE32;
				}
				else if ((nSctBitmap & LEFT_SECTOR_BITMAP_PAGE) == 0 && (nSctBitmap & RIGHT_SECTOR_BITMAP_PAGE) > 0)
				{
					// read from right plane
					bLoopNeed = FALSE32;
					bSecondRead = TRUE32;
				}
			}
			else
			{
				// When read only the spare area, must read twice
				bLoopNeed = TRUE32;
			}
		}
		else if (nPlaneBitmap == enuRIGHT_PLANE_BITMAP)
		{
			nPpn += PAGES_PER_BLOCK;
		}
	}
	nLoopCount = SECTORS_PER_PAGE;

	NAND_Sync(nVBank, &nSyncRet);
	if (bInternalInterleaving == TRUE32)
	{
		// avoid r/b check error with internal interleaving
		aNeedSync[nVBank] = FALSE32;
	}

_B_SecondRead:	// back here again for read right plane

	if(bSecondRead)
	{
		nPpn += PAGES_PER_BLOCK;
		nSctBitmap = (nSctBitmap >> SECTORS_PER_PAGE);

		if(pDBuf != NULL)
		{
			pDBuf += BYTES_PER_MAIN_PAGE;
		}
		else
		{
			// When read only the spare, read 64 + 64 bytes to check the Bad Block
			pSBuf += BYTES_PER_SPARE_PAGE;
		}
	}
#if (WMR_READ_RECLAIM)
	READ_ERR_FLAG = FALSE32;
#endif

	if(pSBuf == NULL)
	{
		pSBuf = aTempSBuf;
		bIsSBufNull = TRUE32;
	}

	//NAND_Sync(nVBank, &nSyncRet);

#ifdef	USE_SETKMODE
	bLastMode = SetKMode(TRUE);
#endif
	// Chip Select
	NF_CE_L(nBank);

	// Read Command (Always read spare area before main area in a page
	NF_CMD(CMD_READ);
	if (ECC_8BIT_SPPORT == FALSE32 && SECTORS_PER_PAGE == 8)
	{
    	NF_SET_ADDR(nPpn, BYTES_PER_MAIN_PAGE+NAND_SECC_OFFSET_4K);
	}
	else
	{
    	NF_SET_ADDR(nPpn, BYTES_PER_MAIN_PAGE);

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
粉嫩欧美一区二区三区高清影视 | 精品动漫一区二区三区在线观看| 亚洲成a人片在线观看中文| 91猫先生在线| 亚洲一区二区精品久久av| 欧美久久久久久蜜桃| 日韩成人伦理电影在线观看| 日韩一区二区三区电影| 另类小说色综合网站| 久久女同互慰一区二区三区| 国产成人精品影视| 亚洲欧洲成人精品av97| 欧美性大战久久久久久久蜜臀| 亚洲一区二区偷拍精品| 欧美一区二区三区在线视频| 国产综合一区二区| 国产精品久久久久毛片软件| 欧美视频一区二区在线观看| 久久精品久久久精品美女| 国产午夜三级一区二区三| 91天堂素人约啪| 爽好多水快深点欧美视频| 久久综合色一综合色88| 99国产精品视频免费观看| 天天免费综合色| 久久精品人人做人人爽人人| 日本道在线观看一区二区| 免费看欧美女人艹b| 欧美高清在线一区二区| 欧美日本免费一区二区三区| 狠狠久久亚洲欧美| 亚洲美女电影在线| 精品精品欲导航| 在线视频国内一区二区| 极品少妇一区二区三区精品视频 | 日韩欧美亚洲国产精品字幕久久久| 国产精品白丝av| 五月婷婷激情综合| 国产精品私房写真福利视频| 91精品国产一区二区三区| zzijzzij亚洲日本少妇熟睡| 蜜桃视频第一区免费观看| 中文字幕在线不卡一区二区三区| 日韩欧美国产综合在线一区二区三区| 99在线热播精品免费| 麻豆高清免费国产一区| 亚洲一区二区三区免费视频| 欧美极品美女视频| 欧美成人午夜电影| 欧美日韩国产免费| 91猫先生在线| 大陆成人av片| 国产一区二区毛片| 日韩电影在线一区二区三区| 亚洲欧美日韩一区| 中文字幕精品在线不卡| 精品不卡在线视频| 欧美一卡二卡在线观看| 欧美系列亚洲系列| 91久久精品一区二区三区| 国产999精品久久久久久绿帽| 日本麻豆一区二区三区视频| 一区二区三区精品在线| 最新不卡av在线| 中文乱码免费一区二区| 久久精品视频免费| 久久久久久久久岛国免费| 精品国产电影一区二区| 欧美一区二区三区免费观看视频| 欧美三级中文字幕| 欧美又粗又大又爽| 91免费精品国自产拍在线不卡| 国产一区二区三区视频在线播放| 久久精工是国产品牌吗| 麻豆精品久久久| 久久国产精品一区二区| 免费av成人在线| 精品午夜一区二区三区在线观看| 久久精品国产99国产| 麻豆精品在线播放| 国产在线视频精品一区| 国产成人综合在线播放| 国产成人精品1024| 成人午夜激情片| 91社区在线播放| 欧美三区在线观看| 91精品国产一区二区三区香蕉 | 波多野结衣亚洲| 99久久久精品免费观看国产蜜| 99国产欧美另类久久久精品| 一本到高清视频免费精品| 色香蕉久久蜜桃| 欧美日韩第一区日日骚| 日韩欧美国产三级电影视频| xfplay精品久久| 中文字幕一区二区5566日韩| 亚洲黄色av一区| 天堂在线亚洲视频| 韩国成人精品a∨在线观看| 国产成人自拍网| 91在线观看美女| 欧美精品精品一区| 久久日一线二线三线suv| 国产精品久久久久久久久久免费看| 中文字幕一区二区三区在线不卡| 一区二区三区四区中文字幕| 蜜臀99久久精品久久久久久软件| 国产美女精品在线| 99久久精品免费看国产| 欧美日韩你懂得| 久久久精品国产免费观看同学| 亚洲欧洲精品一区二区精品久久久 | 激情六月婷婷综合| a4yy欧美一区二区三区| 欧美揉bbbbb揉bbbbb| 精品国产凹凸成av人导航| 综合欧美一区二区三区| 午夜电影一区二区| 成人午夜在线播放| 制服.丝袜.亚洲.中文.综合| 国产亚洲成av人在线观看导航 | 在线观看不卡视频| 欧美电视剧在线看免费| 亚洲精品成人少妇| 国内精品视频一区二区三区八戒| 91久久精品网| 国产午夜精品理论片a级大结局| 亚洲综合偷拍欧美一区色| 国产乱国产乱300精品| 欧美怡红院视频| 国产欧美精品区一区二区三区| 午夜精品久久久久久久久久久| 成人动漫一区二区| 日韩免费看的电影| 亚洲一二三专区| 成人精品电影在线观看| 日韩三级伦理片妻子的秘密按摩| 亚洲欧美电影院| 国产v日产∨综合v精品视频| 3d动漫精品啪啪1区2区免费| 亚洲欧美另类图片小说| 国产一区二区在线影院| 在线综合+亚洲+欧美中文字幕| 日韩美女精品在线| 国产·精品毛片| 精品国产一区二区三区忘忧草 | 欧美精品三级日韩久久| 一区精品在线播放| 国产激情一区二区三区| 日韩欧美在线影院| 亚洲国产cao| 在线精品视频一区二区三四| 国产精品欧美一级免费| 国产一区二区精品久久91| 日韩一区二区三区av| 日日夜夜免费精品视频| 欧美三级韩国三级日本一级| 亚洲免费资源在线播放| 99精品视频在线观看| 中文av一区二区| 粉嫩高潮美女一区二区三区| 国产偷v国产偷v亚洲高清| 国产专区欧美精品| 久久影院电视剧免费观看| 另类小说视频一区二区| 精品国产百合女同互慰| 精品在线免费观看| 精品对白一区国产伦| 国内精品久久久久影院薰衣草| 精品免费99久久| 国产一区二区三区久久久 | 久久久久青草大香线综合精品| 九九精品视频在线看| 欧美成人vr18sexvr| 国产一区二区在线免费观看| 久久人人爽人人爽| 国产精品一品二品| 国产精品免费视频网站| 91麻豆国产精品久久| 亚洲综合久久av| 欧美日韩一级视频| 毛片基地黄久久久久久天堂| xnxx国产精品| 波多野结衣在线一区| 亚洲精品videosex极品| 欧美日韩国产综合视频在线观看 | 91丨国产丨九色丨pron| 亚洲国产人成综合网站| 欧美一级日韩一级| 国产精品一级片| 亚洲精品欧美专区| 制服丝袜日韩国产| 国产成人综合自拍| 夜夜精品浪潮av一区二区三区| 欧美美女网站色| 国产精品一区二区在线看| 亚洲精选一二三| 精品国产亚洲一区二区三区在线观看| 国产精品18久久久| 一区二区高清在线|