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

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

?? nand.c

?? samsung 2410 demo源代碼
?? C
?? 第 1 頁 / 共 3 頁
字號:
		if(i==0)  printf(".");
			//printf("\b\b\b\b\b\b\b\b%04d,%02d]", blockIndex, i);
		if((U32)srcPt>=(srcAddress+targetSize)) // Check end of buffer
		break;	// Exit for loop
		}
		
		if(programError==1) {
		    blockIndex++;
		    srcPt=saveSrcPt;
		    programError=0;
		    continue;
		}

		if((U32)srcPt>=(srcAddress+targetSize)) break;	// Exit while loop

		blockIndex++;
    }

}


void InputTargetBlock(void)
{
	U32 no_block, no_page, no_byte;
	
	printf("\nSource size:0h~%xh\n",downloadProgramSize);
	printf("\nAvailable target block number: 0~4095\n");
	printf("Input target block number:");
    targetBlock=GetIntNum();	// Block number(0~4095)
    if(targetSize==0)
    {
    	#if 0
    	printf("Input target size(0x4000*n):");
    	targetSize=GetIntNum();	// Total byte size
	#else
   	printf("Input program file size(bytes): ");
    	targetSize=GetIntNum();	// Total byte size
    	#endif
    }
	
	no_block = (U32)((targetSize/512)/32);
	no_page = (U32)((targetSize/512)%32);
	no_byte = (U32)(targetSize%512);
	printf("File:%d[%d-block,%d-page,%d-bytes].\n", targetSize, no_block, no_page, no_byte);
}


void NF8_PrintBadBlockNum(void)
{
    int i;
    U16 id;

    printf("\n[SMC(K9S1208V0M) NAND Flash bad block check]\n");
    
    id=NF8_CheckId();
    printf("ID=%x(0xec76)\n",id);
    if(id!=0xec76)
    return;
    for(i=0;i<4096;i++)  	NF8_IsBadBlock(i);   // Print bad block
}


void Test_NF8_Lock(void)
{
       U32 num;
       U32 S_block, E_block;
	printf("SMC(K9S1208V0M) NAND Lock Test !!!\n");
	printf("Select Lock type, Softlock(1)/Lock-tight(2) : ");

	num=GetIntNum();;
			
	printf("\nEnter programmable start block address ");
	S_block = GetIntNum();
	printf("Enter programmable end block address ");
       E_block = GetIntNum();

	rNFSBLK=(S_block<<5);
	rNFEBLK=(E_block<<5);
	
	if(num==1){
		rNFCONT|=(1<<12);
              printf("Software Locked\n ");
	}
	if(num==2){
		rNFCONT|=(1<<13);
              printf("Lock-tight: To clear Lock-tight, reset S3C2440!!!\n ");
	}
      printf("%d block ~ %d block are Programmable\n ", S_block, (E_block-1));
}


void Test_NF8_SoftUnLock(void)
{
       U32 S_block, E_block;
	printf("SMC(K9S1208V0M) NAND SoftUnLock Test !!!\n");
	
	rNFSBLK=0x0;
	rNFEBLK=0x0;

	rNFCONT&=~(1<<12);
	if(rNFCONT&(1<<13)){
		rNFCONT&=~(1<<13);
		printf("Lock-tight\n ");
		printf("You can't unlock Protected blocks !!!\n ");
		printf("%d block ~ %d block are Programmable\n ", (rNFSBLK>>5), ((rNFEBLK>>5)-1));
	}
       else printf("All blocks are Programmable\n ");
}


void PrintSubMessage(void)
{
	int i;
	
	i=0;	
	printf("\n\n");
	while(1)
	{   //display menu
	    printf("%2d:%s",i,n8_func[i][1]);
	    i++;
	    if((int)(n8_func[i][0])==0)
	    {
		 printf("\n");
		 break;
	    }
	    if((i%4)==0) printf("\n");
	}
}


static int NF8_EraseBlock(U32 block)
{
	U32 blockPage=(block<<5);
    int i;

    NFConDone=0;
    rNFCONT|=(1<<9);
    rNFCONT|=(1<<10);
    pISR_NFCON= (unsigned)NFCon_Int;
    rSRCPND=BIT_NFCON;
    rINTMSK=~(BIT_NFCON);
	
#if BAD_CHECK
    if(NF8_IsBadBlock(block))
	return FAIL;
#endif

	NF_nFCE_L();
    
	NF_CMD(0x60);   // Erase one block 1st command, Block Addr:A9-A25
	// Address 3-cycle
	NF_ADDR(blockPage&0xff);	    // Page number=0
	NF_ADDR((blockPage>>8)&0xff);   
	NF_ADDR((blockPage>>16)&0xff);


	NF_CLEAR_RB();
	NF_CMD(0xd0);	// Erase one blcok 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

      if (NF_RDDATA()&0x1) // Erase error
      {	
    	NF_nFCE_H();
	printf("[ERASE_ERROR:block#=%d]\n",block);
//	NF8_MarkBadBlock(block);
	return FAIL;
       }
       else 
       {
    	NF_nFCE_H();
       return OK;
       }
}


void __irq NFCon_Int(void)
{
	//printf("Ni\n");
    NFConDone=1;
	rINTMSK|=BIT_NFCON;
	ClearPending(BIT_NFCON);
	if(rNFSTAT&0x20) printf("Illegal Access is detected!!!\n");
//	else printf("RnB is Detected!!!\n"); 
}


static int NF8_IsBadBlock(U32 block)
{
       int i;
       unsigned int blockPage;
	U8 data;
    
    
       blockPage=(block<<5);	// For 2'nd cycle I/O[7:5] 
    
	NF_nFCE_L();
	NF_CLEAR_RB();

	NF_CMD(0x50);		 // Spare array read command
	NF_ADDR((512+5)&0xf);		 // Read the mark of bad block in spare array(M addr=5), A4-A7:Don't care
	NF_ADDR(blockPage&0xff);	 // The mark of bad block is in 0 page
	NF_ADDR((blockPage>>8)&0xff);	 // For block number A[24:17]
	NF_ADDR((blockPage>>16)&0xff);  // For block number A[25]
	 
	NF_DETECT_RB();	 // Wait tR(max 12us)

       data=NF_RDDATA();

	NF_nFCE_H();    

     if(data!=0xff)
     {
    	printf("[block %d has been marked as a bad block(%x)]\n",block,data);
    	return FAIL;
     }
     else
     {
    	return OK;
     }
}


static int NF8_MarkBadBlock(U32 block)
{
       int i;
	U32 blockPage=(block<<5);
 
     se8Buf[0]=0xff;
     se8Buf[1]=0xff;    
     se8Buf[2]=0xff;    
     se8Buf[5]=0x44;   // Bad blcok mark=44
    
	NF_nFCE_L(); 
	NF_CMD(0x50);   //????
	NF_CMD(0x80);   // Write 1st command
    
	NF_ADDR(0x0);		    // The mark of bad block is 
	NF_ADDR(blockPage&0xff);	    // marked 5th spare array 
	NF_ADDR((blockPage>>8)&0xff);   // in the 1st page.
	NF_ADDR((blockPage>>16)&0xff);  //
    
	for(i=0;i<16;i++)
      {
	   NF_WRDATA(se8Buf[i]);	// Write spare array
      }

	NF_CLEAR_RB();
	NF_CMD(0x10);   // Write 2nd command
	NF_DETECT_RB();

	NF_CMD(0x70);
    
	for(i=0;i<3;i++);  //twhr=60ns////??????
    
      if (NF_RDDATA()&0x1) // Spare arrray write error
      {	
    	NF_nFCE_H();
    	printf("[Program error is occurred but ignored]\n");
       }
      else 
      {
    	NF_nFCE_H();
      }

	printf("[block #%d is marked as a bad block]\n",block);
       return OK;
}

static int NF8_ReadPage(U32 block,U32 page,U8 *buffer)
{
       int i;
       unsigned int blockPage;
	U32 Mecc, Secc;
	U8 *bufPt=buffer;
	U8 se[16], ecc0, ecc1, ecc2, ecc3,a,b,c,d,e;
    
       blockPage=(block<<5)+page;
	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();
	 
	
      #if TRANS_MODE==C_LANG
	    for(i=0;i<512;i++) {
	    	*bufPt++=NF_RDDATA8();	// Read one page
	    }
      #elif TRANS_MODE==DMA
		// Nand to memory dma setting
	    rSRCPND=BIT_DMA0;	// Init DMA src pending.
	    rDISRC0=NFDATA; 	// Nand flash data register
	    rDISRCC0=(0<<1) | (1<<0); //arc=AHB,src_addr=fix
	    rDIDST0=(unsigned)bufPt;
	    rDIDSTC0=(0<<1) | (0<<0); //dst=AHB,dst_addr=inc;
	    rDCON0=(1<<31)|(1<<30)|(1<<29)|(1<<28)|(1<<27)|(0<<23)|(1<<22)|(2<<20)|(512/4/4);
		//Handshake,AHB,interrupt,(4-burst),whole,S/W,no_autoreload,word,count=128;

		// DMA on and start.
	    rDMASKTRIG0=(1<<1)|(1<<0);

		while(!(rSRCPND & BIT_DMA0));	// Wait until Dma transfer is done.
		
	    rSRCPND=BIT_DMA0;

      #elif TRANS_MODE==ASM
	    __RdPage512(bufPt);
      #endif

  /*  
	  NF_MECC_Lock();
	  
	  rNFMECCD0=NF_RDDATA();
	  
	  NF_nFCE_H();	  
	  
	  if ((rNFESTAT0&0x3) == 0x0) 	  return OK;
	  else   return FAIL;
*/

	 NF_MECC_Lock();

	 NF_SECC_UnLock();
	 Mecc=NF_RDDATA();
	 rNFMECCD0=((Mecc&0xff00)<<8)|(Mecc&0xff);
	 rNFMECCD1=((Mecc&0xff000000)>>8)|((Mecc&0xff0000)>>16);
	
	 NF_SECC_Lock();
	 NF8_Spare_Data[0]=Mecc&0xff;
	 NF8_Spare_Data[1]=(Mecc&0xff00)>>8;
	 NF8_Spare_Data[2]=(Mecc&0xff0000)>>16;
	 NF8_Spare_Data[3]=(Mecc&0xff000000)>>24;
	 Mecc=NF_RDDATA();  // read 4~7
 	 NF8_Spare_Data[4]=Mecc&0xff;
	 NF8_Spare_Data[5]=(Mecc&0xff00)>>8;
	 NF8_Spare_Data[6]=(Mecc&0xff0000)>>16;
	 NF8_Spare_Data[7]=(Mecc&0xff000000)>>24;

	 Secc=NF_RDDATA();
	 rNFSECCD=((Secc&0xff00)<<8)|(Secc&0xff);
	 NF8_Spare_Data[8]=Secc&0xff;
	 NF8_Spare_Data[9]=(Secc&0xff00)>>8;
	 NF8_Spare_Data[10]=(Secc&0xff0000)>>16;
	 NF8_Spare_Data[11]=(Secc&0xff000000)>>24;
	 
	 Secc=NF_RDDATA();
	 NF8_Spare_Data[12]=Secc&0xff;
	 NF8_Spare_Data[13]=(Secc&0xff00)>>8;
	 NF8_Spare_Data[14]=(Secc&0xff0000)>>16;
	 NF8_Spare_Data[15]=(Secc&0xff000000)>>24;
	 NF_nFCE_H();    

	 if ((rNFECCERR0&0xf) == 0x0){
	       printf("ECC OK!\n");
		return OK;
	 }
	 else {
		printf("ECC FAIL!\n");
	       return FAIL;
	 }


}


static int NF8_WritePage(U32 block,U32 page,U8 *buffer)
{
    int i;
	U32 blockPage, Mecc, Secc;
	U8 *bufPt=buffer;

	NFConDone=0;
    rNFCONT|=(1<<9);
    rNFCONT|=(1<<10);
    pISR_NFCON= (unsigned)NFCon_Int;
    rSRCPND=BIT_NFCON;
    rINTMSK=~(BIT_NFCON);
	  
	NF_RSTECC();    // Initialize ECC
    NF_MECC_UnLock();
	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);  //

	
#if TRANS_MODE==C_LANG
     
	for(i=0;i<512;i++) {
		NF_WRDATA8(*bufPt++);	// Write one page to NFM from buffer
    }
#elif TRANS_MODE==DMA
      
	// Memory to Nand dma setting
	rSRCPND=BIT_DMA0;	// Init DMA src pending.
	rDISRC0=(unsigned)bufPt; 	// Nand flash data register
	rDISRCC0=(0<<1) | (0<<0); //arc=AHB,src_addr=inc
	rDIDST0=NFDATA;
	rDIDSTC0=(0<<1) | (1<<0); //dst=AHB,dst_addr=fix;
	rDCON0=(1<<31)|(1<<30)|(1<<29)|(0<<28)|(1<<27)|(0<<23)|(1<<22)|(2<<20)|(512/4);
	//  only unit transfer in writing!!!!
	//Handshake,AHB,interrupt,(unit),whole,S/W,no_autoreload,word,count=128;
	
	// DMA on and start.
	rDMASKTRIG0=(1<<1)|(1<<0);
	
	while(!(rSRCPND & BIT_DMA0));	// Wait until Dma transfer is done.
	rSRCPND=BIT_DMA0;	
#endif
/*
      NF_MECC_Lock();
// Get ECC data.
	// Spare data for 8bit
	// byte  0   1    2    3    4   5
	// ecc  [0]  [1]  [2]  [3]  x   [Bad marking]
	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]=0xffff;		// Marking good block

	//Write extra data(ECC, bad marking)
	for(i=0;i<16;i++) {
		NF_WRDATA8(se8Buf[i]);	// Write spare array(ECC and Mark)
		NF8_Spare_Data[i]=se8Buf[i];
    }  

 	NF_CLEAR_RB();

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产91精品在线观看| 91福利在线看| 亚洲精品久久久蜜桃| 日韩欧美一级二级三级久久久| 99riav久久精品riav| 狠狠色丁香婷婷综合久久片| 一区二区不卡在线播放| 国产视频一区在线观看| 91精品国产入口| 色88888久久久久久影院按摩 | 精品中文字幕一区二区| 亚洲女人****多毛耸耸8| 久久久91精品国产一区二区三区| 欧美人妖巨大在线| 91黄色小视频| 91在线无精精品入口| 国产成人av一区| 久久爱www久久做| 午夜成人免费视频| 亚洲综合免费观看高清完整版| 亚洲国产精品成人综合色在线婷婷| 日韩一区二区免费在线电影| 欧美日韩久久久| 日本乱人伦aⅴ精品| av电影在线观看一区| 成人性生交大片免费看中文| 久久99国产精品久久99| 天天色综合天天| 亚洲国产成人av网| 亚洲日本在线看| 亚洲欧美激情视频在线观看一区二区三区| 久久久久国产免费免费| xnxx国产精品| 26uuu国产日韩综合| 欧美不卡在线视频| 精品黑人一区二区三区久久 | 91精品国产一区二区人妖| 欧美在线视频你懂得| 色综合视频一区二区三区高清| 国产高清成人在线| 国产成人超碰人人澡人人澡| 国产美女精品一区二区三区| 国产乱码精品1区2区3区| 国精产品一区一区三区mba桃花| 久久精品免费观看| 狠狠色狠狠色综合日日91app| 国产真实乱子伦精品视频| 国产乱码一区二区三区| 国产成人亚洲综合色影视| 99久久免费视频.com| 在线视频欧美精品| 欧美影视一区在线| 91精品啪在线观看国产60岁| 日韩欧美一级片| 欧美激情一区二区三区不卡| 亚洲欧洲精品天堂一级| 一区二区三区不卡视频在线观看| 亚洲成人手机在线| 捆绑调教美女网站视频一区| 国产一区视频导航| 成人av综合一区| 色欧美片视频在线观看在线视频| 欧美日韩在线观看一区二区 | 国产高清不卡一区| 成人小视频在线| 91成人网在线| 日韩视频免费观看高清在线视频| 久久先锋影音av鲁色资源网| 亚洲视频每日更新| 免费在线看成人av| 大陆成人av片| 欧美日韩精品专区| 国产日韩亚洲欧美综合| 亚洲色图清纯唯美| 麻豆国产精品官网| av在线播放一区二区三区| 91极品美女在线| 2024国产精品| 亚洲另类中文字| 久久精品99国产精品| www.亚洲国产| 6080亚洲精品一区二区| 国产亚洲精品精华液| 亚洲国产精品综合小说图片区| 久久成人综合网| 91免费观看视频在线| 日韩欧美成人激情| 一区二区在线观看免费| 国产综合色精品一区二区三区| 91香蕉国产在线观看软件| 日韩欧美黄色影院| 一区二区三区四区不卡在线| 国内精品国产成人国产三级粉色| 欧美性感一类影片在线播放| 久久久久久免费| 日韩精品久久理论片| 99re这里只有精品视频首页| 精品国产乱码久久久久久免费| 亚洲毛片av在线| 国产精品一区久久久久| 91精品国产综合久久久久| 亚洲裸体在线观看| 国产精品888| 日韩精品一区在线| 亚洲午夜久久久| 成人免费观看男女羞羞视频| 欧美mv和日韩mv国产网站| 一区二区高清视频在线观看| 99热这里都是精品| 久久久精品免费免费| 免费人成在线不卡| 欧美老肥妇做.爰bbww| ...xxx性欧美| 国产成人福利片| 久久久久久久久久看片| 美日韩一区二区三区| 欧美又粗又大又爽| 亚洲日本护士毛茸茸| 成人激情动漫在线观看| 久久九九久精品国产免费直播| 久久精品国产999大香线蕉| 7799精品视频| 首页国产丝袜综合| 欧美精品一卡二卡| 亚洲成人三级小说| 欧美日韩国产大片| 日韩国产在线一| 欧美性videosxxxxx| 一区二区三区在线免费播放| 成人动漫在线一区| 国产精品你懂的在线| 成人伦理片在线| 国产精品免费久久久久| 成人一级视频在线观看| 久久精品男人的天堂| 国产精品白丝jk黑袜喷水| 国产偷国产偷精品高清尤物| 国产成人在线免费| 国产精品全国免费观看高清| 成人午夜电影久久影院| 国产精品久久久久久久久免费相片| 国产不卡免费视频| 国产精品人人做人人爽人人添 | 日韩一区二区三区视频| 麻豆精品视频在线| 久久久噜噜噜久久中文字幕色伊伊 | 亚洲另类中文字| 欧美午夜一区二区三区免费大片| 亚洲午夜久久久久| 欧美一区二区三区四区在线观看| 奇米亚洲午夜久久精品| 久久久久久黄色| 播五月开心婷婷综合| 一区二区免费在线播放| 欧美乱熟臀69xxxxxx| 国内精品写真在线观看| 国产精品女人毛片| 欧美午夜精品免费| 免费一区二区视频| 久久影音资源网| 色综合天天狠狠| 天天综合天天综合色| 精品国产免费人成在线观看| 成人综合婷婷国产精品久久蜜臀 | 日韩三级.com| 国产aⅴ综合色| 夜夜亚洲天天久久| 在线91免费看| 成人性生交大合| 天天色天天操综合| 久久久久久亚洲综合影院红桃| 99综合电影在线视频| 日韩黄色片在线观看| 国产欧美日韩不卡| 欧美乱妇15p| 国产**成人网毛片九色 | 自拍偷拍国产亚洲| 欧美色图一区二区三区| 国产一区欧美日韩| 一区二区三区 在线观看视频| 日韩欧美成人一区| 日本道精品一区二区三区| 久久99国产精品尤物| 亚洲精品国产一区二区三区四区在线| 91精品一区二区三区久久久久久| 成人黄色综合网站| 免费av成人在线| 亚洲人吸女人奶水| 欧美精品一区二区不卡| 色婷婷精品久久二区二区蜜臀av| 精品一区二区日韩| 一区二区三区日韩在线观看| 欧美一二三四区在线| 色拍拍在线精品视频8848| 国产丶欧美丶日本不卡视频| 午夜久久久久久久久久一区二区| 国产精品电影一区二区| 26uuu久久天堂性欧美| 欧美日韩国产一级| 91免费版在线|