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

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

?? bl_nfi.c

?? ARM Bootloader程序
?? C
?? 第 1 頁 / 共 2 頁
字號:
	      *NFI_ADDRM = addr2;
	   *NFI_ADDNOB = addr_no;	           // number of bytes for address	   
	   while (*NFI_PSTA & STATUS_ADDR);	   
	}
	else
	{
	   *NFI_CMD = RD_1ST_CMD;	           // Issue data input command
	   while (*NFI_PSTA & STATUS_CMD);	   
	   *NFI_ADDRL = addr1;
	   if ( addr_no>4 )
	      *NFI_ADDRM = addr2;
	   *NFI_ADDNOB = addr_no;	           // no. of bytes for address	
	   while (*NFI_PSTA & STATUS_ADDR);	   
	   *NFI_CMD = RD_2ND_CYCLE_CMD;
	   while (*NFI_PSTA & STATUS_CMD);	   
	}

   *NFI_OPCON = BURST_RD | NOB_DWORD;    // set burst read
   
   while( *NFI_PSTA & STATUS_DATAR );
   
   NFI_Wait_Ready(timeout);
   
   if ( timeout==0 )
      return KAL_FALSE;

   // Activating DMA transfer
   if ( ECC )
      *NFI_CON = (DMA_RD_EN | AUTOECC_DEC_EN);
   else
      *NFI_CON = DMA_RD_EN;
   
   *(volatile kal_uint32 *)(0x80030118) = 0x0000;
   *(volatile kal_uint32 *)(0x80030100) = (kal_uint32)NFI_DATAR;
   *(volatile kal_uint32 *)(0x80030104) = (kal_uint32)destination;
   *(volatile kal_uint32 *)(0x80030110) = length>>2;
   *(volatile kal_uint32 *)(0x80030114) = 0x00f4001a;
   *(volatile kal_uint32 *)(0x80030128) = 0;
   *(volatile kal_uint32 *)(0x80030118) = 0x8000;
   
   timeout = 0xfff;
   
   while ( ((*(volatile kal_uint32 *)(0x80030000)&0x03)==0x01) && (timeout--) ); 
   
   if ( timeout==0 )
	   return DMA_TRANSFER_DATA_TIMEOUT;
         
//   while (!(*NFI_FIFOCON & RD_EMPTY_MASK) || (*NFI_PSTA & STATUS_DATAR));
   while (*NFI_PSTA & STATUS_BUSY);   

   if ( ECC )
   {
		if ( parity==NULL )
			return NFI_ZERO_POINTER;
		 
		if ( pageSize<1024 )
		{
			parity_ptr[0] = *NFI_PAR6;
			parity_ptr[0] |= (*NFI_PAR7) << 16;         
		}
		else
		{
			parity_ptr[0] = *NFI_PAR0;
			parity_ptr[0] |= (*NFI_PAR1) << 16;
			parity_ptr[1] = *NFI_PAR2;
			parity_ptr[1] |= (*NFI_PAR3) << 16;
			parity_ptr[2] = *NFI_PAR4;
			parity_ptr[2] |= (*NFI_PAR5) << 16;
			parity_ptr[3] = *NFI_PAR6;
			parity_ptr[3] |= (*NFI_PAR7) << 16;
		}         
   }
   
   // Caution: This line must not omitted!
   *NFI_OPCON = 0x0;
   
   if ( timeout )
	   return NFI_SUCCESS;
	else 
	   return NFI_READ_DATA_TIMEOUT;
}

/**********************************************************
Description : NFI_SpareRead
Input       : .......
Output      : _RET_CODE
Remark      : Must be spare area aligned
***********************************************************/
_RET_CODE NFI_SpareRead(kal_uint32 *spare, kal_uint16 addr_no, kal_uint32 addr1, \
                        kal_uint16 addr2, kal_uint16 pageSize, kal_uint16 IO)
{
	kal_int16 timeout=0xfff, size, i;
	  
	*NFI_OPCON = 0x00;
	*NFI_CON = 0x00;        
	*NFI_FIFOCON = 0x30;                  // Flushing FIFO

	if ( pageSize<1024 )
	{
		size = 16;
		*NFI_CON = SW_PROGSPARE_EN;        // program/read spare area enable
		*NFI_CMD = RD_SPARE_CMD;			  // reading spare command	   
		while (*NFI_PSTA & STATUS_CMD);	  
		*NFI_ADDRL = (addr1&0xffffff00);	 
		*NFI_ADDRM = 0;
		*NFI_ADDNOB = addr_no;             // number of bytes for address
		while (*NFI_PSTA & STATUS_ADDR);	 
	}
	else
	{
		size = 64;
		*NFI_CON = SW_PROGSPARE_EN;        // program spare area enable
		*NFI_CMD = RD_1ST_CMD;             // read spare command
		while (*NFI_PSTA & STATUS_CMD);	  
		if ( IO==IO_16BITS )
		{
			// addr1 >>= 1;	   
			addr1 = addr1 + (2048/2);
		}
		else 
		{
			addr1 = addr1 + 2048;
		}
		*NFI_ADDRL = addr1;
		if ( addr_no>4 )
			*NFI_ADDRM = addr2;
		*NFI_ADDNOB = addr_no;             // number of bytes for address
		while (*NFI_PSTA & STATUS_ADDR);	   
		*NFI_CMD = RD_2ND_CYCLE_CMD;            
		while (*NFI_PSTA & STATUS_CMD);	   
	}	   

	//	*NFI_OPCON = BURST_RD | NOB_WORD;     // set burst read	
	*NFI_OPCON = BURST_RD | NOB_DWORD;     // set burst read	

	while( *NFI_PSTA & STATUS_DATAR );

	NFI_Wait_Ready(timeout);

	if ( timeout==0 )
	  return NFI_READ_SPARE_TIMEOUT;


	/*   *NFI_CON |= DMA_RD_EN;
	*(volatile kal_uint32 *)(0x80030118) = 0x0000;
	*(volatile kal_uint32 *)(0x80030100) = (kal_uint32)NFI_DATAR;
	*(volatile kal_uint32 *)(0x80030104) = (kal_uint32)spare;
	*(volatile kal_uint32 *)(0x80030110) = size>>2;
	*(volatile kal_uint32 *)(0x80030114) = 0x00f4001a;
	*(volatile kal_uint32 *)(0x80030128) = 0;
	*(volatile kal_uint32 *)(0x80030118) = 0x8000;

	timeout = 0xfff;

	while ( ((*(volatile kal_uint32 *)(0x80030000)&0x03)==0x01) && (timeout--) ); */


	for (i=0; i<(size/4); i++)
	{
		while ((*NFI_FIFOCON & RD_EMPTY_MASK));
		spare[i] = *NFI_DATAR;
	}   

/*	dbg_print("Spare area = ");
	for(i=0; i<(size/4); i++) {
	     dbg_print("%x ", spare[i]);
	}
	dbg_print("\n\r");*/


	//   while (*NFI_PSTA & STATUS_DATAR);
	// Caution: This line must not omitted!
	*NFI_OPCON = 0x0;
	while (*NFI_PSTA & STATUS_BUSY);   

	if ( timeout )
	   return NFI_SUCCESS;
	else 
	   return DMA_TRANSFER_SPARE_TIMEOUT;
}

/**********************************************************
Description : NFI_ParityCheck
Input       : .......
Output      : _RET_CODE
Remark      : Must be page alignment.
***********************************************************/
_RET_CODE NFI_ParityCheck(kal_uint32 *destination, kal_uint32 *parity, kal_uint16 addr_no, \
                          kal_uint32 addr1, kal_uint16 addr2, kal_uint16 pageSize, kal_uint16 IO, \
                          kal_uint32 blockSize)
{
   _RET_CODE  status;
   kal_uint32 spare[64>>2];
   
   status = NFI_SpareRead(&spare[0], addr_no, addr1, addr2, pageSize, IO);
   
   if ( status!=NFI_SUCCESS )
      return status;
  
   if ( pageSize<1024 )
      status = NUTL_ECC_Correction(destination, parity, &spare[0], 512, blockSize);
   else
      status = NUTL_ECC_Correction(destination, parity, &spare[0], 2048, blockSize);
   
   return status;
}
                  
/**********************************************************
Description : NFI_CheckGoodBlock
Input       : NFI_MENU, baseaddr must be page alignment
Output      : U32 return data
              512B/page, 8-bits interface, 0x????FF??
              otherwise, 0x????FFFF or 0x??????FF
              for good page
              2: Read error
***********************************************************/ 
static kal_uint32 NFI_CheckGoodBlock(NFI_MENU *input, kal_uint32 addr1, kal_uint16 addr2)
{
   kal_uint32 rb_data[4];
   kal_int16  timeout=0xfff, size;
   
   rb_data[0]= 0;
   rb_data[1]= 0;
   rb_data[2]= 0;
   rb_data[3]= 0;
   
   *NFI_OPCON = 0x00;
   *NFI_CON = 0x00;        
   *NFI_FIFOCON = 0x30;                  // Flushing FIFO
   
   if ( input->pageSize<1024 )
   {
      *NFI_CON = SW_PROGSPARE_EN;        // program/read spare area enable
	   *NFI_CMD = RD_SPARE_CMD;			  // reading spare command	   
	   while (*NFI_PSTA & STATUS_CMD);	  
	   *NFI_ADDRL = (addr1&0xffffff00);	 
	   *NFI_ADDRM = 0;
	   *NFI_ADDNOB = input->addressCycle; // number of bytes for address
	   while (*NFI_PSTA & STATUS_ADDR);	 
	}
	else
	{
	   *NFI_CON = SW_PROGSPARE_EN;        // program spare area enable
	   *NFI_CMD = RD_1ST_CMD;             // read spare command
	   while (*NFI_PSTA & STATUS_CMD);	  
	   if ( input->IOInterface == IO_8BITS )
	      *NFI_ADDRL = addr1 + 2048;
	   else
	      *NFI_ADDRL = addr1 + 1024;
	   if ( input->addressCycle>4 )
	      *NFI_ADDRM = addr2;
	   *NFI_ADDNOB = input->addressCycle; // number of bytes for address
	   while (*NFI_PSTA & STATUS_ADDR);	   
      *NFI_CMD = RD_2ND_CYCLE_CMD;            
      while (*NFI_PSTA & STATUS_CMD);	   
	}	   

	*NFI_OPCON = BURST_RD | NOB_WORD;  // set burst read	
	
	while( *NFI_PSTA & STATUS_DATAR );
	
   NFI_Wait_Ready(timeout);
   
   if ( timeout==0 )
      return 2;
   
   size = 0;
   timeout=0xfff;
   
   while ( (size<4) && timeout>0 )
 	{
	   if ( !(*NFI_FIFOCON&RD_EMPTY_MASK) )
	   {
         rb_data[size] = *NFI_DATAR;
         size ++;
      }
      else 
         timeout--;
   }
   
   if ( timeout<=0 )
      return 2;
      
   // Caution: This line must not omitted!
   *NFI_OPCON = 0x0;
      
   if ( input->pageSize<1024 )
   {
      if ( input->IOInterface == IO_8BITS )
         return ( (kal_uint32)((rb_data[1]&0xff00)>>8) );
      else
         return ( ((kal_uint32)(rb_data[0]&0xff) | (rb_data[1]&0xff00)) );
   }
   else
   {
      if ( input->IOInterface == IO_8BITS )
         return ( (kal_uint32)(rb_data[0]&0xff) );
      else
         return ( (kal_uint32)(rb_data[0]&0xffff) );
   }
}


/**********************************************************
Description : NFIReconfigure
Input       : NO
Output      : NO
***********************************************************/
void NFIReconfigure(void)
{
	*NFI_FIFOCON = 0x30;                  // Flushing FIFO
	*NFI_OPCON = 0x00;
	*NFI_CON = 0x00;     
	// Force 512Bytes ECC block size for both 2KB and 512B NAND-flash
	*NFI_PAGEFMT |= 0x20;
	*NFI_ACCCON = 0x7FF;
}


/**********************************************************
Description : GoodBlockChecking
Input       : NFI_MENU, NFIReadPtr must be page alignment
Output      : TRUE, good block, FALSE, bad block
***********************************************************/
kal_bool GoodBlockChecking(NFI_MENU *input, kal_uint32 addr1, kal_uint16 addr2)
{
   kal_uint32 marking, i;
      
   for (i=0; i<2; i++)
   {
      // Read the bad block marking from the first page
      marking = NFI_CheckGoodBlock(input, addr1, addr2);
      if ( (marking!=0xff) && (marking!=0xffff) )
         return KAL_FALSE;
      addr1 = addr1 + (1<<input->pageShift);
   }
         
   return KAL_TRUE;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日本成人在线一区| 蜜桃av噜噜一区| 国产精品午夜久久| 中文字幕制服丝袜成人av| 精品在线一区二区| 精品嫩草影院久久| 极品美女销魂一区二区三区| 欧美午夜电影网| 午夜欧美一区二区三区在线播放| 懂色av一区二区在线播放| 亚洲国产精品尤物yw在线观看| 欧美精品99久久久**| 国内外精品视频| 香港成人在线视频| 国产日韩在线不卡| 日本丶国产丶欧美色综合| 亚洲资源中文字幕| 欧美日韩成人高清| 亚洲成人动漫一区| 欧美一级高清片| 麻豆精品蜜桃视频网站| 亚洲一二三四在线观看| 欧美日韩一区三区四区| 91精品国产综合久久婷婷香蕉 | 成人免费va视频| 日本午夜精品一区二区三区电影 | 精品伦理精品一区| 岛国精品一区二区| 三级久久三级久久| 久久精品亚洲麻豆av一区二区 | 中文字幕va一区二区三区| 欧美日韩高清一区二区| 日韩精品专区在线影院重磅| 亚洲一二三级电影| 精品福利一二区| 成人黄色小视频| 黑人巨大精品欧美黑白配亚洲 | 久久一日本道色综合| 日韩亚洲欧美综合| 不卡在线观看av| 欧美视频在线观看一区二区| 99re在线精品| 成人av集中营| 成人高清视频在线| 国产精品小仙女| 国产精品一二三区在线| 日本视频一区二区| 日本美女视频一区二区| 3d动漫精品啪啪1区2区免费| 国产成人免费在线观看| 国产成人亚洲综合a∨婷婷图片| 欧美一区二区视频网站| 欧美综合色免费| 精品福利av导航| 欧美变态口味重另类| 岛国精品一区二区| 国产成人鲁色资源国产91色综| 丝袜亚洲另类丝袜在线| 亚洲国产精品影院| 久久99久国产精品黄毛片色诱| 中文字幕电影一区| 中文字幕一区二区三区四区| 日韩午夜在线播放| 亚洲视频小说图片| 国产精品国产三级国产普通话三级 | 一区二区三区资源| 久久综合久久鬼色中文字| 日韩欧美黄色影院| 久久久久国产一区二区三区四区| 中文字幕精品三区| 综合久久给合久久狠狠狠97色| 亚洲欧洲精品一区二区三区不卡| 精品久久人人做人人爰| 中文字幕精品综合| 亚洲午夜在线电影| 蜜桃免费网站一区二区三区| 精品制服美女久久| 色94色欧美sute亚洲13| 石原莉奈在线亚洲二区| 色哟哟国产精品| 亚洲国产电影在线观看| 一区二区三区小说| 色天天综合久久久久综合片| 欧美xxxx在线观看| 日韩亚洲欧美中文三级| 欧美精品乱人伦久久久久久| 欧美一级免费大片| 日韩和欧美的一区| 国产日韩欧美精品综合| 久久网这里都是精品| 欧美videos大乳护士334| 亚洲国产人成综合网站| 精品综合免费视频观看| 99久久er热在这里只有精品66| 欧美日韩国产首页在线观看| 7777精品伊人久久久大香线蕉经典版下载| 久色婷婷小香蕉久久| 99精品视频在线免费观看| 日本伊人午夜精品| 欧美专区在线观看一区| 欧美婷婷六月丁香综合色| 中文字幕中文字幕一区二区| 手机精品视频在线观看| 国产一区久久久| 国产成人精品免费一区二区| 欧美一区二区私人影院日本| 麻豆国产精品官网| 亚洲国产一区在线观看| 欧美私人免费视频| 国产精品一区二区你懂的| 91九色最新地址| 久久久三级国产网站| 精品国产露脸精彩对白| 国产欧美日韩麻豆91| 日本中文字幕不卡| 成人免费观看av| 日韩女优av电影| 亚洲国产精品影院| 91丨porny丨户外露出| 国产一区二区三区久久悠悠色av| 欧美三级日韩在线| 欧美色视频在线观看| 欧美日韩一本到| 亚洲精品日日夜夜| 免费高清在线一区| 国产欧美日韩精品a在线观看| 亚洲区小说区图片区qvod| 午夜一区二区三区视频| 成人丝袜18视频在线观看| 精品少妇一区二区三区| 天堂成人免费av电影一区| 一本色道久久综合狠狠躁的推荐| 亚洲男人天堂av网| 亚洲一卡二卡三卡四卡五卡| 欧美午夜电影在线播放| 另类的小说在线视频另类成人小视频在线 | 国产精品系列在线播放| 国产精品久久影院| 欧美视频一区二区| 国产在线精品一区二区不卡了| 中文字幕二三区不卡| 欧美性受xxxx黑人xyx性爽| 视频一区视频二区中文字幕| 精品对白一区国产伦| 93久久精品日日躁夜夜躁欧美| 亚洲国产精品久久不卡毛片| 欧美精品一区二区三区四区| 97aⅴ精品视频一二三区| 丝袜诱惑亚洲看片| 中文无字幕一区二区三区| 欧洲一区二区三区免费视频| 老司机精品视频导航| 亚洲欧洲国产日本综合| 欧美一区二区三区在线电影| 岛国精品在线播放| 日韩精品色哟哟| 国产精品成人一区二区艾草 | 精品国产区一区| 色综合亚洲欧洲| 裸体健美xxxx欧美裸体表演| 国产精品亲子伦对白| 4hu四虎永久在线影院成人| 成人一级片在线观看| 水野朝阳av一区二区三区| 国产欧美精品区一区二区三区| 欧美日韩国产不卡| 成人少妇影院yyyy| 日韩av电影天堂| 国产精品久久免费看| 欧美一级一区二区| 97久久久精品综合88久久| 久久精品国产秦先生| 亚洲男人天堂一区| 欧美电影精品一区二区| 91国偷自产一区二区使用方法| 久久疯狂做爰流白浆xx| 一区二区不卡在线播放 | 亚洲精品国产成人久久av盗摄| 欧美变态tickle挠乳网站| 欧美三级一区二区| 91视视频在线直接观看在线看网页在线看| 日韩成人一区二区三区在线观看| 亚洲私人影院在线观看| 久久久久久亚洲综合| 91国产成人在线| 成人中文字幕在线| 国产一区视频导航| 午夜精品福利一区二区三区av| 中文字幕亚洲不卡| 久久久99精品久久| 欧美成人猛片aaaaaaa| 欧美日韩国产精品成人| 欧洲精品在线观看| av一区二区三区| 处破女av一区二区| 成人影视亚洲图片在线| 国产主播一区二区三区| 美女视频黄 久久| 日本色综合中文字幕| 亚洲亚洲人成综合网络|