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

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

?? s3c6410_fil.c

?? 6410BSP3
?? C
?? 第 1 頁 / 共 5 頁
字號(hào):
	{
        NF_SETREG_8BITECC();
		Write_Spare_Separate(nBank, nPpn, pSpareCxt);
        NF_SETREG_4BITECC();
	}
	else
	{
		Write_Spare(nBank, nPpn, pSpareCxt);
	}
	// Write Confirm
	if(TWO_PLANE_PROGRAM == TRUE32 && !bSecondWrite && bLoopNeed)
	{
		bSecondWrite = TRUE32;
		NF_CMD(CMD_2PLANE_PROGRAM_DUMMY);

		_TRDelay2(0);

		goto _B_SecondWrite;
	}

	NF_CMD(CMD_PROGRAM_CONFIRM);

	// Chip Unselect
	NF_CE_H(nBank);

#ifdef	USE_SETKMODE
	SetKMode(bLastMode);
#endif

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

	return;
}

/*****************************************************************************/
/*                                                                           */
/* NAME                                                                      */
/*      NAND_Write_Steploader	                                             */
/* DESCRIPTION                                                               */
/*      This function writes NAND page area							 		 */
/* PARAMETERS                                                                */
/*      nBank    	[IN] 	Physical device number			               	 */
/*      nPpn     	[IN] 	Physical page number				         	 */
/*      nSctBitmap 	[IN] 	The indicator for the sector to write         	 */
/*      nPlaneBitmap[IN]    The indicator of the plane  					 */
/*      pDBuf		[IN]	Buffer pointer of main area to write          	 */
/*      pSBuf		[IN]	Buffer pointer of spare area to write         	 */
/*																			 */
/* RETURN VALUES                                                             */
/*		None																 */
/* NOTES                                                                     */
/*                                                                           */
/*****************************************************************************/

VOID
NAND_Steploader_Write(UINT32 nBank, UINT32 nPpn, UINT32 nSctBitmap,
			UINT32  nPlaneBitmap, UINT8* pDBuf, UINT8* pSBuf)
{
	UINT32 nCnt;
	UINT32 nPbn;
	UINT32 nPOffset;
	UINT32 i;

	//BOOL32	bFirstWrite = TRUE32;
	BOOL32	bSecondWrite = FALSE32;
	BOOL32  bLoopNeed = FALSE32;

	SECCInfo tSECCInfo;


#ifdef	USE_SETKMODE
	BOOL bLastMode;
#endif

	NAND_MSG((_T("[FIL] ++NAND_Write(%d, %d, 0x%02x, 0x%02x)\r\n"), nBank, nPpn, nSctBitmap, nPlaneBitmap));
	if (nBank >= BANKS_TOTAL || nPpn >= PAGES_PER_BANK || (pDBuf == NULL && pSBuf == NULL))
	{
		NAND_ERR((_T("[FIL:ERR]--NAND_Write() : Parameter Overflow\r\n")));
		WMR_ASSERT(FALSE32);
		return;
	}


#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)
		{
			bLoopNeed = TRUE32;
		}
		else if (nPlaneBitmap == enuRIGHT_PLANE_BITMAP)
		{
			nPpn += PAGES_PER_BLOCK;
			//nSctBitmap = nSctBitmap>>4;
		}
	}

	nSctBitmap &= FULL_SECTOR_BITMAP_PAGE;

#ifdef	USE_SETKMODE
	bLastMode = SetKMode(TRUE);
#endif

	pNANDFConReg->NFCONF = (pNANDFConReg->NFCONF & ~((1<<30)|(3<<23))) | (1<<23) | NF_TACLS(DEFAULT_TACLS) | NF_TWRPH0(DEFAULT_TWRPH0) | NF_TWRPH1(DEFAULT_TWRPH1); // System Clock is more than 66Mhz, ECC type is MLC.
	pNANDFConReg->NFCONT |= (1<<18)|(1<<13)|(1<<12)|(1<<11)|(1<<10)|(1<<9); //ECC for programming.// Enable RnB Interrupt 
	pNANDFConReg->NFSTAT |= ((1<<6)|(1<<5)|(1<<4));

	// CE Select
	NF_CE_L(nBank);
	
	NF_CMD(CMD_PROGRAM);
	NF_SET_ADDR(nPpn, 0);

	WMR_MEMSET(&tSECCInfo, 0xFF, 53);		// Initialize the spare buffer
	// Write Main Sector
	if (pDBuf != NULL)
	{
		for (nCnt=0; nCnt<SECTORS_PER_PAGE; nCnt++)
		{
			NF_MECC_UnLock();
			NF_MECC_Reset();

			if ((UINT32)pDBuf&0x3)
			{
				_Write_512Byte_Unaligned(pDBuf+NAND_SECTOR_SIZE*nCnt);
			}
			else
			{
				_Write_512Byte(pDBuf+NAND_SECTOR_SIZE*nCnt);
			}

			NF_MECC_Lock();

			while(!(pNANDFConReg->NFSTAT&(1<<7))) ;
			pNANDFConReg->NFSTAT|=(1<<7);

			tSECCInfo.t8MECC[nCnt].n8MECC0 = NF_8MECC0();
			tSECCInfo.t8MECC[nCnt].n8MECC1 = NF_8MECC1();
			tSECCInfo.t8MECC[nCnt].n8MECC2 = NF_8MECC2();
			tSECCInfo.t8MECC[nCnt].n8MECC3 = (NF_8MECC3() & 0xff);
		}

		
	}

//	NF_DATA_W(tSECCInfo.nBadBlock); // 1 byte n8MECC3 ==> bad block marker

	for(i = 0; i < SECTORS_PER_PAGE; i++) {
		NF_DATA_W4(tSECCInfo.t8MECC[i].n8MECC0); // 4 byte n8MECC0
		NF_DATA_W4(tSECCInfo.t8MECC[i].n8MECC1); // 4 byte n8MECC1
		NF_DATA_W4(tSECCInfo.t8MECC[i].n8MECC2); // 4 byte n8MECC2
		NF_DATA_W((tSECCInfo.t8MECC[i].n8MECC3) & 0xff); // 1 byte n8MECC3
	}

	pNANDFConReg->NFSTAT |=  (1<<4); //NF_CLEAR_RB
	NF_CMD(CMD_PROGRAM_CONFIRM);

//	NF_DETECT_RB();
	NF_WAIT_RnB(nBank);

	NF_CMD(CMD_READ_STATUS);   // Read status command       

	for(i=0;i<3;i++);  //twhr=60ns
    
   	 if (NF_DATA_R()&NAND_STATUS_ERROR) 
    	{// Page write error
		NF_CE_H(nBank);
		RETAILMSG(1,(TEXT("##### Error write operation #####\r\n")));
		pNANDFConReg->NFCONF = NF_4BIT_ECC | NF_TACLS(DEFAULT_TACLS) | NF_TWRPH0(DEFAULT_TWRPH0) | NF_TWRPH1(DEFAULT_TWRPH1);
		return;
	} 
	else
	{
		NF_CE_H(nBank);
		pNANDFConReg->NFCONF = NF_4BIT_ECC | NF_TACLS(DEFAULT_TACLS) | NF_TWRPH0(DEFAULT_TWRPH0) | NF_TWRPH1(DEFAULT_TWRPH1);
		return;
	}
}

/*****************************************************************************/
/*                                                                           */
/* NAME                                                                      */
/*      NAND_Erase		                                                     */
/* DESCRIPTION                                                               */
/*      This function erases NAND block area						 		 */
/* PARAMETERS                                                                */
/*      nBank    	[IN] 	Physical device number			               	 */
/*      nPpn     	[IN] 	Physical page number				         	 */
/*      nPlaneBitmap[IN]    The indicator of the plane  					 */
/*																			 */
/* RETURN VALUES                                                             */
/*		None																 */
/* NOTES                                                                     */
/*                                                                           */
/*****************************************************************************/
VOID
NAND_Erase (UINT32 nBank, UINT32 nPbn, UINT32 nPlaneBitmap)
{
	UINT32	nVBank;
	UINT32	nPageAddr;
	UINT32 	nPairBank;
	UINT32  nSyncRet;

	BOOL32	bSecondErase = FALSE32;
	BOOL32	bLoopNeed = FALSE32;


#ifdef	USE_SETKMODE
	BOOL bLastMode;
#endif

	NAND_MSG((_T("[FIL]++NAND_Erase(%d, %d, 0x%02x)\r\n"), nBank, nPbn, nPlaneBitmap));
//	NAND_ERR((_T("[FIL]++NAND_Erase(%d, %d, 0x%02x)\r\n"), nBank, nPbn, nPlaneBitmap));

	if (nBank >= BANKS_TOTAL || nPbn >= BLOCKS_PER_BANK)
	{
    	NAND_ERR((_T("[FIL]++NAND_Erase(%d, %d, 0x%02x)\r\n"), nBank, nPbn, nPlaneBitmap));
		NAND_ERR((_T("[FIL:ERR]--NAND_Erase() : Parameter overflow\r\n")));
		WMR_ASSERT(FALSE32);
		return;
	}

	nVBank = nBank;

	// 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)
		{
			nPbn += BLOCKS_PER_BANK;
		}
		nBank /= 2;
	}

	if (TWO_PLANE_PROGRAM == TRUE32)
	{
		if (nPlaneBitmap == enuBOTH_PLANE_BITMAP)
		{
			bLoopNeed = TRUE32;
		}
		else if (nPlaneBitmap == enuRIGHT_PLANE_BITMAP)
		{
			bSecondErase = TRUE32;
		}
	}

	nPbn = nPbn*(1+(TWO_PLANE_PROGRAM == TRUE32));

	/* 
	   In the Internal Interleaving, it's forbidden NAND to do Write operation & the other operation
	   at the same time. When Write is going on in Bank 1, Bank 0 has to wait to finish 
	   the operation of Bank 1 if the next operation is not Write.

	   While Bank 1 is erased, Bank 0 do not start Write operation. (But, Erase or Read is allowed)
	   Internal Interleaving concept is only existed between Write and Write.	   
	*/
	if (bInternalInterleaving == TRUE32)
	{
		NAND_Sync(nVBank, &nSyncRet);

		// TODO: what does this means???
#if	1
		NF_CE_L(nBank);
		NF_CMD(CMD_READ);
		NF_CE_H(nBank);
#endif

		NAND_Sync(nPairBank, &nSyncRet);

		aNeedSync[nVBank] = TRUE32;
	}

#ifdef	USE_SETKMODE
	bLastMode = SetKMode(TRUE);
#endif

	// Chip Select
	NF_CE_L(nBank);

_B_SecondErase:

	if(bSecondErase)
	{
		nPbn++;
	}

	// Calculate Row Address of the Block (128 page/block)
	nPageAddr = (nPbn << (6 + IS_MLC));

	// Erase Command
	NF_CMD(CMD_ERASE);

	// Write Row Address
	NF_ADDR(nPageAddr&0xff);
	NF_ADDR((nPageAddr>>8)&0xff);
	NF_ADDR((nPageAddr>>16)&0xff);

	if (TWO_PLANE_PROGRAM == TRUE32 && !bSecondErase && bLoopNeed)
	{
		bSecondErase = TRUE32;
		goto _B_SecondErase;
	}

	// Erase confirm command
	NF_CMD( CMD_ERASE_CONFIRM);

	// Chip Unselect
	NF_CE_H(nBank);

#ifdef	USE_SETKMODE
	SetKMode(bLastMode);
#endif

	/* In the Internal Interleaving, it's forbidden NAND to do Write operation & the other operation
	   at the same time. When Write is going on in Bank 1, Bank 0 has to wait to finish 
	   the operation of Bank 1 if the next operation is not Write.

	   While Bank 1 is erased, Bank 0 do not start Write operation. (But, Erase or Read is allowed)
	   Internal Interleaving concept is only existed between Write and Write.	   
	*/
	if (bInternalInterleaving == TRUE32)
	{
		NAND_Sync(nVBank, &nSyncRet);
	}

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

	return;
}


/*****************************************************************************/
/*                                                                           */
/* NAME                                                                      */
/*      NAND_Sync		                                                     */
/* DESCRIPTION                                                               */
/*      This function checks the R/B signal of NAND					 		 */
/*		When it's busy, it means NAND is under operation.					 */
/*		When it's ready, it means NAND is ready for the next operation.		 */
/* PARAMETERS                                                                */
/*      nBank    	[IN] 	Physical device number			               	 */
/*																			 */
/* RETURN VALUES                                                             */
/*		FIL_CRITICAL_ERROR													 */
/*				When the input value is more than its range					 */
/*				or it has erase fail										 */
/*		FIL_SUCCESS															 */
/*				When the erase operation has done clearly					 */
/* NOTES                                                                     */
/*                                                                           */
/*****************************************************************************/
INT32
NAND_Sync(UINT32 nBank, UINT32 *nPlaneBitmap)
{
	UINT32	nData;
	UINT32	nPairBank;
	UINT32	nVBank;

	INT32	nRet = FIL_SUCCESS;

	BOOL32	bInternalBank = FALSE32;

#ifdef	USE_SETKMODE
	BOOL bLastMode;
#endif

	NAND_MSG((_T("[FIL]++NAND_Sync(%d, %d)\r\n"), nBank, nPlaneBitmap));

	if (nBank >= BANKS_TOTAL)
	{
		NAND_ERR((_T("[FIL:ERR]--NAND_Sync() : Parameter overflow\r\n")));
		WMR_ASSERT(FALSE32);
		return FIL_CRITICAL_ERROR;
	}

	WMR_ASSERT(nPlaneBitmap != NULL);

	nVBank = nBank;

	// avoid r/b check error with internal interleaving
	if (bInternalInterleaving == TRUE32)
	{
		nPairBank = ((nBank & 0x1) == 1) ? (nBank - 1) : (nBank + 1);

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美精品三级在线观看| 91精品1区2区| 欧美剧情片在线观看| 亚洲一区二区影院| 欧美伦理视频网站| 美女高潮久久久| 亚洲精品一区二区三区蜜桃下载| 狠狠色丁香久久婷婷综合丁香| 欧美精品一区二区三区视频| 国产在线不卡一卡二卡三卡四卡| 国产亚洲美州欧州综合国| a亚洲天堂av| 亚洲一区二区成人在线观看| 制服丝袜中文字幕一区| 韩国在线一区二区| 亚洲欧美日韩国产另类专区| 欧美猛男超大videosgay| 激情五月播播久久久精品| 中文一区一区三区高中清不卡| 91同城在线观看| 日韩国产欧美在线视频| 国产偷v国产偷v亚洲高清| 91久久精品日日躁夜夜躁欧美| 日韩成人午夜精品| 欧美国产97人人爽人人喊| 欧洲人成人精品| 国产一区二区三区电影在线观看| 中文字幕中文字幕一区| 制服丝袜亚洲网站| 成人黄色国产精品网站大全在线免费观看 | 久久99日本精品| 中文字幕免费一区| 在线电影院国产精品| 大胆欧美人体老妇| 日本aⅴ亚洲精品中文乱码| 国产欧美日韩亚州综合| 欧美日韩三级一区二区| 丁香亚洲综合激情啪啪综合| 婷婷激情综合网| 国产精品福利在线播放| 日韩一区二区三区电影| 色狠狠一区二区三区香蕉| 黄网站免费久久| 性久久久久久久久| 国产精品久久久久影院色老大 | 欧美精品视频www在线观看| 国产成人在线视频网址| 首页国产欧美日韩丝袜| 亚洲视频在线一区| 久久久久97国产精华液好用吗| 欧美三级视频在线播放| 99热精品一区二区| 国产成人在线观看| 老司机精品视频在线| 无码av中文一区二区三区桃花岛| 国产精品久久777777| 久久一区二区视频| 91精品国产色综合久久不卡蜜臀 | 99精品久久免费看蜜臀剧情介绍| 久久99久久99| 蜜桃av一区二区| 亚洲国产精品久久久久秋霞影院 | 亚洲综合清纯丝袜自拍| 国产精品无圣光一区二区| 精品国产一区二区三区四区四| 欧美高清性hdvideosex| 欧美在线视频日韩| 在线观看国产精品网站| 99国产精品99久久久久久| 成av人片一区二区| 不卡的av电影| av午夜一区麻豆| 成人免费观看av| 国产成人精品亚洲午夜麻豆| 韩国成人精品a∨在线观看| 老司机午夜精品| 久久99精品久久久久| 久久99精品一区二区三区| 美美哒免费高清在线观看视频一区二区| 亚洲成人自拍一区| 性欧美大战久久久久久久久| 五月综合激情网| 日本在线观看不卡视频| 麻豆精品一二三| 国产乱色国产精品免费视频| 国产一区不卡精品| 高清在线成人网| 91视频在线观看| 在线一区二区视频| 欧美日韩国产一级| 欧美电影免费观看高清完整版在线| 欧美一区二区国产| 久久―日本道色综合久久| 久久精品欧美日韩| 亚洲欧洲精品成人久久奇米网| 亚洲色图19p| 亚洲成a人v欧美综合天堂下载| 日韩精品久久久久久| 韩国在线一区二区| fc2成人免费人成在线观看播放 | 欧美日韩一卡二卡三卡| 欧美精品 日韩| 久久亚洲一级片| 中文字幕欧美一区| 五月婷婷综合激情| 精品制服美女久久| av网站免费线看精品| 欧美午夜精品一区二区三区| 欧美一区二区三区精品| 久久久国产一区二区三区四区小说| 国产精品久久久久久户外露出| 一区二区欧美在线观看| 另类小说一区二区三区| 暴力调教一区二区三区| 欧美精品乱码久久久久久按摩| 久久综合色鬼综合色| 亚洲精品国产品国语在线app| 免费在线视频一区| eeuss鲁一区二区三区| 欧美一区二区在线视频| 国产拍揄自揄精品视频麻豆| 亚洲国产日韩a在线播放性色| 激情五月婷婷综合网| 91久久免费观看| 国产欧美视频一区二区| 亚洲成人免费在线| 成人av免费观看| 日韩欧美国产三级| 夜夜嗨av一区二区三区| 国产麻豆视频一区二区| 欧美精品一卡两卡| 日韩一区在线播放| 国内精品国产成人国产三级粉色| 91久久香蕉国产日韩欧美9色| 久久精品夜色噜噜亚洲a∨| 亚洲成人午夜电影| 99re这里只有精品首页| 亚洲精品一区二区三区在线观看| 亚洲自拍偷拍麻豆| 成人福利视频网站| 久久综合久色欧美综合狠狠| 亚洲成人综合视频| 色八戒一区二区三区| 国产欧美日韩三区| 经典三级一区二区| 欧美一区二区在线不卡| 亚洲国产一区二区三区| 国产拍揄自揄精品视频麻豆| 免费在线一区观看| 欧美精品自拍偷拍动漫精品| 亚洲日本va午夜在线电影| 国产黑丝在线一区二区三区| 日韩一区二区免费高清| 亚洲成人av资源| 欧美中文字幕亚洲一区二区va在线| 国产区在线观看成人精品| 久久99精品久久久久婷婷| 欧美二区三区的天堂| 亚洲午夜羞羞片| 91福利在线看| 一区二区三区四区不卡在线 | 亚洲欧美日韩一区二区三区在线观看| 国产精品一区二区久久精品爱涩 | 在线观看91视频| 一区二区三区在线观看动漫| 色婷婷综合激情| 成人欧美一区二区三区在线播放| 国产91精品一区二区麻豆网站| 久久综合九色综合欧美亚洲| 极品美女销魂一区二区三区| 欧美成人激情免费网| 蜜臀av一区二区在线观看| 欧美一三区三区四区免费在线看 | 亚洲国产精品久久一线不卡| 在线欧美小视频| 亚洲主播在线观看| 欧美日韩一级大片网址| 天堂成人免费av电影一区| 3d成人动漫网站| 国模冰冰炮一区二区| 国产日韩高清在线| 91麻豆swag| 亚洲国产aⅴ成人精品无吗| 91精品国产手机| 国产精品影视在线| 国产精品不卡在线观看| 日本黄色一区二区| 日本一道高清亚洲日美韩| 精品捆绑美女sm三区| 成人免费看黄yyy456| 亚洲已满18点击进入久久| 91精品国产一区二区人妖| 国产高清视频一区| 亚洲人精品一区| 91精品国产色综合久久不卡蜜臀| 国产精品一区二区在线观看网站| 中文字幕一区不卡| 91麻豆精品国产91久久久使用方法| 激情综合一区二区三区| 亚洲色图都市小说|