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

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

?? badblockmanagement.c

?? Nand Flash Translation Layer 用于nandflash的操作。 bad block memory map garbage collection average er
?? C
字號:


#include "OSModule_MemoryManagement.h"
#include "HardwareAdaptationLayer.h"
#include "LLD.h"
#include "BadBlockManagement.h"
#include "FalUserDirective.h"







/*number of bad block present on device*/
static UINT8 BadBlocksNumber = 0;

/*physical block number of block containing the BBT*/
static INT16 BootBlockNumber = -1;

/*head of bad blocks list*/
static BadBlockElem *BadBlockList = NULL;

/*pointer to the last elem of bad block list in ram*/
static BadBlockElem *last = NULL;
//static UINT8 BadBlockBuff[528];
//static UINT8 pageBuffer[528];



/*************************GetBadBlockTable ****************************
* Retrieve the BBT from flash (if exists). Return a concatenate list  *
* of BadBlockElem													  *
*---------------------------------------------------------------------*
*   startBlock : physical block number where start the searching	  *
*									  *
*   bbt : the head of bad block list retrieved				  *
*																	  *
***********************************************************************/

NFTL_Return GetBadBlockTable(BadBlockElem *bbt, UINT16 startBlock)
{
	UINT16 i;
	UINT32 k;

	UINT8 searchRange;
	UINT8 founded = 0;
	BootStruct bootStruct;
	UINT16 *bbtArray = NULL;
	UINT8 *buffer = NULL;

	UINT16 lenght;

	//lenght = GetDeviceArchitecture().pageSize;
	
	lenght = CHUNK_SIZE;

	searchRange = 10;
	last = NULL;
	BadBlocksNumber = 0;

	//buffer = OS_DRIVER_Malloc(GetDeviceArchitecture().pageSize);
	buffer = (UINT8 *)OS_DRIVER_Malloc(CHUNK_SIZE);
	if (buffer == NULL)
	{
		return FAILURE;
	}

	for (i = startBlock; i <= (startBlock + searchRange); i++)
	{
		if (!founded)
		{
			UINT32 targetAddress;  
			
			CalculateAddress(i,0,&targetAddress);

			//if ((NAND_PageRead(targetAddress,(UINT8 *)(&BadBlockBuff[0]),lenght) != NAND_PASS))
			if ((NAND_PageRead(targetAddress,buffer,lenght) != NAND_PASS))
			{
				OS_DRIVER_Free(buffer);
				return FAILURE;
			}

			OS_MemCopy(&bootStruct,buffer,sizeof(BootStruct));		

			//founded bootStruct
			if (OS_SearchString((char *) bootStruct.bootStructId,"NANDBOOT") != NULL)
			{
				UINT8 *pageBuffer = NULL;
				int c = 0;
				UINT8 noOfPage = 0;
				INT32 lastPageDim = 0;
				UINT8 totalPage = 0;
				founded = 1;

				//set the physical block number of the block containing the bootstruct
				SetBBMBootBlockNumber(i);

				//allocate the list of Bad Blocks
				if (bootStruct.noOfBadBlocks == 0)
				{
					bbt = NULL;
					bbtArray = NULL;
					OS_DRIVER_Free(buffer);
					return SUCCESS;
				}	

				bbtArray = (UINT16 *)
					OS_DRIVER_Malloc(sizeof(UINT16) * bootStruct.noOfBadBlocks);
				if (bbtArray == NULL)
				{
					SetBBMBootBlockNumber(-1);
					OS_DRIVER_Free(buffer);
					return FAILURE;
				}
#if 0
				noOfPage = ((bootStruct.noOfBadBlocks) * sizeof(UINT16)) /
					GetDeviceArchitecture().mainSize;
				lastPageDim = (bootStruct.noOfBadBlocks * sizeof(UINT16)) %
					GetDeviceArchitecture().mainSize;
#endif
#if 1
				noOfPage = ((UINT16)((bootStruct.noOfBadBlocks) * sizeof(UINT16))) >>9;
					
				lastPageDim = (bootStruct.noOfBadBlocks * sizeof(UINT16)) &511 ;
#endif
				totalPage = noOfPage;

				if (lastPageDim != 0)
				{
					totalPage += 1;
				}

				//pageBuffer = OS_DRIVER_Malloc(GetDeviceArchitecture().pageSize);
				pageBuffer = (UINT8 *)OS_DRIVER_Malloc(CHUNK_SIZE);
				if (pageBuffer == NULL)
				{
					return FAILURE;
				}

				for (c = 1; c <= totalPage; c++)
				{
					UINT16 lenght;


					//lenght = GetDeviceArchitecture().pageSize;
					lenght = CHUNK_SIZE;

					CalculateAddress(i,c,&targetAddress);


					if (NAND_PageRead(targetAddress,pageBuffer,lenght) != NAND_PASS)
					{
						bbt = NULL;
						if (bbtArray != NULL)
						{
							OS_DRIVER_Free(bbtArray);
							bbtArray = NULL;
						}
						OS_DRIVER_Free(buffer);
						OS_DRIVER_Free(pageBuffer);
						SetBBMBootBlockNumber(-1);
						return FAILURE;
					}

					if (c == totalPage && lastPageDim)
					{
						//OS_MemCopy((UINT8 *) bbtArray +
							//((c - 1) * GetDeviceArchitecture().mainSize),
							//pageBuffer,lastPageDim);
							OS_MemCopy((UINT8 *) bbtArray +
							((c - 1) * CHUNK_DATA_SIZE),
							pageBuffer,lastPageDim);
					}
					else
					{
						//OS_MemCopy((UINT8 *) bbtArray +
						//	((c - 1) * GetDeviceArchitecture().mainSize),
						//	pageBuffer,GetDeviceArchitecture().mainSize);
						OS_MemCopy((UINT8 *) bbtArray +
							((c - 1) * CHUNK_DATA_SIZE),
							pageBuffer,CHUNK_DATA_SIZE);
					}
				}
				OS_DRIVER_Free(pageBuffer);
			}
		}
	}

	OS_DRIVER_Free(buffer);
	if (!founded)
	{
		return DEVICE_UNFORMATTED;
	}
	SetBBMBadBlocksNumber(bootStruct.noOfBadBlocks);
	//create a list of badblockelem


	SetBBMlast(BadBlockList);
	for (k = 1; k <= bootStruct.noOfBadBlocks; k++)
	{
		BadBlockElem *temp = (BadBlockElem *) OS_DRIVER_Malloc(sizeof(BadBlockElem));
		if (temp == NULL)
		{
			bbt = NULL;
			if (bbtArray != NULL)
			{
				OS_DRIVER_Free(bbtArray);
				bbtArray = NULL;
			}
			bbtArray = NULL;
			SetBBMBootBlockNumber(-1);
			return	FAILURE;
		} 
		temp->blockNumber = bbtArray[k - 1];
		temp->next = NULL;
		if (GetBBMlast() == NULL)
		{
			SetBBMlast(temp);
			SetBBMBadBlockList(GetBBMlast());
		}
		else
		{
			GetBBMlast()->next = temp;
			SetBBMlast(temp);
		}
	}
	if (bbtArray != NULL)
	{
		OS_DRIVER_Free(bbtArray);
		bbtArray = NULL;
	}
	bbtArray = NULL;
	*bbt = *(GetBBMBadBlockList());	
	return SUCCESS;
}


/*****************  MarkBadBlock ************************************
*  Mark a block as bad												*
*-------------------------------------------------------------------*
*   blockNumber : physical block number of block to mark bad		*
*																	*
*	return values:													*
*				SUCCESS: no problem erasing block					*
*				FAILURE: error marking bad the block				*
*********************************************************************/

NFTL_Return MarkBadBlock(UINT16 blockNumber)
{
	//write the spare

	UINT8 BadFlag = 0x00;
	UINT32 returnAddress;
	
	CalculateAddress(blockNumber,0,&returnAddress);

	returnAddress += BLOCK_STATUS_BYTE;
	if (NAND_SpareProgram(returnAddress,&BadFlag,1) == NAND_FAIL)
	{
		return FAILURE;
	}

	return SUCCESS;
}


/***********************  AddBadBlock *******************************
* Add an element at the tail of bad blocks list						*
*-------------------------------------------------------------------*
*   blockNumber : physical block number of block to add				*
*																	*
*	return values:													*
*				SUCCESS: no adding bad block						*
*				FAILURE: error marking bad the block				*
*********************************************************************/

NFTL_Return AddBadBlock(UINT16 blockNumber)
{
	/*if (blockNumber
	 >= GetDeviceArchitecture().numOfBlocks * GetDeviceArchitecture().devicesNumber)
		return FAILURE;
		*/
	if (GetBBMBadBlockList() == NULL)
	{
		SetBBMBadBlockList((BadBlockElem *) OS_DRIVER_Malloc(sizeof(BadBlockElem)));
		GetBBMBadBlockList()->blockNumber = blockNumber;
		GetBBMBadBlockList()->next = NULL;
		SetBBMlast(BadBlockList);
	}
	else
	{
		GetBBMlast()->next = (BadBlockElem *) OS_DRIVER_Malloc(sizeof(BadBlockElem));
		GetBBMlast()->next->blockNumber = blockNumber;
		GetBBMlast()->next->next = NULL;
		SetBBMlast(GetBBMlast()->next);
	}
	SetBBMBadBlocksNumber(GetBBMBadBlocksNumber() + 1);
	return SUCCESS;
}

/*****************  FlushBadBlockTable ******************************
* write on flash the Bad Block List and OS_DRIVER_Free space on ram			*
* occupied by BadBlockList											*
*-------------------------------------------------------------------*
*   firstGoodBlock : physical block number ehere write BBT			*
*					 or -1 if BBT must be written 					*
*					  in the current block used for store BBT		*
*																	*
*																	*
*********************************************************************/

NFTL_Return FlushBadBlockTable(UINT16 firstGoodBlock)
{
	UINT8 pageNumber = 0;
	UINT16 *table = NULL;
	UINT8 i;
	UINT32 lastPageSize;
	BadBlockElem *temp;
	BootStruct bootStruct;

	//lastPageSize = GetDeviceArchitecture().mainSize;
	lastPageSize = CHUNK_DATA_SIZE;
	if (firstGoodBlock != 0xFFFF)
	{
		//if (firstGoodBlock >
		//	GetDeviceArchitecture().numOfBlocks * GetDeviceArchitecture().devicesNumber)
			if (firstGoodBlock >
			4096 * GetDeviceArchitecture().devicesNumber)
		{
			return FAILURE;
		}
	}

	strcpy((char *) bootStruct.bootStructId,"NANDBOOT NANDBOOT NANDBOOT NANDBOOT");

	bootStruct.noOfBadBlocks = GetBBMBadBlocksNumber();


	//calculate the number of pages required to store BBT
//	if ((((GetBBMBadBlocksNumber()) * sizeof(UINT16)) % GetDeviceArchitecture().mainSize) !=
	//	0)
		if ((((GetBBMBadBlocksNumber()) * sizeof(UINT16)) % CHUNK_DATA_SIZE) !=
		0)
	{
		pageNumber = (((GetBBMBadBlocksNumber()) * sizeof(UINT16)) /
			CHUNK_DATA_SIZE) +
			1;
		lastPageSize = (((GetBBMBadBlocksNumber()) * sizeof(UINT16)) %
			CHUNK_DATA_SIZE);
	}
	else
	{
		pageNumber = (((GetBBMBadBlocksNumber()) * sizeof(UINT16)) /
			CHUNK_DATA_SIZE);
	}


	if (GetBBMBadBlocksNumber() != 0)
	{
		//create BBT on ram
		table = (UINT16 *)OS_DRIVER_Malloc(sizeof(UINT16) * GetBBMBadBlocksNumber());
		if (table == NULL)
		{
			return FAILURE;
		}


		//fill the table with list elem
		temp = GetBBMBadBlockList();
		i = 0;
		while (temp != NULL)
		{
			BadBlockElem *t;
			table[i] = temp->blockNumber;
			t = temp;
			temp = temp->next;
			if (t != NULL)
			{
				OS_DRIVER_Free(t);
				t = NULL;
			}
			i++;
		}

		SetBBMBadBlockList(NULL);
	}


	//erase the block selected
	//if there is  a BBT on device

	if (firstGoodBlock == 0xFFFF) /*exsit*/
	{
		UINT8 *buffer;
		UINT32 returnAddress;
		UINT16 lenght;

	//	lenght = GetDeviceArchitecture().pageSize;
	//	buffer = OS_DRIVER_Malloc(GetDeviceArchitecture().pageSize);
		lenght = CHUNK_SIZE;
		buffer = (UINT8 *)OS_DRIVER_Malloc(CHUNK_SIZE);
		if (buffer == NULL)
		{
			return FAILURE;
		}


		//OS_MemSet(buffer,0xFF,GetDeviceArchitecture().pageSize);
		OS_MemSet(buffer,0xFF,CHUNK_SIZE);
		OS_MemCopy(buffer,&bootStruct,sizeof(bootStruct));
		CalculateAddress(GetBBMBootBlockNumber(),0,&returnAddress) ;
		
		if (NAND_BlockErase(returnAddress) != NAND_PASS)
		{
			OS_DRIVER_Free(buffer);
			return FAILURE;
		}
		//write the bootstruct

		//if (NAND_PageProgram(returnAddress,buffer,GetDeviceArchitecture().pageSize) !=
		//	NAND_PASS)
				if (NAND_PageProgram(returnAddress,buffer,CHUNK_SIZE) !=
			NAND_PASS)
		{
			OS_DRIVER_Free(buffer);
			return FAILURE;
		}
		OS_DRIVER_Free(buffer);
	}
	else/*not exsit*/
	{
		//UINT8 *buffer = OS_DRIVER_Malloc(GetDeviceArchitecture().pageSize);
		UINT8 *buffer = (UINT8 *)OS_DRIVER_Malloc(CHUNK_SIZE);

		UINT32 returnAddress;
		UINT16 lenght;

		//lenght = GetDeviceArchitecture().pageSize;
		lenght = CHUNK_SIZE;


		//OS_MemSet(buffer,0xFF,GetDeviceArchitecture().pageSize);
		OS_MemSet(buffer,0xFF,CHUNK_SIZE);
		OS_MemCopy(buffer,&bootStruct,sizeof(bootStruct));

		CalculateAddress(firstGoodBlock,0,&returnAddress);
		
		if (NAND_BlockErase(returnAddress) != NAND_PASS)
		{
			OS_DRIVER_Free(buffer);
			return FAILURE;
		}

		if (NAND_PageProgram(returnAddress,buffer,lenght) != NAND_PASS)
		{
			OS_DRIVER_Free(buffer);
			return FAILURE;
		}
		OS_DRIVER_Free(buffer)	;
		SetBBMBootBlockNumber(firstGoodBlock);
	}


	//write BBT in flash page after page
	for (i = 1; i <= pageNumber; i++)
	{
		UINT16 lenght;
		UINT32 returnAddress;
		//UINT8 *buffer = OS_DRIVER_Malloc(GetDeviceArchitecture().pageSize);
		UINT8 *buffer = (UINT8 *)OS_DRIVER_Malloc(CHUNK_SIZE);
		if (buffer == NULL)
		{
			return FAILURE;
		}

		lenght = CHUNK_SIZE;

		OS_MemSet(buffer,0xFF,CHUNK_SIZE);
		OS_MemCopy(buffer,table,bootStruct.noOfBadBlocks * sizeof(UINT16));

		CalculateAddress(GetBBMBootBlockNumber(),i,&returnAddress) ;
		
		if (NAND_PageProgram(returnAddress,buffer,lenght) != NAND_PASS)
		{
			OS_DRIVER_Free(buffer);
			return FAILURE;
		}

		OS_DRIVER_Free(buffer);
	}



	if (table != NULL)
	{
		OS_DRIVER_Free(table);
		table = NULL;
	}


	return SUCCESS;
}

/*****************  GetBadBlocksNumber ******************************
* Return the number of bad blocks present on flash  	 			*
*   					 											*
*-------------------------------------------------------------------*
*   numOfBadBlocks : containt the number of bad blocks present on 	*
*					 flash  										*
*   return value:  SUCCESS no error is occured     					*
*********************************************************************/

NFTL_Return GetBadBlocksNumber(UINT16 *numOfBadBlocks)
{
	*numOfBadBlocks = GetBBMBadBlocksNumber();
	return SUCCESS;
}


/*****************  GetBadBlocksNumber ******************************
* Save the number of bad blocks present on flash	   			*
*   					 											*
*-------------------------------------------------------------------*
*   numOfBadBlocks : containt the number of bad blocks present on 	*
*					 flash  										*
*   return value:  SUCCESS no error is occured     					*
*********************************************************************/
NFTL_Return SetBadBlocksNumber(UINT16 numOfBadBlocks)
{
	SetBBMBadBlocksNumber(numOfBadBlocks);
	return SUCCESS;
}


NFTL_Return Unmount_BBM()
{
	BadBlockElem *temp;
	/*number of bad block present on device*/
	SetBBMBadBlocksNumber(0);

	/*physical block number of block containing the BBT*/
	SetBBMBootBlockNumber(-1);

	/*pointer to the last elem of bad block list in ram*/
	SetBBMlast(NULL);

	while (GetBBMBadBlockList() != NULL)
	{
		temp = GetBBMBadBlockList();
		SetBBMBadBlockList(GetBBMBadBlockList()->next);
		if (temp != NULL)
		{
			OS_DRIVER_Free(temp);
			temp = NULL;
		}
	}

	return SUCCESS;
}


UINT8 GetBBMBadBlocksNumber()
{
	return BadBlocksNumber;
}
void SetBBMBadBlocksNumber(UINT8 value)
{
	BadBlocksNumber = value;
}

BadBlockElem * GetBBMBadBlockList()
{
	return BadBlockList;
}

void SetBBMBadBlockList(BadBlockElem *value)
{
	BadBlockList = value;
}


BadBlockElem * GetBBMlast()
{
	return last;
}

void SetBBMlast(BadBlockElem *value)
{
	last = value;
}

INT16 GetBBMBootBlockNumber()
{
	return BootBlockNumber;
}
void SetBBMBootBlockNumber(INT16 value)
{
	BootBlockNumber = value;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲午夜激情网页| 91久久精品一区二区二区| 国产福利一区二区三区视频在线| 丰满岳乱妇一区二区三区| 欧美在线视频不卡| 中文字幕免费不卡在线| 青青草成人在线观看| 91视频在线观看免费| 久久综合九色欧美综合狠狠| 亚洲国产精品久久久男人的天堂| 国产精品一区二区免费不卡 | 国产精品国产自产拍在线| 亚洲18色成人| 91麻豆产精品久久久久久| 精品日韩在线一区| 天天射综合影视| 色一情一伦一子一伦一区| 精品播放一区二区| 日韩激情视频网站| 欧美日韩精品一区二区三区 | 91精品福利在线一区二区三区 | 成人网在线播放| 精品毛片乱码1区2区3区| 亚洲福利视频一区二区| 不卡的av中国片| 久久久精品影视| 久久精品国产成人一区二区三区| 欧美日韩亚州综合| 亚洲人妖av一区二区| 丁香天五香天堂综合| 精品日韩av一区二区| 天天影视网天天综合色在线播放| 91福利小视频| 亚洲综合在线第一页| 91丝袜国产在线播放| 1区2区3区精品视频| 成年人午夜久久久| 中文一区一区三区高中清不卡| 99精品国产一区二区三区不卡| 国产婷婷精品av在线| 国产精品1024| 国产蜜臀97一区二区三区 | 日韩一区国产二区欧美三区| 亚洲国产精品一区二区久久恐怖片 | 亚洲视频电影在线| 色国产精品一区在线观看| 亚洲女人小视频在线观看| 91麻豆国产福利精品| 一个色综合av| 欧美一区二区私人影院日本| 青青草视频一区| 日韩一区二区不卡| 国产精品一区三区| 亚洲人成影院在线观看| 欧美在线综合视频| 日本欧美肥老太交大片| 日韩你懂的电影在线观看| 国内精品视频一区二区三区八戒| 久久精品水蜜桃av综合天堂| 成人精品免费看| 亚洲一区二区三区四区在线观看| 欧美电影一区二区三区| 久久国产综合精品| 中日韩免费视频中文字幕| 在线日韩一区二区| 麻豆极品一区二区三区| 国产日韩三级在线| 在线影视一区二区三区| 日本中文字幕一区二区视频| 久久久影视传媒| 色狠狠综合天天综合综合| 蜜桃一区二区三区在线观看| 欧美国产欧美亚州国产日韩mv天天看完整| 99久久综合狠狠综合久久| 五月激情综合色| 国产亚洲欧美日韩在线一区| 91视频在线看| 激情图片小说一区| 一区二区三区中文字幕在线观看| 欧美精品tushy高清| 成人午夜私人影院| 午夜亚洲福利老司机| 国产欧美日韩综合| 51精品视频一区二区三区| 国产成人精品亚洲777人妖| 亚洲成人一区在线| 亚洲国产精品激情在线观看| 欧美妇女性影城| 成人av电影在线| 黄网站免费久久| 亚洲福利国产精品| 欧美国产乱子伦| 欧美tk丨vk视频| 欧美日韩精品三区| 色就色 综合激情| 不卡av在线免费观看| 精品在线免费视频| 午夜国产精品影院在线观看| 最新不卡av在线| 国产女人18毛片水真多成人如厕| 91精品免费观看| 欧美日韩精品二区第二页| av网站免费线看精品| 国产精品99久久久久久久女警| 天堂一区二区在线| 亚洲午夜三级在线| 亚洲欧美激情在线| 中文字幕一区二区三区色视频 | 久久精品视频在线免费观看| 欧美久久一二区| 欧美日韩在线三区| 91丨九色丨尤物| av电影在线观看不卡| 成人中文字幕电影| 国产91丝袜在线18| 国产高清不卡一区| 国产成人免费在线| 国产夫妻精品视频| 国产美女主播视频一区| 韩日精品视频一区| 国产专区欧美精品| 黄色精品一二区| 国产精品一级二级三级| 国产一区二区主播在线| 狠狠色丁香婷婷综合| 国产精品一区专区| 成人精品免费网站| 91浏览器打开| 91黄色在线观看| 欧美日韩一区二区电影| 欧美日韩国产首页| 欧美一级免费观看| 久久综合九色综合97_久久久| 欧美精品一区二区三区蜜桃视频| 精品福利在线导航| 国产欧美1区2区3区| 中文字幕精品在线不卡| 亚洲欧洲国产日本综合| 一区二区三区在线观看国产 | 成人激情电影免费在线观看| 成人午夜在线视频| 色婷婷久久久久swag精品| 欧美亚日韩国产aⅴ精品中极品| 欧美色综合影院| 欧美不卡123| 亚洲一区二区视频| 日本视频中文字幕一区二区三区| 免费在线观看日韩欧美| 国产91色综合久久免费分享| 色综合久久久久网| 91精品国产91久久久久久一区二区 | 菠萝蜜视频在线观看一区| 日本韩国精品在线| 欧美一区二区三区啪啪| 国产日韩成人精品| 一区二区三区日本| 韩国三级电影一区二区| 91视频免费播放| 日韩一区二区视频| 日韩一区有码在线| 日本伊人午夜精品| 不卡一区二区中文字幕| 欧美精品在线一区二区| 国产午夜精品久久久久久久 | 国产在线乱码一区二区三区| 97aⅴ精品视频一二三区| 欧美一区二区三区视频在线| 国产精品女人毛片| 日韩成人dvd| 97se狠狠狠综合亚洲狠狠| 日韩一区和二区| 亚洲欧美视频在线观看视频| 六月丁香婷婷久久| 欧美性色黄大片| 欧美激情一区二区三区不卡 | 成人污视频在线观看| 91精品国产综合久久香蕉麻豆| 国产精品你懂的| 国产麻豆精品theporn| 欧美美女喷水视频| 亚洲三级电影网站| 国产精品羞羞答答xxdd| 欧美一区二区三区在| 一区二区三区在线影院| av影院午夜一区| 日本一区二区三区高清不卡| 老司机精品视频线观看86| 精品视频在线视频| 亚洲精品国产a| 成人激情图片网| 国产欧美一区二区三区在线老狼| 日本欧美在线看| 欧美日韩小视频| 亚洲老司机在线| 91女厕偷拍女厕偷拍高清| 国产精品乱码久久久久久| 国产乱码精品一区二区三区av | 中文字幕欧美日韩一区| 黄色日韩网站视频| 精品福利一区二区三区 |