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

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

?? nf_drv.c

?? 單片機學習資料主要講述MP3開發 適合初學者進行開發學習
?? C
?? 第 1 頁 / 共 2 頁
字號:
    Nf_wait_busy();
    Nf_send_command (NF_RANDOM_DATA_INPUT_CMD);
    Nf_send_address (0x00);
    Nf_send_address (0x00);
    Nf_send_address ( ((Byte*)&nf_current_physical_sector_addr)[3] );     /* row address Byte 0       */
    Nf_send_address ( ((Byte*)&nf_current_physical_sector_addr)[2] );     /* row address Byte 1       */
    if (NF_5_CYCLE_ADDRESS_BIT)                                           /* size of nf > 128Mbytes ? */
      Nf_send_address ( ((Byte*)&nf_current_physical_sector_addr)[1] );   /* row address Byte 2       */

    for (j = ((Byte*)&gl_cpt_page)[0] >> 1; j != 0; j--)
    {
      nf_download_buffer();
      nf_download_buffer();
    }
    Nf_send_command (NF_RANDOM_DATA_INPUT_CMD);     /* spare area */
    ((Byte*)&gl_cpt_page)[0] = 0x08; 
    Nf_send_address(0x00);                          
    Nf_send_address(0x08);
    nf_update_spare_data();                         /* update spare data */
    Nf_send_command (NF_PAGE_PROGRAM_CMD);

    gl_cpt_page = 0;
    gl_ptr_mem++;
    ((Byte*)&nf_current_physical_sector_addr)[3]++;
    ((Byte*)&gl_address)[3]++;
  }

  if (((Byte*)&gl_ptr_mem)[3] & 0x3F)
  {
    for (j = (((Byte*)&gl_ptr_mem)[3] & 0x3F); j < 0x40; j++)
    {
      Nf_wait_busy();
      Nf_send_command (NF_READ_CMD);
      Nf_send_address (0x00);
      Nf_send_address (0x00);
      Nf_send_address ( ((Byte*)&gl_address)[3] );    /* row address Byte 0           */
      Nf_send_address ( ((Byte*)&gl_address)[2] );    /* row address Byte 1           */
      if (NF_5_CYCLE_ADDRESS_BIT)                     /* size of nf > 128Mbytes ?     */
        Nf_send_address ( ((Byte*)&gl_address)[1] );  /* row address Byte 2           */
      Nf_send_command (NF_COPY_BACK_CMD);
      Nf_wait_busy();
  
      Nf_send_command (NF_RANDOM_DATA_INPUT_CMD);
      Nf_send_address (0x00);
      Nf_send_address (0x00);
      Nf_send_address ( ((Byte*)&nf_current_physical_sector_addr)[3] );   /* row address Byte 0       */
      Nf_send_address ( ((Byte*)&nf_current_physical_sector_addr)[2] );   /* row address Byte 1       */
      if (NF_5_CYCLE_ADDRESS_BIT)                                         /* size of nf > 128Mbytes ? */
        Nf_send_address ( ((Byte*)&nf_current_physical_sector_addr)[1] ); /* row address Byte 2       */
      Nf_send_command (NF_PAGE_PROGRAM_CMD);
      nf_current_physical_sector_addr++;
      gl_address++;
    }
  }
}


/*F**************************************************************************
* NAME: nf_reassign_block
*----------------------------------------------------------------------------
* PARAMS:
*
* return:
*----------------------------------------------------------------------------
* PURPOSE:
*   Reassign the block value in LUT (copy of LUT)
*----------------------------------------------------------------------------
* EXAMPLE:
*----------------------------------------------------------------------------
* NOTE:
*----------------------------------------------------------------------------
* REQUIREMENTS: 
* ram/xram:
* cycle:
* stack: 
* code:
*****************************************************************************/
void nf_reassign_block (void)
{
Byte i;           /* Counter            */
Uint16 start;
Uint32 address2;  /* LUT source address */

  if (nf_lut_index[nf_zone] == 63)
  {
    if ((nf_buf_free[gl_buf_free_idx] & 0x7FFF) == nf_look_up_table_block)
    {
      gl_buf_free_idx++;
      if (gl_buf_free_idx > nf_spare_block)
      {
        gl_buf_free_idx = 0;
      }      
    }

    /* source address */
    address2 = ((Uint32)(nf_look_up_table_block)<<NF_SHIFT_SECTOR_BLOCK) + 63;

    nf_look_up_table_block = nf_buf_free[gl_buf_free_idx] & 0x7FFF;
    
    gl_buf_free_idx++;
    if (gl_buf_free_idx > nf_spare_block)
    {
      gl_buf_free_idx = 0;
    }      

    /* target addres */
    gl_address = ((Uint32)(nf_look_up_table_block) << NF_SHIFT_SECTOR_BLOCK);

    nf_lut_index[nf_zone] = 0;

  }
  else
  {
    /* source address */
    address2 = ((Uint32)(nf_look_up_table_block)<<NF_SHIFT_SECTOR_BLOCK) + nf_lut_index[nf_zone];
    nf_lut_index[nf_zone]++;
    /* target address */
    gl_address = address2 + 1;
  }

  /* prepare a copy back command to update the lut */
  Nf_wait_busy();
  Nf_send_command (NF_READ_CMD);
  Nf_send_address (0x00);                       /* column address Byte 0     */
  Nf_send_address (0x00);                       /* column address Byte 1     */
  Nf_send_address (((Byte*)&address2)[3]);      /* row address Byte 0        */
  Nf_send_address (((Byte*)&address2)[2]);      /* row address Byte 1        */
  if (NF_5_CYCLE_ADDRESS_BIT)                   /* size of nf > 128Mbytes ?  */
    Nf_send_address ( ((Byte*)&address2)[1] );  /* row address Byte 2        */
  Nf_send_command (NF_COPY_BACK_CMD);

  start = nf_block_min << 1;

  Nf_wait_busy();
  Nf_send_command (NF_RANDOM_DATA_INPUT_CMD);
  Nf_send_address (((Byte*)&start)[1]);           /* Column address Byte 0        */
  Nf_send_address (((Byte*)&start)[0]);           /* Column address Byte 1        */
  Nf_send_address ( ((Byte*)&gl_address)[3] );    /* Row address Byte 0           */
  Nf_send_address ( ((Byte*)&gl_address)[2] );    /* Row address Byte 1           */
  if (NF_5_CYCLE_ADDRESS_BIT)                     /* Size of nf > 128Mbytes ?     */
    Nf_send_address ( ((Byte*)&gl_address)[1] );  /* Row address Byte 2           */


  for (i = 0; i <= nf_gl_buf_idx_max; i++)
  {
    Nf_wr_byte (nf_buf[i].b[0]); 
    Nf_wr_byte (nf_buf[i].b[1]); 
  }

  Nf_send_command (NF_RANDOM_DATA_INPUT_CMD);     /* spare block */
  Nf_send_address(0xD0);                          /* logical block >= 1000 */
  Nf_send_address(0x07);
  
  for (i = 0; i <= 23; i++)
  {
    Nf_wr_byte (nf_buf_free[i]>>8);
    Nf_wr_byte (nf_buf_free[i]);
  }
  Nf_wr_byte(0xFF); Nf_wr_byte(0xFF); Nf_wr_byte(0xFF); Nf_wr_byte(0xFF); /* spare area */
  Nf_wr_byte(0xFF); Nf_wr_byte(0xFF); Nf_wr_byte(0xE8); Nf_wr_byte(0xFF);
  Nf_wr_byte(0xFF); Nf_wr_byte(0xFF); Nf_wr_byte(0xFF); Nf_wr_byte(0xE8);

  Nf_send_command(NF_PAGE_PROGRAM_CMD);   /* valid the page programmation */
   
  nf_gl_buf_idx_max = 0;  /* reset the max buff index */

  if (nf_lut_index[nf_zone] == 0)                             /* erase old lut */
  {
    address2 = (Uint32)(nf_lut_block[nf_zone])<<NF_SHIFT_SECTOR_BLOCK;
    nf_lut_block[nf_zone] = nf_look_up_table_block;           /* update address of look up table */
    Nf_wait_busy();
    Nf_send_command (NF_BLOCK_ERASE_CMD);                     /* Auto Block Erase Setup     */
    Nf_send_address ( ((Byte*)&address2)[3] );                /* row address Byte 1         */
    Nf_send_address ( ((Byte*)&address2)[2] );                /* row address Byte 2         */
    if (NF_5_CYCLE_ADDRESS_BIT)                               /* size of nf > 128Mbytes ?   */
      Nf_send_address ( ((Byte*)&address2)[1] );              /* row address Byte 3         */
    Nf_send_command(NF_BLOCK_ERASE_CONFIRM_CMD);              /* erase command              */
  }
}


/*F**************************************************************************
* NAME: nf_mark_bad_block
*----------------------------------------------------------------------------
* PARAMS:   
*           
* return:   
*----------------------------------------------------------------------------
* PURPOSE:
*   Write 0x00 on block status byte (Byte 5 of spare data)
*----------------------------------------------------------------------------
* EXAMPLE:
*----------------------------------------------------------------------------
* NOTE:
*   
*----------------------------------------------------------------------------
* REQUIREMENTS: 
* ram/xram:
* cycle:
* stack: 
* code:
*****************************************************************************/
void nf_mark_bad_block (void)
{
  Nf_wait_busy();
  Nf_write_open_spare_area(gl_address, 0x03);
  Nf_wr_byte(0x00);
  Nf_wr_byte(0x00);
  Nf_wr_byte(0x00);
  Nf_send_command (NF_PAGE_PROGRAM_CMD);  /* Send program command */
}


/*F**************************************************************************
* NAME: nf_block_erase
*----------------------------------------------------------------------------
* PARAMS:   
*
* return:
*   OK : erase done
*   KO : erase not done
*----------------------------------------------------------------------------
* PURPOSE: Erase a block on Nand Flash Media
*----------------------------------------------------------------------------
* EXAMPLE:
*----------------------------------------------------------------------------
* NOTE:
*
*----------------------------------------------------------------------------
* REQUIREMENTS: 
* ram/xram:
* cycle:
* stack: 
* code:
*****************************************************************************/
bit nf_block_erase (Uint32 pos)
{
  Nf_wait_busy();
  Nf_send_command (NF_BLOCK_ERASE_CMD);       /* Auto Block Erase Setup       */
  Nf_send_address ( ((Byte*)&pos)[3] );       /* Row address Byte 0           */
  Nf_send_address ( ((Byte*)&pos)[2] );       /* Row address Byte 1           */
  if (NF_5_CYCLE_ADDRESS_BIT)                     /* Size of card >= 128Mbytes ?  */
    Nf_send_address ( ((Byte*)&pos)[1] );     /* Row address Byte 2           */
  Nf_send_command(NF_BLOCK_ERASE_CONFIRM_CMD);/* Erase command              */
  return OK;
}


/*F**************************************************************************
* NAME: nf_erase_all_block
*----------------------------------------------------------------------------
* PARAMS:   
*           
* return:   
*   OK : erase done
*   KO : erase not done
*----------------------------------------------------------------------------
* PURPOSE:
*   This function erase all blocks on a NF and start the lut construction
*----------------------------------------------------------------------------
* EXAMPLE:
*----------------------------------------------------------------------------
* NOTE:
*   This function use the global variable Uint32 gl_address
*----------------------------------------------------------------------------
* REQUIREMENTS: 
* ram/xram:
* cycle:
* stack: 
* code:
*****************************************************************************/
bit nf_erase_all_block (void)
{
Byte i;
Uint16 j;
Uint16 block;
Uint16 block_reserved_space;
bit erase;
 
  Nf_CS_ON();
  /* Erase all block */
  block_reserved_space = (Uint16) (((nf_reserved_space_start >> NF_SHIFT_SECTOR_BLOCK) % 1000));
  gl_address = 0;
  for (nf_zone = 0; nf_zone < NF_ZONE_MAX_CPT; nf_zone++)
  {
    for (j = 1024; j != 0; j--)
    {
      Nf_wait_busy();
      Nf_read_open_spare_area(gl_address, 0x05);      /* Read block status byte */
      erase = TRUE;
      if (Nf_rd_byte() != 0xFF) /* if bad block */
      {
        erase = FALSE;          /* don't erase block */
      }
      else
      {
        ((Byte*)&block)[0] = Nf_rd_byte(); /* Read logical block address */
        ((Byte*)&block)[1] = Nf_rd_byte();
        if ( (MEM_RESERVED_SIZE != 0) && (nf_zone == (NF_ZONE_MAX_CPT - 1)))
        {
          if ((((Byte*)&block)[0] & 0xF8) == 0x10)
          {
            block = (block & 0x0FFF) >> 1;
            if (block >= block_reserved_space)      /* If it is a reserved block */
            {
              erase = FALSE;                        /* Don't erase block */
            }
          }
        }
      }

      if (NF_FULL_CHIP_ERASE == FALSE)
      {
        if (((Byte*)&block)[0] != 0xE8)
        {
          erase = FALSE;
        }
      }
      else
      {
        if (((Byte*)&block)[0] == 0x00)
        {
          erase = FALSE;
        }
      }

      if (erase)
      {
        nf_block_erase(gl_address);
        if (nf_check_status() == KO)
        { 
          nf_mark_bad_block(); /* Failure on erase operation */     
        }
        else
        { /* Fill redundant area with 0x00 */
          Nf_write_open_spare_area(gl_address, 0x00);
          for (i = 16; i != 0; i--)
            Nf_wr_byte(0x00);
          Nf_send_command(NF_PAGE_PROGRAM_CMD);        /* Valid the page programmation */
          if ( nf_check_status() == KO)
          { 
            nf_mark_bad_block();                        /* Failure on program operation */
          }
          else
          {
            Nf_read_open_spare_area(gl_address, 0x00);        /* Read 16 bytes */
            i = 16;
            while ((i != 0) && (Nf_rd_byte() == 0x00)) i--;

            if (i)
            {
              nf_mark_bad_block();
            }
            else
            {
              nf_block_erase(gl_address);          /* Finally, erase the block */      
              if ( nf_check_status() == KO)
              { /* Failure on erase operation */
                nf_mark_bad_block();      
              }
            }
          }
        }
      }
      gl_address += NF_PAGE_PER_BLOCK;
    }
  }
  Nf_CS_OFF();
  return (nf_read_spare_byte());
}




?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人福利视频在线| 日韩一级成人av| 国产综合一区二区| 精品国内二区三区| 福利91精品一区二区三区| 亚洲精品一卡二卡| 欧美精品1区2区3区| 国产精品18久久久久久久久久久久| 久久亚洲捆绑美女| 欧美无砖砖区免费| 另类欧美日韩国产在线| 亚洲人成在线观看一区二区| 717成人午夜免费福利电影| 成人动漫一区二区三区| 久久精品99久久久| 日韩va欧美va亚洲va久久| 玉足女爽爽91| 国产精品久线在线观看| 久久午夜色播影院免费高清 | 精品女同一区二区| 欧美群妇大交群的观看方式| 91污片在线观看| 成人高清视频在线观看| 国产在线播放一区二区三区| 日本aⅴ免费视频一区二区三区 | 欧美性感一区二区三区| 99国产精品久久久久久久久久| 久久精品国产一区二区三区免费看| 亚洲综合色在线| 亚洲一区二区三区四区中文字幕| 国产精品初高中害羞小美女文| 国产精品你懂的在线| 久久精品国产成人一区二区三区| 一级精品视频在线观看宜春院| 日本中文字幕一区二区有限公司| 亚洲国产精品久久久久秋霞影院| 亚洲成人午夜影院| 美女脱光内衣内裤视频久久影院| 国产一区二区久久| 成人午夜激情视频| 色婷婷av久久久久久久| 欧美男女性生活在线直播观看| 欧美妇女性影城| 久久久精品国产免费观看同学| 久久精品视频在线免费观看 | 欧美激情一区不卡| 亚洲精品乱码久久久久久久久| 爽爽淫人综合网网站| 成人一区在线观看| 欧美一级黄色片| 亚洲欧洲另类国产综合| 日本欧美一区二区| 成人av影院在线| 欧美一区二区三区视频免费播放| 国产情人综合久久777777| 亚洲一区二区三区四区五区中文 | 天天影视色香欲综合网老头| 国产精品白丝av| 精品国偷自产国产一区| 热久久一区二区| 91福利资源站| 亚洲人吸女人奶水| 久久国产欧美日韩精品| 欧美日韩一级片在线观看| 欧美国产综合色视频| 黄页网站大全一区二区| 精品久久一区二区| 狠狠色伊人亚洲综合成人| 欧美一级在线观看| 日韩电影免费一区| 欧美一区二区视频网站| 久久精品国产成人一区二区三区 | 欧美日韩成人综合在线一区二区| 久久精品亚洲乱码伦伦中文| 国产精品18久久久久久久久| 国产亚洲午夜高清国产拍精品| 国产美女一区二区三区| 国产欧美精品国产国产专区| 播五月开心婷婷综合| 亚洲精品视频在线看| 在线免费视频一区二区| 视频一区在线播放| 久久久久亚洲蜜桃| 99久久er热在这里只有精品66| 中文字幕人成不卡一区| 欧美日韩一区二区三区不卡| 久久疯狂做爰流白浆xx| 国产精品午夜在线观看| 欧美在线观看一区| 国产呦萝稀缺另类资源| 亚洲国产电影在线观看| 欧美日韩国产区一| 福利电影一区二区| 久热成人在线视频| 亚洲电影你懂得| 国产精品日韩成人| 日韩欧美电影一二三| 欧美在线色视频| 91一区一区三区| 欧美日韩黄色一区二区| 国产福利91精品一区二区三区| 一区二区三区不卡在线观看 | 奇米在线7777在线精品| 亚洲人成小说网站色在线| 精品国产一二三区| 日韩欧美一级片| 91精品国产综合久久久蜜臀图片| 一本色道久久综合精品竹菊| 国产成人av资源| 成人三级伦理片| 成人听书哪个软件好| 国产69精品久久99不卡| 国产成人鲁色资源国产91色综| 久久国产三级精品| 国产精品99久久久久久有的能看| 久久超碰97中文字幕| 精品一区二区在线视频| 国产激情偷乱视频一区二区三区| 蜜臀av性久久久久蜜臀aⅴ四虎| 国产一区中文字幕| 国产**成人网毛片九色 | 蜜臀av性久久久久蜜臀aⅴ流畅| 六月婷婷色综合| 成人深夜在线观看| 欧美女孩性生活视频| 国产片一区二区| 中文字幕人成不卡一区| 视频一区二区三区在线| 韩国一区二区三区| 在线视频你懂得一区| 精品国产乱码久久久久久图片| 久久精品欧美一区二区三区不卡| 日本一区二区三区免费乱视频| 亚洲欧美一区二区三区久本道91 | 欧美日韩在线播放| 国产精品欧美精品| 免费视频一区二区| 色综合天天综合网天天狠天天| 91精品免费观看| 亚洲麻豆国产自偷在线| 国产精品一区二区三区网站| 日韩欧美第一区| 日韩和的一区二区| 99re在线精品| 中文字幕一区在线观看视频| 黑人精品欧美一区二区蜜桃| 欧美在线观看视频一区二区| 久久久精品中文字幕麻豆发布| 天天影视涩香欲综合网| 色婷婷亚洲精品| 亚洲柠檬福利资源导航| 色综合久久天天| 亚洲精品videosex极品| av亚洲精华国产精华| 亚洲啪啪综合av一区二区三区| 国产精品综合在线视频| 欧美精品一区二区三区在线播放| 亚洲电影在线播放| 欧美日韩国产精品自在自线| 婷婷六月综合亚洲| 91精品欧美一区二区三区综合在| 美日韩一级片在线观看| 欧美成人精品1314www| 国产精品一区一区| 成人免费一区二区三区视频| 97久久精品人人做人人爽| 亚洲国产婷婷综合在线精品| 日本韩国一区二区三区视频| 婷婷综合久久一区二区三区| 日韩欧美国产麻豆| av中文字幕亚洲| 午夜精品爽啪视频| 久久久99久久| 欧美日韩一区不卡| 国产99久久精品| 亚洲一区二区三区四区五区黄| 91超碰这里只有精品国产| 婷婷综合在线观看| 国产亚洲视频系列| 欧美性视频一区二区三区| 日韩黄色免费电影| 亚洲精品老司机| 久久久一区二区三区捆绑**| 欧美视频一区二区在线观看| 亚洲欧洲精品成人久久奇米网| www.日韩精品| 美女视频网站久久| 亚洲欧美一区二区三区孕妇| 久久天堂av综合合色蜜桃网| 色噜噜狠狠色综合欧洲selulu| 美女视频一区二区| 五月婷婷综合网| 自拍偷拍国产精品| 欧洲色大大久久| voyeur盗摄精品| 国产在线乱码一区二区三区| 天天综合色天天| 亚洲一区二区三区四区在线| 国产色产综合产在线视频| 欧美va亚洲va在线观看蝴蝶网|