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

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

?? nand.c

?? 三星給予ARM920T內核的S3C2413的demo版本
?? C
?? 第 1 頁 / 共 3 頁
字號:
	NF_CMD(0x10);	 // Write 2nd command
	NF_DETECT_RB();

	NF_CMD(0x70);   // Read status command   
    
	for(i=0;i<3;i++);  //twhr=60ns
     
    if (NF_RDDATA()&0x1) {// Page write error
    	
		printf("[PROGRAM_ERROR:block#=%d]\n",block);
		NF8_MarkBadBlock(block);
		 NF_nFCE_H();
		return FAIL;
    } else {
    	   NF_nFCE_H();
	  return OK;
	   
	}
*/

       NF_MECC_Lock();
	// Get ECC data.
	// Spare data for 8bit
	// byte  0     1    2     3     4          5               6      7            8         9
	// ecc  [0]  [1]  [2]  [3]    x   [Bad marking]                    SECC0  SECC1
	Mecc = rNFMECC0;
	se8Buf[0]=(U8)(Mecc&0xff);
	se8Buf[1]=(U8)((Mecc>>8) & 0xff);
	se8Buf[2]=(U8)((Mecc>>16) & 0xff);
	se8Buf[3]=(U8)((Mecc>>24) & 0xff);
	se8Buf[5]=0xff;		// Marking good block

	NF_SECC_UnLock();
	//Write extra data(ECC, bad marking)
	for(i=0;i<4;i++) {
		NF_WRDATA8(se8Buf[i]);	// Write spare array(Main ECC)
		NF8_Spare_Data[i]=se8Buf[i];
    	}  
      NF_SECC_Lock(); 
	Secc=rNFSECC; 
	se8Buf[8]=(U8)(Secc&0xff);
	se8Buf[9]=(U8)((Secc>>8) & 0xff);
	for(i=4;i<16;i++) {
		NF_WRDATA8(se8Buf[i]);  // Write spare array(Spare ECC and Mark)
		NF8_Spare_Data[i]=se8Buf[i];
	}  
 	NF_CLEAR_RB();
	NF_CMD(0x10);	 // Write 2nd command
//	NF_DETECT_RB();
	while(NFConDone==0);
	 rNFCONT&=~(1<<9);
	 rNFCONT&=~(1<<10); // Disable Illegal Access Interrupt
	 if(rNFSTAT&0x20) return FAIL;

	NF_CMD(0x70);   // Read status command   
    
	for(i=0;i<3;i++);  //twhr=60ns
    
       if (NF_RDDATA()&0x1) {// Page write error
    	       NF_nFCE_H();
		printf("[PROGRAM_ERROR:block#=%d]\n",block);
		NF8_MarkBadBlock(block);
		return FAIL;
       } else {
    	      NF_nFCE_H();
	      return OK;
	}

}


static U16 NF8_CheckId(void)
{
    int i;
	U16 id, id4th;
    
	NF_nFCE_L();
    NF_CMD(0x90);
	NF_ADDR(0x0);
	for (i=0; i<10; i++);
	printf("NFSTAT: 0x%x\n", rNFSTAT);
    id=NF_RDDATA8()<<8;	// Maker code 0xec
    id|=NF_RDDATA8();	// Devide code(K9S1208V:0x76), (K9K2G16U0M:0xca)

	NF_nFCE_H();
       return id;
}


void Nand_Reset(void)
{
    int i;
   
	NF_nFCE_L();

	NF_CLEAR_RB();
	NF_CMD(0xFF);	//reset command
	for(i=0;i<10;i++);  //tWB = 100ns. //??????
	NF_DETECT_RB();
	
	NF_nFCE_H();

}

static void NF8_Init(void)
{
	// for S3C2413

	rNFCONF = (TACLS<<12)|(TWRPH0<<8)|(TWRPH1<<4)|(0<<0);	
	// TACLS		[14:12]	CLE&ALE duration = HCLK*TACLS.
	// TWRPH0		[10:8]	TWRPH0 duration = HCLK*(TWRPH0+1)
	// TWRPH1		[6:4]	TWRPH1 duration = HCLK*(TWRPH1+1)
	// AdvFlash(R)	[3]		Advanced NAND, 0:256/512, 1:1024/2048
	// PageSize(R)	[2]		NAND memory page size
	//						when [3]==0, 0:256, 1:512 bytes/page.
	//						when [3]==1, 0:1024, 1:2048 bytes/page.
	// AddrCycle(R)	[1]		NAND flash addr size
	//						when [3]==0, 0:3-addr, 1:4-addr.
	//						when [3]==1, 0:4-addr, 1:5-addr.
	// BusWidth(R/W) [0]	NAND bus width. 0:8-bit, 1:16-bit.
	
	//rNFCONT = (0<<17)|(0<<16)|(0<<10)|(0<<9)|(0<<8)|(1<<7)|(1<<6)|(1<<5)|(1<<4)|(1<<1)|(1<<0);
	rNFCONT = (0<<17)|(0<<16)|(0<<10)|(0<<9)|(0<<8)|(1<<7)|(1<<6)|(1<<5)|(1<<4)|(0x3<<1)|(1<<0);
	// Lock-tight	[17]	0:Disable lock, 1:Enable lock.
	// Soft Lock	[16]	0:Disable lock, 1:Enable lock.
	// EnablillegalAcINT[10]	Illegal access interupt control. 0:Disable, 1:Enable
	// EnbRnBINT	[9]		RnB interrupt. 0:Disable, 1:Enable
	// RnB_TrandMode[8]		RnB transition detection config. 0:Low to High, 1:High to Low
	// SpareECCLock	[7]		0:Unlock, 1:Lock
	// MainECCLock	[6]		0:Unlock, 1:Lock
	// InitMECC(W)	[5]		1:Init main area ECC decoder/encoder.
	// InitSECC(W)	[4]		1:Init spare area ECC decoder/encoder.
	// Reg_nCE1		[2]		0:nFCE=0, 1:nFCE=1.
	// Reg_nCE0		[1]		0:nFCE=0, 1:nFCE=1.
	// NANDC Enable	[0]		operating mode. 0:Disable, 1:Enable.

//	rNFSTAT = 0;
    
//    Nand_Reset();
}


void Test_MLC_ECC(void)
{
    int i;
    U32 block, page;
	U32 blockPage, Mecc0, Mecc1, Secc;
	//U8 *bufPt=buffer;
	U8 *bufPt;
	
	bufPt=(unsigned char *)0x31100000;

	NFConDone=0;
	
	rNFCONF = (rNFCONF & ~(1<<30))|(1<<24); // System Clock is more than 66Mhz, ECC type is MLC.
	rNFCONT |= (1<<18); //ECC for programming.
	
    rNFCONT|=(1<<9); // Enable RnB Interrupt 
    rNFCONT|=(1<<10); // Enable Illegal Access Interrupt
    
    pISR_NFCON= (unsigned)NFCon_Int;
    rSRCPND=BIT_NFCON;
    rINTMSK=~(BIT_NFCON);
	  
	NF_RSTECC();    // Initialize ECC
    NF_MECC_UnLock();
    
    /////////////////////////////////////////////////
    // block1, page0 writing with valid data, ecc   /
    /////////////////////////////////////////////////
    
    block=1;
    page=0;
    
	blockPage=(block<<5)+page;

	NF_nFCE_L(); 
	NF_CMD(0x0);//??????
	NF_CMD(0x80);   // Write 1st command
	NF_ADDR(0);			    // Column 0
	NF_ADDR(blockPage&0xff);	    //
	NF_ADDR((blockPage>>8)&0xff);   // Block & page num.
	NF_ADDR((blockPage>>16)&0xff);  //

	//NF_RSTECC();    // Initialize ECC
	
   
	for(i=0;i<512;i++) {
		NF_WRDATA8(i);	// Write one page to NFM from buffer
    }
	


    //NF_MECC_Lock();
	// Get ECC data.
	// Spare data for 8bit
	// byte  0     1    2     3    4     5     6     7      8      9
	// ecc  [0]  [1]  [2]  [3]    [4]   [5]   [6]                    
	Mecc0 = rNFMECC0;
	Mecc1 = rNFMECC1;
	
	se8Buf[0]=(U8)(Mecc0&0xff);
	se8Buf[1]=(U8)((Mecc0>>8) & 0xff);
	se8Buf[2]=(U8)((Mecc0>>16) & 0xff);
	se8Buf[3]=(U8)((Mecc0>>24) & 0xff);
	se8Buf[4]=(U8)(Mecc1&0xff);
	se8Buf[5]=(U8)((Mecc1>>8) & 0xff);
	se8Buf[6]=(U8)((Mecc1>>16) & 0xff);
	
	
	for(i=0;i<7;i++) {
		NF_WRDATA8(se8Buf[i]);	// Write spare array(Main ECC)
		NF8_Spare_Data[i]=se8Buf[i];
    }
      
    
	for(i=7;i<16;i++) {
		NF_WRDATA8(se8Buf[i]);  // Write spare array(Spare ECC and Mark)
		NF8_Spare_Data[i]=se8Buf[i];
	}  
	
	while(!(rNFSTAT&(1<<7))) ;
		
 	NF_CLEAR_RB();
	NF_CMD(0x10);	 // Write 2nd command
	NF_DETECT_RB();
//	while(NFConDone==0);
	rNFCONT&=~(1<<9);
	rNFCONT&=~(1<<10); // Disable Illegal Access Interrupt
	if(rNFSTAT&0x20) 
	{
		printf("Error\n"); 
		return;	
	}

	NF_CMD(0x70);   // Read status command   
    
	for(i=0;i<3;i++);  //twhr=60ns
    
    if (NF_RDDATA8()&0x1) {// Page write error
    	NF_nFCE_H();
		printf("first[PROGRAM_ERROR:block#=%d]\n",block);
		NF8_MarkBadBlock(block);
		return;
    } else {
    	NF_nFCE_H();
	}
	
	/////////////////////////////////////////////////
    // block1, page1 writing with invalid data, ecc /
    /////////////////////////////////////////////////
    
    NFConDone=0;
    rSRCPND=BIT_NFCON;
    rINTMSK=~(BIT_NFCON);
        
    NF_RSTECC();    // Initialize ECC
    NF_MECC_UnLock();
    
	block=1;
    page=1;
    
	blockPage=(block<<5)+page;

	NF_nFCE_L(); 
	NF_CMD(0x0);//??????
	NF_CMD(0x80);   // Write 1st command
	NF_ADDR(0);			    // Column 0
	NF_ADDR(blockPage&0xff);	    //
	NF_ADDR((blockPage>>8)&0xff);   // Block & page num.
	NF_ADDR((blockPage>>16)&0xff);  //

    //NF_RSTECC();    // Initialize ECC

#if 1 //1-bit Error
	for(i=0;i<512;i++) {
		if(i==511) {
			NF_WRDATA8(254);
		}
		else {
			NF_WRDATA8(i);
		}		
	}
#elif 0 //2-bit Error
	for(i=0;i<512;i++) {
		if(i==0) {
			NF_WRDATA8(1);
		}
		else if(i==1) {
			NF_WRDATA8(0);
		}								
		else {
			NF_WRDATA8(i);
		}		
	}
#elif 0	//3-bit Error
	for(i=0;i<512;i++) {
		if(i==10) {
			NF_WRDATA8(11);
		}
		else if(i==11) {
			NF_WRDATA8(10);
		}			
		else if(i==128)	{
			NF_WRDATA8(129);
		}					
		else {
			NF_WRDATA8(i);
		}
	}	
#elif 0  // 4-bit Error  
	for(i=0;i<512;i++) {
		if(i==10) {
			NF_WRDATA8(11);
		}
		else if(i==11) {
			NF_WRDATA8(10);
		}			
		else if(i==128) {
			NF_WRDATA8(129);
		}			
		else if(i==129) {
			NF_WRDATA8(128);
		}			
		else {
			NF_WRDATA8(i);
		}		
	}
#endif			
    
    
    //NF_MECC_Lock();
	// Get ECC data.
	// Spare data for 8bit
	// byte  0     1    2     3    4     5     6     7      8      9
	// ecc  [0]  [1]  [2]  [3]    [4]   [5]   [6]                    
	/*
	Mecc0 = rNFMECC0;
	Mecc1 = rNFMECC1;
	se8Buf[0]=(U8)(Mecc0&0xff);
	se8Buf[1]=(U8)((Mecc0>>8) & 0xff);
	se8Buf[2]=(U8)((Mecc0>>16) & 0xff);
	se8Buf[3]=(U8)((Mecc0>>24) & 0xff);
	se8Buf[4]=(U8)(Mecc1&0xff);
	se8Buf[5]=(U8)((Mecc1>>8) & 0xff);
	se8Buf[6]=(U8)((Mecc1>>16) & 0xff);*/

	Mecc0 = rNFMECC0;
	Mecc1 = rNFMECC1;
	

	for(i=0;i<7;i++) {
		NF_WRDATA8(se8Buf[i]);	// Write spare array(Main ECC)
		NF8_Spare_Data[i]=se8Buf[i];
    }
      
    NF_SECC_Lock(); 

	for(i=7;i<16;i++) {
		NF_WRDATA8(se8Buf[i]);  // Write spare array(Spare ECC and Mark)
		NF8_Spare_Data[i]=se8Buf[i];
	}  
	
   	while(!(rNFSTAT&(1<<7))); // Wait until 4-bit ECC encoding is completed.
   	
   		
 	NF_CLEAR_RB();
	NF_CMD(0x10);	 // Write 2nd command
	NF_DETECT_RB();
	//while(NFConDone==0);
	rNFCONT&=~(1<<9);
	rNFCONT&=~(1<<10); // Disable Illegal Access Interrupt
	if(rNFSTAT&0x20)	{
		printf("Error\n"); 
		return;	
	}

	NF_CMD(0x70);   // Read status command   
    
	for(i=0;i<30;i++);  //twhr=60ns
    
    if (NF_RDDATA8()&0x1) {// Page write error
    	NF_nFCE_H();
		printf("Second[PROGRAM_ERROR:block#=%d]\n",block);
		NF8_MarkBadBlock(block);
		return;
    } else {
    	NF_nFCE_H();		
	}
	

	/////////////////////////////////////////////////
    // block1, page1 reading with invalid data, ecc /
    /////////////////////////////////////////////////


	block=1;
	page=1;
    blockPage=(block<<5)+page;
    
	rNFCONF = (rNFCONF & ~(1<<30))|(1<<24); // System Clock is more than 66Mhz, ECC type is MLC.
	rNFCONT &= ~(1<<18); //ECC for reading.
	    
	NF_RSTECC();    // Initialize ECC
	NF_MECC_UnLock();
    
	NF_nFCE_L();    

	NF_CLEAR_RB();
	NF_CMD(0x00);	// Read command
	NF_ADDR(0); 	// Column = 0
	NF_ADDR(blockPage&0xff);		//
	NF_ADDR((blockPage>>8)&0xff);	// Block & Page num.
	NF_ADDR((blockPage>>16)&0xff);	//
	NF_DETECT_RB();
	 
   
    for(i=0;i<512;i++) {
    	*bufPt++=NF_RDDATA8();	// Read one page
    }
    
    for(i=0; i<7; i++) 
    {
    	*bufPt++=NF_RDDATA8();
    }
   
	while(!(rNFSTAT&(1<<6))); //wait until 4-bit ECC decoding is completed.
	
	rNFSTAT |= (1<<6);

	NF_nFCE_H();    

	 if ((rNFECCERR0&(0x7<<26)) == 0x0){
	       printf("ECC OK!\n");
		return;
	 }
	 else {
		printf("ECC FAIL!\n");
		printf("status0:0x%x|status1:0x%x|bit:0x%x\n", rNFECCERR0, rNFECCERR1, rNFMLCBITPT);
	    return;
	 }

	
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91国偷自产一区二区使用方法| 一区二区三区免费网站| 麻豆成人综合网| 欧美日韩高清一区二区| 日韩福利视频网| 久久久噜噜噜久久人人看| 国产精品影音先锋| 国产精品久久久久永久免费观看 | 欧美人动与zoxxxx乱| 亚洲一二三区视频在线观看| 欧美日韩日日骚| 激情文学综合丁香| 国产精品午夜春色av| 欧美中文一区二区三区| 蜜臀av性久久久久蜜臀aⅴ四虎| 欧美sm美女调教| www.久久精品| 日本视频在线一区| 国产精品三级电影| 欧美精品电影在线播放| 成人一区二区在线观看| 国产精品福利一区| 欧美人与禽zozo性伦| 国产综合色精品一区二区三区| 中文字幕国产一区二区| 欧美疯狂做受xxxx富婆| 粉嫩绯色av一区二区在线观看| 亚洲综合久久久久| 久久久综合精品| 欧美午夜精品免费| 国产99久久久国产精品免费看| 亚洲人亚洲人成电影网站色| 欧美区一区二区三区| 国产成人亚洲综合a∨婷婷| 亚洲成人1区2区| 国产精品久久久久久久蜜臀| 91麻豆精品国产91久久久久久久久 | 99精品黄色片免费大全| 日韩国产成人精品| 亚洲老妇xxxxxx| 精品粉嫩超白一线天av| 在线观看国产91| 成人免费av在线| 青青草97国产精品免费观看无弹窗版| 亚洲欧洲av在线| 欧美mv日韩mv| 欧美理论在线播放| 一本色道久久综合精品竹菊| 国产一本一道久久香蕉| 日本一道高清亚洲日美韩| 亚洲色图欧美在线| 国产精品久久久久一区二区三区共| 欧美久久一区二区| 色综合久久久久综合体桃花网| 久久国产欧美日韩精品| 亚洲综合色视频| 亚洲欧美一区二区久久| 亚洲国产精品ⅴa在线观看| 精品少妇一区二区三区日产乱码 | 中文字幕在线免费不卡| 久久亚洲一区二区三区四区| 欧美一级高清大全免费观看| 欧美自拍偷拍午夜视频| 99re热视频精品| 岛国av在线一区| 成人黄动漫网站免费app| 国产在线视视频有精品| 午夜精品123| 五月激情六月综合| 亚洲成人一区在线| 亚洲国产精品一区二区尤物区| 亚洲三级小视频| 一区二区在线观看不卡| 亚洲女人****多毛耸耸8| 中文字幕日韩av资源站| 中文字幕一区二区三区视频 | 中文字幕一区二区三区在线播放 | 精品入口麻豆88视频| 日韩免费看的电影| 精品日韩在线观看| 久久久国产精华| 国产精品免费观看视频| 国产精品美女久久久久aⅴ国产馆| 国产精品久久免费看| 一区精品在线播放| 亚洲精品国产精华液| 夜夜夜精品看看| 午夜电影一区二区| 久久超碰97中文字幕| 国产精品一级在线| 成人av小说网| 欧美伊人久久大香线蕉综合69| 欧美在线免费观看视频| 91精品国产高清一区二区三区蜜臀| 69堂亚洲精品首页| 精品成人佐山爱一区二区| 国产精品污污网站在线观看| 专区另类欧美日韩| 天天做天天摸天天爽国产一区| 美国欧美日韩国产在线播放| 国产91综合网| 在线视频观看一区| 日韩一区二区视频| 国产精品视频免费看| 一区二区日韩电影| 久久se精品一区精品二区| 成人小视频在线| 欧美日韩综合色| 国产亚洲综合av| 亚洲网友自拍偷拍| 国产精品99精品久久免费| 在线观看一区日韩| 亚洲精品在线观看视频| 亚洲色图视频免费播放| 青青草原综合久久大伊人精品| 国产不卡在线视频| 欧美另类高清zo欧美| 国产清纯在线一区二区www| 亚洲一区二区三区小说| 国产精品香蕉一区二区三区| 欧美性大战久久久久久久蜜臀| 欧美成人一级视频| 一区二区三区四区精品在线视频| 日韩电影网1区2区| 99国产精品久久久久久久久久久| 91精品国产综合久久久蜜臀图片| 国产欧美日韩综合| 蜜臀av性久久久久蜜臀aⅴ流畅 | 欧美色综合影院| 亚洲国产成人私人影院tom| 午夜欧美电影在线观看| 成人激情电影免费在线观看| 91精品欧美久久久久久动漫| 日韩一区欧美一区| 国产精品白丝jk白祙喷水网站 | 日韩欧美国产一区二区在线播放 | 欧美xxxxx裸体时装秀| 亚洲精品久久7777| 国产91丝袜在线18| 日韩一区和二区| 日韩精品高清不卡| 在线观看一区二区视频| 中文字幕亚洲欧美在线不卡| 国产精品一二三区在线| 555夜色666亚洲国产免| 一区二区三区在线观看视频 | 国产精品网站在线观看| 极品美女销魂一区二区三区免费| 欧美写真视频网站| 一区二区高清在线| 色综合一区二区三区| 欧美国产日韩精品免费观看| 久久99精品久久久久久久久久久久| 欧美色图在线观看| 亚洲一二三区在线观看| 91国产免费观看| 亚洲人成人一区二区在线观看| 国产精品一区二区久激情瑜伽| 日韩精品中文字幕一区| 日韩国产欧美在线播放| 欧美日韩国产a| 亚洲一区二区三区在线看| 在线观看日韩一区| 亚洲精品国产精华液| 欧美中文字幕亚洲一区二区va在线 | 蜜臀久久久久久久| 欧美精品丝袜久久久中文字幕| 亚洲成人自拍偷拍| 欧美区视频在线观看| 亚洲a一区二区| 91精品国产综合久久香蕉麻豆| 三级亚洲高清视频| 日韩三级视频中文字幕| 蜜臀av亚洲一区中文字幕| 精品日韩一区二区三区| 国产在线不卡一区| 中文字幕一区二区5566日韩| 99久久精品99国产精品| 一区二区三区高清在线| 欧美精品丝袜中出| 久久国产精品一区二区| 久久美女艺术照精彩视频福利播放| 国产一区二区精品久久99| 国产精品天美传媒| 91国偷自产一区二区开放时间 | 91网上在线视频| 亚洲国产综合色| 日韩视频一区在线观看| 国产91丝袜在线18| 亚洲欧美日本韩国| 欧美一区二区视频在线观看| 九九久久精品视频| 日韩毛片精品高清免费| 欧美精品123区| 国产成人av网站| 亚洲国产精品久久久久秋霞影院 | 福利一区福利二区| 一区二区三区高清不卡| 欧美变态凌虐bdsm| 91蜜桃传媒精品久久久一区二区|