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

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專(zhuān)輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? nf.c

?? 單片機(jī)學(xué)習(xí)資料主要講述MP3開(kāi)發(fā) 適合初學(xué)者進(jìn)行開(kāi)發(fā)學(xué)習(xí)
?? C
?? 第 1 頁(yè) / 共 5 頁(yè)
字號(hào):
/*C**************************************************************************
* NAME:         nf.c
*----------------------------------------------------------------------------
* Copyright (c) 2003 Atmel.
*----------------------------------------------------------------------------
* RELEASE:      snd1c-refd-nf-4_0_3      
* REVISION:     1.11     
*----------------------------------------------------------------------------
* PURPOSE:
* This file contains the high level NF with 2Kb page routines
*****************************************************************************/
 
/*_____ I N C L U D E S ____________________________________________________*/


#include "config.h"                           /* system configuration */
#include "board.h"                            /* board definition  */
#include "lib_mcu\usb\usb_drv.h"              /* usb driver definition */
#include "nf.h"                               /* NF definition */


/*_____ M A C R O S ________________________________________________________*/

#ifndef NF_CAPACITY_AUTO_DETECT
  #error  NF_CAPACITY_AUTO_DETECT must be defined in board.h
#endif

#if NF_CONFIG != NF_1X_2KB
  #error NF_CONFIG must be defined with NF_1X_2KB in config.h
#endif

#ifndef NF_FULL_CHIP_ERASE
  #error NF_FULL_CHIP_ERASE  must be set to TRUE or FALSE in config.h
#endif

#ifndef MEM_RESERVED_SIZE
  #error MEM_RESERVED_SIZE must be defined in config.h
#endif


/*_____ D E F I N I T I O N ________________________________________________*/

xdata Byte nf_send_cmd At(NF_CMD_LATCH_ENABLE_ADD);   /* Command */
xdata Byte nf_send_add At(NF_ADD_LATCH_ENABLE_ADD);   /* Address */
xdata Byte volatile nf_data At(NF_ADDRESS_CMD_DATA);  /* Data    */

/*_____ D E C L A R A T I O N ______________________________________________*/
extern  data    Uint32  gl_ptr_mem;               /* memory data pointer                        */
extern  pdata   Byte gl_buffer[];
extern          bit reserved_disk_space;

data  Uint32  nf_current_physical_sector_addr;   /* give the address of the current sector     */  
data  Uint32  gl_address;                        /* general address variable                   */
data  Uint16  nf_look_up_table_block;            /* look up table address (block)              */
data  Uint16  gl_cpt_page;                       /* internal page counter (byte access)        */
data  Byte    nf_zone;                           /* current zone number                        */
data  Byte    nf_gl_buf_idx;
data  Byte    gl_buf_free_idx ;

bdata bit nf_block_used = FALSE;                  /* Set when a block was used                  */
bdata bit nf_busy = FALSE;                        /* indicate that nand flash is busy           */
bdata bit nf_lut_modified = FALSE;                /* indicate that LUT have been modified       */
bdata bit nf_wr_open = FALSE;                     /* indicate that a write command is required  */ 
bdata bit nf_reserved_space = FALSE;

idata Uint16  nf_logical_block;                   /* Current logical block value                */
idata Byte    nf_gl_buf_idx_max;                  /* max index for updating LUT                 */

xdata Uint16  nf_lut_block[NF_ZONE_MAX];          /* LUT address (block value)                  */
xdata Uint16  nf_buf_free[24];                    /* contain free physical block address        */
xdata Byte    nf_spare_block;                     /* number of free block                       */
xdata Uint16  nf_block_to_be_deleted;             /* give the address of the next deleted block */
xdata Uint16  nf_block_min;                       /* address of the first block in the buffer   */
xdata Uint16  nf_block_max;                       /* address of the last block in the buffer    */
xdata Union16 nf_buf[NF_BUFFER_SIZE];             /* Buffer for write operation                 */
xdata Byte    nf_old_zone;                        /* for zone change                            */  
xdata Byte    nf_lut_index[NF_ZONE_MAX];          /* give the index for updating LUT            */
xdata Byte    nf_spare_block_number[NF_ZONE_MAX]; /* Number of free spare block in each zone    */




xdata Uint32 nf_mem_size;
xdata Uint32 nf_reserved_space_start;
xdata Uint32 save_gl_ptr_mem;
xdata Uint32 save_physical_sector;
bit nf_write_advanced = FALSE;
bit nf_close_write_session = FALSE;

#if (NF_CAPACITY_AUTO_DETECT == TRUE)             /* If autodetect capacity nand flash is active  */
  xdata Byte    nf_zone_max;                      /* nf_zone_max definition                       */
  xdata Byte    nf_device_type;                   /* nf_device_type definition                    */
  bdata bit     nf_5_cycle_address;               /* nf_5_cycle_address definition                */
#endif



/**************************************************************************************
manufacturer code :
            0x98                Toshiba
            0xEC                Samsung


supported   |  device |  capacity |     |manufacturer | Copy back
by this     |   code  |           |     |S : Samsung  | supported
driver      |         |           |     |T : Toshiba  |
------------------------------------------------------------------------------------
  no        |   0x39  |    8MB    | 512 |S    (1,8V)  | no
  no        |   0xE6  |    8MB    | 512 |S - T(3,3V)  | no
  no        |   0x73  |   16MB    | 512 |S - T(3,3V)  | no
  no        |   0x33  |   16MB    | 512 |S    (1,8V)  | no
  no        |   0x75  |   32MB    | 512 |S    (3,3V)  | yes
  no        |   0x75  |   32MB    | 512 |T    (3,3V)  | no
  no        |   0x76  |   64MB    | 512 |S    (3,3V)  | yes
  no        |   0x76  |   64MB    | 512 |T    (3,3V)  | no
  no        |   0x79  |  128MB    | 512 |S    (3,3V)  | yes
  no        |   0x79  |  128MB    | 512 |T    (3,3V)  | no
  yes       |   0xA1  |  128MB    |2048 |S    (1,8V)  | yes
  yes       |   0xF1  |  128MB    |2048 |S    (3,3V)  | yes
  yes       |   0xAA  |  256MB    |2048 |S    (1,8V)  | yes
  yes       |   0xDA  |  256MB    |2048 |S    (3,3V)  | yes
**************************************************************************************/


/*F**************************************************************************
* NAME: nf_force_write_close
*----------------------------------------------------------------------------
* PARAMS:
*
* return:
*----------------------------------------------------------------------------
* PURPOSE:
*   End of write close function.
*----------------------------------------------------------------------------
* EXAMPLE:
*----------------------------------------------------------------------------
* NOTE:
*   Call to this function is mandatory after a write session.
*   Flag nf_close_write_session must be set to 1 during the call to 
*   nf_write_close() function.
*   This flag must be reset after a call to nf_force_write_close().
*----------------------------------------------------------------------------
* REQUIREMENTS:
*****************************************************************************/
void nf_force_write_close(void)
{
  /* Copy last part of a block if the block was assigned */
  Nf_CS_ON();
  if (nf_block_used)
  {
    if ( (((Byte*)&gl_ptr_mem)[3] & 0x3F) || (gl_cpt_page != 0) ) 
      nf_copy_block_tail();
    nf_block_erase((Uint32)(nf_block_to_be_deleted) << NF_SHIFT_SECTOR_BLOCK);    /* Erase old block */
    nf_block_used = FALSE;
  }
}


/*F**************************************************************************
* NAME: nf_read_spare_byte
*----------------------------------------------------------------------------
* PARAMS:
*
* return:
*   OK : LUT construction complete
*   KO : pb for LUT
*----------------------------------------------------------------------------
* PURPOSE:
*   read spare data byte and construct the look up table.
*----------------------------------------------------------------------------
* EXAMPLE:
*----------------------------------------------------------------------------
* NOTE:
*----------------------------------------------------------------------------
* REQUIREMENTS:
*****************************************************************************/
bit nf_read_spare_byte(void)
{
Byte byte_5;
Byte byte_6;
Byte lut_is_present;
Byte page;
Uint16 block;
Uint16 j;                       /* counter */
Uint16 i;                       /* counter */
Uint16 start;                   /* start value for the construction of the LUT */
Uint16 end;                     /* final value */
Uint16 free_bloc_pos;
Union16 block2;
bit   block_valid;
xdata Uint16 last_physical_used_block[NF_ZONE_MAX]; /* Last physical block used */
#define temp_address  gl_ptr_mem

  Nf_CS_ON();

  lut_is_present      = 0x00;         
  nf_close_write_session = FALSE;
  for (i = 0; i < NF_ZONE_MAX_CPT; i++)
  {
    nf_lut_index[i] = 0;                /* LUT index */
  }

  /***************************************************/
  /* For each zone, this following lines :           */
  /*   Search bad block                              */
  /*   Determine if a LUT is present                 */
  /*   Determine the last physical block             */ 
  /***************************************************/
  gl_address = 0;
  Nf_wait_busy();
                                      
  for (i = 0; i < NF_ZONE_MAX_CPT; i++)                               /* for each zone */

  {
    nf_spare_block_number[i] = 23;                                    /* initialize the spare block table */
    last_physical_used_block[i] = (Uint16)(i) << NF_SHIFT_BLOCK_ZONE; /* initialize the last used physical block value */
    for (j = NF_BLOCK_PER_ZONE; j != 0; j--)        
    {
      Nf_read_open_spare_area(gl_address, 0x05);
      if ( Nf_rd_byte() != 0xFF )                                     /* block status : valid/invalid */
      {
        nf_spare_block_number[i]--;                                   /* Defect block  */
        if (nf_spare_block_number[i] < 4)
          return KO;
      }
      else                                                            /* Block is valid */
      {
        byte_6 = Nf_rd_byte();                                        /* Determine is the block is a specific block */
        if (  (byte_6 == 0x00) ||                                     /* 0x00 = specific block */
              ( (byte_6 != 0xFF) && ( (byte_6 & 0xF8) != 0x10 ) &&    /* Value in redundant spare area not correct */
                (byte_6 != 0xE8) )                                    /* Don't care about LUT block */
           )
        { 
          nf_spare_block_number[i]--;                                 /* specific or invalid block */
          if (nf_spare_block_number[i] < 4)
            return KO;

        }
        else
        {
          if (byte_6 == 0xE8)                                         /* look up table ? */
          {
              lut_is_present |= (0x01) << i;
              nf_lut_block[i] = gl_address >> NF_SHIFT_SECTOR_BLOCK;
          }

          if ( (byte_6 & 0xF8) == 0x10)                               /* Determine the last physical used block */
          {
            last_physical_used_block[i] = gl_address >> NF_SHIFT_SECTOR_BLOCK;
          }
        }

      }
      gl_address += NF_PAGE_PER_BLOCK;
    }
  }

  for (i = 0; i < NF_ZONE_MAX_CPT; i++)
  { /* Determine the index for each correct lut */
    if ((lut_is_present & (0x01 << i)))
    {
      gl_address = (Uint32)(nf_lut_block[i]) << NF_SHIFT_SECTOR_BLOCK;
      do
      {
        Nf_read_open_spare_area(gl_address, 0x06);
        nf_lut_index[i]++;
        gl_address++;
        byte_6 = Nf_rd_byte();
      }
      while ((byte_6 == 0xE8) && ((gl_address & 0x3F) != 0)); 
      if ((byte_6 == 0xE8) && ((gl_address & 0x3F) == 0))
      {
        nf_lut_index[i]--;
        gl_address--;
      }
      else
      {
        nf_lut_index[i]-=2;
        gl_address-=2;
      }      

      Nf_read_open_spare_area(gl_address, 0x00);
      if (Nf_rd_byte() != 0xFF)                       /* LUT have been modified */
      {
        nf_block_erase(gl_address);
        lut_is_present &= ~((0x01) << i);             /* Reset bit */
        nf_lut_index[i] = 0;
        Nf_wait_busy();
      }

    }
  }
  /*****************************************************************/
  /*          Find free physical block for LUT for each zone       */
  /*****************************************************************/
  for (i = 0; i < NF_ZONE_MAX_CPT; i++)
  {
    if (!(lut_is_present & (0x01 << i)))
    {
      block = last_physical_used_block[i];
      start = (Uint16)(i) << NF_SHIFT_BLOCK_ZONE;                   /* starting value for each zone */
      j = 0;
      if (block == start)                                           /* starting block for scan      */
      {
        block = start + 1023;
      }
      block_valid = FALSE;                                          /* init flag block valid */
      do
      {
        gl_address = (Uint32)(block) << NF_SHIFT_SECTOR_BLOCK;
        Nf_read_open_spare_area(gl_address, 0x05);
        byte_5 = Nf_rd_byte();
        byte_6 = Nf_rd_byte();
  
        if ( (byte_5 == 0xFF) && (byte_6 == 0xFF) ) /* not assigned and valid block */

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲日本丝袜连裤袜办公室| 亚洲欧美二区三区| 91精品视频网| 欧美日韩国产首页在线观看| 在线免费观看日韩欧美| 日本高清成人免费播放| 在线观看网站黄不卡| 欧美日韩一区 二区 三区 久久精品| 91免费看`日韩一区二区| 色综合视频在线观看| 在线观看免费视频综合| 欧美日本视频在线| 日韩午夜激情视频| 久久久久久免费毛片精品| 中文字幕欧美日韩一区| 国产精品成人一区二区艾草| 一区二区视频在线| 亚洲123区在线观看| 免费成人在线影院| 国产真实乱对白精彩久久| 成人一区二区三区中文字幕| 97国产一区二区| 欧美午夜电影在线播放| 日韩欧美亚洲国产另类| 国产农村妇女毛片精品久久麻豆| 中文字幕一区二区三区四区| 亚洲综合在线观看视频| 日韩国产精品久久久| 久久aⅴ国产欧美74aaa| 不卡一区二区中文字幕| 欧日韩精品视频| 欧美电影免费观看高清完整版在线观看 | 欧美日韩一级片在线观看| 欧美日韩另类国产亚洲欧美一级| 欧美一级夜夜爽| 久久久青草青青国产亚洲免观| 国产精品久久久久影院色老大| 一区二区三区免费在线观看| 奇米777欧美一区二区| 国产成人综合精品三级| 欧美午夜寂寞影院| 国产午夜三级一区二区三| 樱花草国产18久久久久| 久久99精品国产麻豆婷婷洗澡| 成人免费毛片aaaaa**| 欧美精品tushy高清| 国产午夜一区二区三区| 亚洲国产中文字幕在线视频综合| 精品一区二区三区日韩| 91成人在线精品| 久久夜色精品国产欧美乱极品| 亚洲精品久久7777| 国产在线国偷精品免费看| 欧美羞羞免费网站| 国产欧美精品区一区二区三区| 亚洲国产成人va在线观看天堂| 国内外成人在线| 欧美日韩在线综合| 欧美极品美女视频| 日本免费新一区视频| 91网站黄www| 国产午夜久久久久| 捆绑变态av一区二区三区| 日本道免费精品一区二区三区| 久久久久九九视频| 蜜臀av性久久久久蜜臀aⅴ流畅| 色哟哟国产精品| 欧美国产综合色视频| 久久国产日韩欧美精品| 欧美午夜在线一二页| 国产精品久久久久久久岛一牛影视| 免费成人av资源网| 欧美视频中文字幕| 亚洲欧美日韩电影| 丁香婷婷综合色啪| 精品国产免费人成电影在线观看四季| 一二三四社区欧美黄| 97se亚洲国产综合自在线| 久久青草欧美一区二区三区| 天天综合网天天综合色| 在线一区二区观看| 最新久久zyz资源站| 风流少妇一区二区| 26uuu久久综合| 久久国产精品色婷婷| 欧美精品xxxxbbbb| 亚洲国产日韩一级| 在线精品视频免费播放| 亚洲婷婷在线视频| 99免费精品视频| 中文字幕精品一区二区三区精品| 狠狠色丁香婷综合久久| 欧美一级日韩免费不卡| 日韩激情在线观看| 欧美另类一区二区三区| 亚洲成人自拍偷拍| 欧美日韩在线电影| 五月天精品一区二区三区| 欧美中文字幕一区二区三区 | 成人欧美一区二区三区在线播放| 国产suv精品一区二区6| 日本一区二区三区四区| 成人综合日日夜夜| 国产精品污www在线观看| 国产91清纯白嫩初高中在线观看| 久久这里都是精品| 国产福利一区在线| 国产精品网曝门| 91啦中文在线观看| 一区二区三区精品视频在线| 欧美亚洲综合另类| 偷拍日韩校园综合在线| 制服丝袜激情欧洲亚洲| 美腿丝袜亚洲一区| 久久久久国产免费免费| 成人黄页在线观看| 亚洲美女视频一区| 欧美日韩成人一区二区| 男女男精品网站| 久久日韩粉嫩一区二区三区| 成人h动漫精品一区二| 综合精品久久久| 欧美午夜视频网站| 麻豆精品一区二区三区| 国产日韩精品一区二区浪潮av| av电影在线观看一区| 亚洲中国最大av网站| 欧美一级高清片| 国产99久久久精品| 亚洲黄色尤物视频| 日韩一区二区电影| 成人精品亚洲人成在线| 怡红院av一区二区三区| 日韩一区二区精品葵司在线 | 欧美日韩国产综合一区二区| 日本不卡的三区四区五区| 久久精品视频免费| 99riav一区二区三区| 日本大胆欧美人术艺术动态 | 精品一区二区久久| 国产精品美女久久久久aⅴ国产馆 国产精品美女久久久久av爽李琼 国产精品美女久久久久高潮 | 91精品国产色综合久久不卡蜜臀| 九九**精品视频免费播放| 最新国产の精品合集bt伙计| 欧美巨大另类极品videosbest| 国产一区二区在线视频| 亚洲卡通动漫在线| 精品日产卡一卡二卡麻豆| 91免费视频大全| 精品一区二区国语对白| 一区二区三区鲁丝不卡| 精品99一区二区三区| 日本高清不卡视频| 国产一区二区在线观看免费| 亚洲精品成人精品456| 精品国产电影一区二区| 色播五月激情综合网| 国内成人精品2018免费看| 一区二区三区日韩欧美| 欧美精品一区二区三区蜜桃| 91九色02白丝porn| 国产九色精品成人porny | 91视视频在线观看入口直接观看www| 国产福利一区二区| 亚洲精品高清在线| 国产亚洲精品aa| 日韩丝袜美女视频| 欧美三级日韩在线| 成人av午夜影院| 久久99精品国产麻豆婷婷| 亚洲一区二区三区中文字幕在线| 久久久av毛片精品| 欧美一区二区三区免费观看视频| 99视频热这里只有精品免费| 国产乱码精品一区二区三区五月婷| 亚洲国产精品尤物yw在线观看| 国产精品久久午夜夜伦鲁鲁| 久久综合色鬼综合色| 制服丝袜一区二区三区| 欧洲一区在线电影| 成人免费不卡视频| 国产成人免费在线观看| 激情综合五月婷婷| 免费成人在线观看视频| 偷拍一区二区三区| 亚洲午夜视频在线观看| 亚洲品质自拍视频| 中文字幕一区二| 国产精品美女久久久久久久久久久| 久久蜜桃av一区精品变态类天堂| 欧美一区二区啪啪| 欧美日韩精品专区| 欧美人妇做爰xxxⅹ性高电影| 91丨porny丨蝌蚪视频| 99视频有精品| 91香蕉视频在线| 99久久精品情趣| 99精品视频免费在线观看| 波多野洁衣一区| av不卡免费电影|