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

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

?? nf.c

?? 這是用C語言寫的USB源程序,相信對大家有所幫助
?? C
?? 第 1 頁 / 共 3 頁
字號:
			nf_64 = 0;
			break;
		case 0x75 :                         /* 32 Mbyte  */
			nf_device_type = NF_SIZE_32MB;
			nf_zone_max = 2;
			nb_reserved_sector=3;
			nf_disk_size =  NF_SECTOR_SIZE_32MB;
			nf_64 = 0;
			break;
		case 0x76 :                         /* 64 Mbyte  */
			nf_device_type = NF_SIZE_64MB;
			nf_zone_max = 4;
			nb_reserved_sector=1;
			nf_disk_size =  NF_SECTOR_SIZE_64MB;
			nf_64 = 1;        /* 4 address cycles */
			break;
		case 0x79 :                         /* 128 Mbyte */
			nf_device_type = NF_SIZE_128MB;
			nf_zone_max = 8;
			nb_reserved_sector=1;
			nf_disk_size =  NF_SECTOR_SIZE_128MB;
			nf_64 = 1;        /* 4 address cycles */
			break;
		default:break;
	}

  read_spare_byte();
  index_block_erased = 0;
  index_reassign = 0;
  Nf_CS_OFF();
}

/*F**************************************************************************
* NAME:     nf_read_open

*----------------------------------------------------------------------------
* PARAMS:   pos:   address of the logic sector to read (size 512 bytes)
*
* RETURN:   Update memory for reading
*
*----------------------------------------------------------------------------
* PURPOSE:  Low level memory read update

*****************************************************************************/
bit nf_read_open (Uint32 pos)
{
  Uint16	logical_block;
  Uint16	physical_block;
  Byte		nf_zone;

  Nf_CS_ON();
  gl_ptr_mem = pos;
  gl_cpt_page = 0;

  /* Determine the logical block value */
  logical_block = (gl_ptr_mem >> 5);

  /* Determinate zone */
  nf_zone = (Byte)(logical_block / 992);

  /* Each zone have 1000 data blocks */
  logical_block %=(Uint16)992;// logical_block - (992 * nf_zone);

  /* Calculate the address where the physical block value */
  address = address_look_up_table + ((Uint32)(logical_block) >> 8) 
                  + ((Uint32)(nf_zone) << 2);

  /* Open the look-up table */
  Nf_wait_busy();
  if (logical_block & 0x80)
  {
    Nf_send_command(NF_READ_B_AREA_CMD);            /* 2nd half page */
    Nf_send_address( (logical_block << 1) - 256);
  }
  else
  {
    Nf_send_command(NF_READ_A_AREA_CMD);            /* first half page */
    Nf_send_address(logical_block << 1);
  }

  Nf_send_address ( ((Byte*)&address)[3] );   /* 2nd address cycle         */
  Nf_send_address ( ((Byte*)&address)[2] );   /* 3rd address cycle         */
  if (nf_64)                                        /* Size of card >= 64Mbytes ?*/
    Nf_send_address ( ((Byte*)&address)[1] ); /* 4th address cycle         */


  Nf_wait_busy();

  /* Read the physical block number */
  ((Byte*)&physical_block)[0] = Nf_rd_byte();
  ((Byte*)&physical_block)[1] = Nf_rd_byte();

  /* Calculate the physical sector address */
  current_physical_sector_addr = ((Uint32)(physical_block) << 5) + (gl_ptr_mem & 0x1F); 

  nf_send_ra_cmd();
/*
  Nf_send_command (NF_READ_A_AREA_CMD);
  Nf_send_address ( 0x00 );                                       
  Nf_send_address ( ((Byte*)&current_physical_sector_addr)[3] );  
  Nf_send_address ( ((Byte*)&current_physical_sector_addr)[2] );  
  if (nf_64)                                                      
    Nf_send_address ( ((Byte*)&current_physical_sector_addr)[1] );
*/
  Nf_wait_busy();
  return OK;
}

/*F**************************************************************************
* NAME:     nf_read_close
*----------------------------------------------------------------------------
* PARAMS:
*
* RETURN:
*
*----------------------------------------------------------------------------
* PURPOSE:  Low level memory read close
*
*****************************************************************************
* NOTE:
*
*****************************************************************************/
void nf_read_close (void)
{
  Nf_CS_OFF();
}


/*F*************************************************************************
* NAME:     nf_read_byte
*---------------------------------------------------------------------------
* AUTHOR:
*---------------------------------------------------------------------------
* PARAMS:
*
* RETURN:   Data read from memory
*
*---------------------------------------------------------------------------
* PURPOSE:  Low level memory read function
*
****************************************************************************
* NOTE:    
*
****************************************************************************/
Byte nf_read_byte (void)
{
  Byte b;
  Byte i;

  if (gl_cpt_page == 0x00)
    Nf_wait_busy();

  b = Nf_rd_byte();
  gl_cpt_page++;
  
  /* Detection of the end of data page */
  if (gl_cpt_page == NF_DATA_SIZE)                 
  {
    /* read spare data bytes */
	for(i=0;i<16;i++)ACC=Nf_rd_byte();

    gl_ptr_mem++;                           /* new page          */

    gl_cpt_page=0;                          /* start at column 0 */

    if ( !(gl_ptr_mem & 0x1F) )   /* New block ? */
    {
      nf_read_open(gl_ptr_mem);
    }
    else
    {
      current_physical_sector_addr++;
      Nf_wait_busy();

	  nf_send_ra_cmd();

    }
  }
  return b;
}




/*F**************************************************************************
* NAME: nf_read_sector
*----------------------------------------------------------------------------
* PARAMS:
*   global: gl_ptr_mem
*
* return: OK read done
*         KO read failure
*----------------------------------------------------------------------------
* PURPOSE: 
*   This function is an optimized function that writes 512 bytes from NF
*   card to USB controller 
*----------------------------------------------------------------------------
* EXAMPLE:
*----------------------------------------------------------------------------
* NOTE:
*----------------------------------------------------------------------------
* REQUIREMENTS:
*****************************************************************************/
bit nf_read_sector(void)
{
  Byte i;
  Byte j;

  Nf_wait_busy();

  for (i = 8; i != 0; i--)
  {
	
	for(j=0;j<8;j++)
	{
		Usb_write_byte(Nf_rd_byte());
		Usb_write_byte(Nf_rd_byte());
		Usb_write_byte(Nf_rd_byte());
		Usb_write_byte(Nf_rd_byte());
		Usb_write_byte(Nf_rd_byte());
		Usb_write_byte(Nf_rd_byte());
		Usb_write_byte(Nf_rd_byte());
		Usb_write_byte(Nf_rd_byte());
	}


    Usb_set_TXRDY();                        /* start usb transfer */
    while (!Usb_tx_complete());             /* wait end of transfer */
    Usb_clear_TXCMPL();                     /* ack transfer */
  }

  /* read spare data bytes */
  for(i=0;i<4;i++)
  {
  	ACC=Nf_rd_byte();
  	ACC=Nf_rd_byte();
	ACC=Nf_rd_byte();
  	ACC=Nf_rd_byte();
  }

  gl_ptr_mem++;                       /* new page          */
  
  if ( !(gl_ptr_mem & 0x1F) )   /* New block ? */
  {
    nf_read_open(gl_ptr_mem);
  }
  else
  {
    current_physical_sector_addr++;
    Nf_wait_busy();
	nf_send_ra_cmd();
  }
  return OK;  
}

/*F**************************************************************************
* NAME:     nf_write_open
*----------------------------------------------------------------------------
* AUTHOR:
*----------------------------------------------------------------------------
* PARAMS:   pos:   address of the the next write data
*

*----------------------------------------------------------------------------
* PURPOSE:  Low level memory write update

*****************************************************************************/
extern xdata  Byte mode_state;

bit nf_write_open (Uint32 pos)
{
  Uint16 logical_block;
  Uint16 physical_block;
  Uint32 look_up_table;
  Byte	nf_zone;

	if((mode_state == MODE_DOWNLOAD) && (!Nf_WP))
	{
		return KO;
	}

  Nf_CS_ON();
  gl_ptr_mem = pos;
  gl_cpt_page = 0;

  /* Determine the logical block value */
  logical_block = (gl_ptr_mem >> 5);

  /* Determinate zone */
  nf_zone = (Byte)(logical_block / 992);

  /* Each zone have 1000 data blocks */
  logical_block =logical_block - ((Uint16)nf_zone * 992);

  /* Calculate the address where the physical block value */
  look_up_table = address_look_up_table + ((Uint32)(logical_block) >> 8) + ((Uint32)(nf_zone) << 2);

  nf_calc_logical_block(logical_block);

  Nf_wait_busy();
  /* Open the look-up table */
  if (logical_block & 0x80)
  {
    Nf_send_command(NF_READ_B_AREA_CMD);            /* 2nd half page */
    Nf_send_address( (logical_block << 1) - 256);
  }
  else
  {
    Nf_send_command(NF_READ_A_AREA_CMD);            /* first half page */
    Nf_send_address(logical_block << 1);
  }

  Nf_send_address ( ((Byte*)&look_up_table)[3] );   /* 2nd address cycle         */
  Nf_send_address ( ((Byte*)&look_up_table)[2] );   /* 3rd address cycle         */
  if (nf_64)                                        /* Size of card >= 64Mbytes ?*/
    Nf_send_address ( ((Byte*)&look_up_table)[1] ); /* 4th address cycle         */

  Nf_wait_busy();

  /* Read the physical block number                          */
  ((Byte*)&physical_block)[0] = Nf_rd_byte();
  ((Byte*)&physical_block)[1] = Nf_rd_byte();

	if(record_open_bit)
	{
		record_open_bit=0;
		physical_block &= 0x7FFF;
		block_used=FALSE;
	

		current_physical_sector_addr = (Uint32)(physical_block) << 5;

		if((pos&0x1f) == 0)
		{
			nf_block_erase(current_physical_sector_addr);	
			Nf_wait_busy();
		}
		nf_init_spare();
		index_block_erased=0;
	}
	else
	{
		index_free_block[0] += 2;
		if (index_free_block[0] >= nf_spare_block_number[0])
		{
			index_free_block[0] = 0;
		}
  
		index_look_up_table += 2;
		if (index_look_up_table >= nf_spare_block_number[0])
		{
			index_look_up_table = 0;
		}

		block_used = ( !(physical_block & 0x8000) ) ? TRUE : FALSE;
		physical_block &= 0x7FFF;

		if ( block_used )     /* Already used block ?  */
		{
			if (nf_zone != 0)
			{
				index_free_block[nf_zone] += 2;          
				if (index_free_block[nf_zone] >= nf_spare_block_number[nf_zone])
				{
					index_free_block[nf_zone] = 0;
				}
			}
 
			/* Find the new physical block */
			address = address_look_up_table + 3 + ((Uint32)(nf_zone) << 2);
			Nf_send_command(NF_READ_B_AREA_CMD);        
			Nf_send_address( index_free_block[nf_zone] + 192);
			Nf_send_address ( ((Byte*)&address)[3] );   
			Nf_send_address ( ((Byte*)&address)[2] );   
			if (nf_64)                                  
			{
      		Nf_send_address ( ((Byte*)&address)[1] ); 
			}

			/* Save physical block value to be erased at the end of the write operation */
			block_to_be_erased[index_block_erased] = physical_block;
			/* save index */
			index_block_used[index_block_erased] = index_free_block[nf_zone];          

			Nf_wait_busy();
			((Byte*)&physical_block)[0] = Nf_rd_byte();
			((Byte*)&physical_block)[1] = Nf_rd_byte();

			physical_block &= 0x7FFF;

			/* Update the reassign block structure : logical block <-> physical block */
			reassign_block[index_reassign].zone = nf_zone;
			reassign_block[index_reassign].logical_block =  logical_block;
			reassign_block[index_reassign].physical_block = physical_block;
			index_reassign++;
			current_physical_sector_addr = (Uint32)(physical_block) << 5;
			/* Copy first part of the block                          */
			nf_copy_block_head();
			index_block_erased++;
		}
		else                                 /* new logical block  */
		{ 
			/* Update the reassign block structure : logical block <-> physical block */
			reassign_block[index_reassign].zone = nf_zone;
			reassign_block[index_reassign].logical_block =  logical_block;
			reassign_block[index_reassign].physical_block = physical_block;
			index_reassign++;
			current_physical_sector_addr = (Uint32)(physical_block) << 5;
			nf_init_spare();                   
		}
	}

	Nf_wait_busy();
	nf_busy = FALSE;
	Nf_CS_OFF();
	return OK; 
}

/*F**************************************************************************
* NAME:     nf_write_close
*----------------------------------------------------------------------------
* AUTHOR:
*----------------------------------------------------------------------------
* PARAMS:
*
* RETURN:
*
*----------------------------------------------------------------------------
* PURPOSE:  Low level memory write close: release NF 
*
*****************************************************************************
* NOTE:
*
*****************************************************************************/
bit nf_write_close (void)
{ 
  Uchar i;

  Nf_CS_ON();

  if (gl_cpt_page != 0)       /* uncomplete write */
  {
    if (gl_cpt_page < 256)    /* First half page */
    {
      for ( ; gl_cpt_page < 256; gl_cpt_page++)
      {
        gl_buffer[gl_cpt_page] = 0x00;
      }
      Nf_wait_busy();

	  nf_send_w_cmd(MODE_CMDA,1);

      /* Copy the buffer */
      nf_download_buffer();
      /* Program the device */
      Nf_send_command(NF_PAGE_PROGRAM_CMD);
    }
    /* 2nd half page */
    for ( ; gl_cpt_page < 512; gl_cpt_page++)
    {
     gl_buffer[gl_cpt_page] = 0x00;
    }
    Nf_wait_busy();

    Nf_send_command (NF_READ_B_AREA_CMD);
    Nf_send_command (NF_SEQUENTIAL_DATA_INPUT_CMD);
    Nf_send_address ( 0x00 );
    Nf_send_address ( ((Byte*)&current_physical_sector_addr)[3] );
    Nf_send_address ( ((Byte*)&current_physical_sector_addr)[2] );
    if (nf_64)   
      Nf_send_address ( ((Byte*)&current_physical_sector_addr)[1] );

    /* Copy the buffer */
    nf_download_buffer();
    nf_update_spare_data();
    /* Program the device */
    Nf_send_command(NF_PAGE_PROGRAM_CMD);
    gl_cpt_page = 0;
    gl_ptr_mem++;
  }

  /* Copy last part of a block                  */
  if ( (block_used) && ( gl_ptr_mem & 0x1F ) )
    nf_copy_block_tail();
	//	nf_copy_block_ljl();

  Nf_wait_busy();

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
黄网站免费久久| 日韩一区二区三区观看| 欧美一区二区免费| 国产欧美精品国产国产专区 | 2020国产精品久久精品美国| 国产精品久久久一本精品| 舔着乳尖日韩一区| 色老汉av一区二区三区| 欧美精品一区二区三区蜜臀| 亚洲午夜羞羞片| 成人精品国产一区二区4080| 欧美xxxxxxxxx| 亚洲一区电影777| 99精品在线观看视频| 精品国产一区二区在线观看| 三级在线观看一区二区| 在线看国产日韩| 亚洲欧美另类久久久精品| 高清在线观看日韩| 久久精品一区蜜桃臀影院| 免费在线成人网| 欧美精品色一区二区三区| 亚洲黄色在线视频| 99久久精品国产一区二区三区| 欧美一区二区三区四区在线观看| 中文字幕亚洲区| 成人免费高清视频在线观看| 久久亚洲精华国产精华液| 久久爱另类一区二区小说| 欧美电影一区二区| 日韩精彩视频在线观看| 欧美日韩精品一区二区天天拍小说| 国产亚洲成年网址在线观看| 激情欧美一区二区| 精品国产乱子伦一区| 精油按摩中文字幕久久| 91麻豆精品国产| 精品在线免费观看| 精品国产精品网麻豆系列| 国内精品免费**视频| 免费高清不卡av| 欧美日韩一区二区三区在线| 亚洲综合免费观看高清完整版在线| 国产精品中文字幕欧美| 国产三级欧美三级| 成人黄动漫网站免费app| 国产婷婷色一区二区三区 | 欧美日韩视频在线一区二区| 亚洲一区在线视频观看| 5858s免费视频成人| 麻豆精品久久久| 久久精品视频一区二区三区| 丁香婷婷综合色啪| 亚洲精品中文字幕乱码三区| 欧美天堂一区二区三区| 欧美a级一区二区| 国产欧美一二三区| 91年精品国产| 日韩国产精品91| 国产精品三级视频| 色成人在线视频| 日本不卡视频在线| 久久亚洲一区二区三区明星换脸| 国产精选一区二区三区 | 欧美日韩国产美女| 久久国产精品色婷婷| 欧美国产日韩在线观看| 欧美性感一区二区三区| 精品一区二区三区在线播放视频 | 国产精品66部| 尤物视频一区二区| 日韩欧美精品在线| 成人免费三级在线| 日韩电影在线观看一区| 国产人成一区二区三区影院| 欧美日韩在线一区二区| 国产一区欧美一区| 亚洲成人一区二区在线观看| 国产亚洲精久久久久久| 91精品一区二区三区在线观看| 国产一区二区伦理片| 亚洲图片自拍偷拍| 国产精品国产三级国产aⅴ无密码| 欧美综合欧美视频| 国产成人精品一区二区三区网站观看| 国产亚洲一区字幕| 在线不卡免费欧美| 色综合视频在线观看| 国产在线精品一区二区不卡了| 中文字幕色av一区二区三区| 日韩欧美在线综合网| 91免费版pro下载短视频| 久88久久88久久久| 欧美aⅴ一区二区三区视频| 亚洲人成在线播放网站岛国| 久久影视一区二区| 中文字幕一区二区三区色视频| 欧美妇女性影城| 日本韩国一区二区三区| 国产宾馆实践打屁股91| 另类欧美日韩国产在线| 亚洲激情校园春色| 国产精品电影一区二区三区| 久久精品一区二区三区不卡 | 亚洲一区二三区| 中文字幕一区二区日韩精品绯色| 在线播放欧美女士性生活| 日本高清成人免费播放| 波多野结衣在线一区| 国产河南妇女毛片精品久久久| 天涯成人国产亚洲精品一区av| 《视频一区视频二区| 中文字幕中文字幕中文字幕亚洲无线| 欧美亚洲丝袜传媒另类| 91福利在线观看| 99久久久国产精品免费蜜臀| 成人av网址在线| 成人中文字幕在线| 成人黄色av电影| 色综合久久久久综合99| 91美女在线观看| 欧美午夜精品久久久久久超碰 | 亚洲国产欧美另类丝袜| 亚洲蜜臀av乱码久久精品| 亚洲人吸女人奶水| 有坂深雪av一区二区精品| 亚洲自拍都市欧美小说| 亚洲国产精品一区二区www在线| ●精品国产综合乱码久久久久| 中文字幕中文在线不卡住| 国产精品久久久久久久久果冻传媒| 精品国产凹凸成av人网站| 久久久国产一区二区三区四区小说| 欧美成人艳星乳罩| 久久日韩粉嫩一区二区三区| 久久婷婷色综合| 欧美国产日韩亚洲一区| 最新不卡av在线| 国产乱码精品一区二区三| 高清不卡一区二区| 欧美一区二区三区视频在线| eeuss国产一区二区三区| 久久综合久久99| 欧美三级午夜理伦三级中视频| 狠狠狠色丁香婷婷综合激情| 捆绑调教美女网站视频一区| 国产最新精品免费| 亚洲综合色婷婷| 国产精品亚洲成人| 精品区一区二区| 午夜精彩视频在线观看不卡| 97se亚洲国产综合在线| 久久精品综合网| 日本一区中文字幕| 欧美日韩精品欧美日韩精品一 | 欧美一区午夜视频在线观看| 亚洲欧美乱综合| k8久久久一区二区三区| 精品女同一区二区| 开心九九激情九九欧美日韩精美视频电影| 成人亚洲一区二区一| 精品国产区一区| 国内久久婷婷综合| 久久伊人中文字幕| 国产精品一品二品| 国产女人水真多18毛片18精品视频 | 天天综合色天天综合色h| 色天天综合久久久久综合片| 综合色中文字幕| 成人av片在线观看| 国产精品国产a| fc2成人免费人成在线观看播放| 日韩一区二区三区四区五区六区| 夜夜揉揉日日人人青青一国产精品| 国产一区二区免费视频| 久久亚洲影视婷婷| 国产a精品视频| 国产精品精品国产色婷婷| 成人av网址在线观看| 亚洲欧洲一区二区在线播放| 91网站黄www| 亚洲免费观看在线观看| 在线影视一区二区三区| 一区二区三区精密机械公司| 欧美视频完全免费看| 日本va欧美va欧美va精品| 精品久久久久久无| 国产成人午夜片在线观看高清观看| 337p粉嫩大胆噜噜噜噜噜91av | 午夜av一区二区| 日韩一区二区精品在线观看| 老鸭窝一区二区久久精品| 久久久久久久网| 色综合天天狠狠| 全国精品久久少妇| 国产亚洲一区二区三区四区| 一本色道亚洲精品aⅴ| 午夜视频在线观看一区二区三区| 91超碰这里只有精品国产| 国产一区二区三区免费|