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

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

?? nf.c

?? 該原碼為在ateml的單片機(jī)上實(shí)現(xiàn)的mp3播放器.里面有電路圖和完整的源程序.
?? C
?? 第 1 頁(yè) / 共 5 頁(yè)
字號(hào):
/*C**************************************************************************
* NAME:         nf.c
*----------------------------------------------------------------------------
* Copyright (c) 2003 Atmel.
*----------------------------------------------------------------------------
* RELEASE:      snd1c-refd-nf-4_0_3      
* REVISION:     1.5     
*----------------------------------------------------------------------------
* PURPOSE:
* This file contains the high level NF routines for 2 NF slots
*****************************************************************************/

/*_____ 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_2X_512B
  #error NF_CONFIG must be defined with NF_2X_512B 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 ________________________________________________*/

extern  data    Uint32  gl_ptr_mem;         /* memory data pointer */
extern  pdata   Byte gl_buffer[];
extern  bdata   bit rx_bank;
extern          bit reserved_disk_space;



xdata Byte nf_send_cmd_odd At(NF_CMD_LATCH_ENABLE_ADD_ODD);       /* Command */
xdata Byte nf_send_add_odd At(NF_ADD_LATCH_ENABLE_ADD_ODD);       /* Address */
xdata Byte volatile nf_data_odd At(NF_ADDRESS_CMD_DATA_ODD);      /* Data    */

xdata Byte nf_send_cmd_even At(NF_CMD_LATCH_ENABLE_ADD_EVEN);     /* Command */
xdata Byte nf_send_add_even At(NF_ADD_LATCH_ENABLE_ADD_EVEN);     /* Address */
xdata Byte volatile nf_data_even At(NF_ADDRESS_CMD_DATA_EVEN);    /* Data    */

/*_____ D E C L A R A T I O N ______________________________________________*/

bdata bit nf_block_used;                            /* Set when a block was used                  */
bdata bit nf_busy;                                  /* indicate that nand flash is busy           */
bdata bit nf_lut_modified;                          /* indicate that LUT have been modified       */
bdata bit nf_zone_change;                           /* indicate that we have to change zone       */
bdata bit nf_parity_bit;
bdata bit nf_reserved_space = FALSE;


data  Uint16  gl_cpt_page;                          /* internal page counter (byte access)        */
data  Uint32  gl_address;                           /* general address variable                   */
data  Uint32  nf_current_physical_sector_addr_even; /* give the address of the current sector     */  
data  Uint32  nf_current_physical_sector_addr_odd;  /* give the address of the current sector     */  
data  Byte    nf_gl_buf_idx;

idata Byte    nf_zone;                              /* current zone number                        */
idata Byte    nf_gl_buf_free_idx ;
idata Byte    nf_gl_buf_idx_max;                    /* max index for updating LUT                 */
idata Byte    nf_spare_block;                       /* number of free block                       */
xdata Byte    nf_old_zone;                          /* for zone change                            */  
idata Uint16  nf_logical_block;                     /* Current logical block value                */
idata Uint16  nf_look_up_table_block;               /* look up table address (block)              */
xdata Uint16  nf_block_to_be_deleted_even;          /* give the address of the next deleted block */
xdata Uint16  nf_block_to_be_deleted_odd;           /* give the address of the next deleted block */
idata Uint16  nf_block_min;                         /* address of the first block in the buffer   */
idata Byte    block_max;                            /* address of the last block in the buffer    */

xdata t_free_blocks buf_free[24];                   /* contain free physical block address        */
xdata Byte lut_index[NF_ZONE_MAX];                  /* give the index for updating LUT            */
xdata Uint16 lut_block[NF_ZONE_MAX];                /* LUT address (block value)                  */
xdata Byte nf_spare_block_number[NF_ZONE_MAX];      /* Number of free spare block in each zone    */
xdata t_lut   buf[NF_BUFFER_SIZE];                  /* Buffer for write operation                 */

xdata Uint32 nf_mem_size;
xdata Uint32 nf_reserved_space_start;

#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_4_cycle_address;                 /* nf_4_cycle_address definition                */
  bdata bit     nf_copy_back;                       /* copy back command available                  */

#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
  YES       |   0x73  |   16MB    | 512 |S - T(3,3V)  | no
  YES       |   0x33  |   16MB    | 512 |S    (1,8V)  | no
  YES       |   0x75  |   32MB    | 512 |S    (3,3V)  | yes
  YES       |   0x75  |   32MB    | 512 |T    (3,3V)  | no
  YES       |   0x76  |   64MB    | 512 |S    (3,3V)  | yes
  YES       |   0x76  |   64MB    | 512 |T    (3,3V)  | no
  YES       |   0x79  |  128MB    | 512 |S    (3,3V)  | yes
  YES       |   0x79  |  128MB    | 512 |T    (3,3V)  | no
  no        |   0xA1  |  128MB    |2048 |S    (1,8V)  | yes
  no        |   0xF1  |  128MB    |2048 |S    (3,3V)  | yes
  no        |   0xAA  |  256MB    |2048 |S    (1,8V)  | yes
  no        |   0xDA  |  256MB    |2048 |S    (3,3V)  | yes
**************************************************************************************/


/*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;         /* 5th byte of spare data */
Byte    byte_6;         /* 6th byte of spare data */
Byte    tmp_spare;      /* dummy 8 bits data      */
Byte    i;              /* counter                */
Uint16  j;              /* counter                */
Uint32  temp_address;   /* dummy 32 bits data     */              
Uint16  start;          /* start value for the construction of the LUT */
Uint16  end;            /* final value            */
Uint16  block;          /* 16 bits dummy data     */
Union16 block2;         /* 16 bits dummy data     */
bdata bit     block_valid;
bdata bit     lut_part;
xdata Uint16  free_bloc_pos_even;
xdata Uint16  free_bloc_pos_odd;
xdata Uint16  last_physical_used_block_even[NF_ZONE_MAX]; /* Last physical block used     */
xdata Uint16  last_physical_used_block_odd[NF_ZONE_MAX];  /* Last physical block used     */
xdata Byte    lut_is_present[NF_ZONE_MAX];


  /* Global media initialization */
  nf_old_zone        = 0xFF;
  nf_block_min       = 0xFFFF;          /* starting buffer value    */
  nf_gl_buf_idx_max  = 0;               /* max index in the buffer  */
  nf_lut_modified    = FALSE;           /* buffer change flag       */
  nf_gl_buf_idx      = 0;               /* main buffer index        */
  nf_gl_buf_free_idx = 0;               /* free physical buffer idx */
  for (i = 0; i < NF_ZONE_MAX_CPT; i++)
  {
    lut_index[i] = 0;                   /* LUT index                */
    lut_is_present[i] = FALSE;
  }

  /***************************************************/
  /* For each zone, this following lines :           */
  /*   Search bad block                              */
  /*   Determine if a LUT is present                 */
  /*   Determine the last physical block             */ 
  /***************************************************/

  Nf_CS_EVEN();
  Nf_wait_busy_even();

  for (i = 0; i < NF_ZONE_MAX_CPT; i++)                     /* for each zone */
  {
    gl_address = i << 5;   
    nf_spare_block_number[i] = 23;                          /* Initialize the spare block table */
    last_physical_used_block_even[i] = (Uint16)(i);         /* Initialize the last used physical block value */

    for (j = NF_BLOCK_PER_ZONE; j != 0; j--)                /* for each block */ 
    {
      Nf_read_open_C_area_even(gl_address, 0x05);
      if (Nf_rd_byte_even() != 0xFF )                       /* block status data : valid/invalid block */
      {
        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_even();                                 /* 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
        {
          /* Determine if the block is the look up table */ 
          if (byte_6 == 0xE8)                       /* look up table ? */
          {
            lut_is_present[i] = TRUE;
            lut_block[i] = gl_address >> 5;
          }
          /* Determine the last physical used block */
          if ( (byte_6 & 0xF8) == 0x10)             /* Used block  */
          {
            last_physical_used_block_even[i] = gl_address >> 5;
          }
        }

      }
      gl_address += (NF_ZONE_MAX_CPT << 5);
    }
  }



  Nf_CS_ODD();
  Nf_wait_busy_odd();

  for (i = 0; i < NF_ZONE_MAX_CPT; i++)                             /* for each zone */
  {
    gl_address =  i << 5;
    tmp_spare = 23;                                                 /* Initialize the spare block table */
    last_physical_used_block_odd[i] = (Uint16)(i);                  /* Initialize the last used physical block value */

    for (j = NF_BLOCK_PER_ZONE; j != 0; j--)                        /* for each block */ 
    {
      Nf_read_open_C_area_odd(gl_address, 0x05);
      byte_5 = Nf_rd_byte_odd();
      if ( byte_5 != 0xFF )                                         /* block status data : valid/invalid block */
      {
        tmp_spare--;                                                /* Defect block */
        if (tmp_spare < 4)
          return KO;

      }
      else                                                          /* Block is valid */
      {
                                                                    /* Determine is the block is a specific block */
        byte_6 = Nf_rd_byte_odd();
        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 */
           )
        { 
          tmp_spare--;                                              /* specific or invalid block */
          if (tmp_spare < 4)
            return KO;

        }
        else
        {
          if (byte_6 == 0xE8)                                       /* look up table ? */
          {
            Nf_wait_busy_odd();
            Nf_send_command_odd (NF_READ_A_AREA_CMD);
            Nf_send_command_odd (NF_BLOCK_ERASE_CMD);               /* Auto Block Erase Setup */
            Nf_send_address_odd ( ((Byte*)&gl_address)[3] );        /* 2nd address cycle*/
            Nf_send_address_odd ( ((Byte*)&gl_address)[2] );        /* 3rd address cycle*/
            if (NF_4_CYCLE_ADDRESS_BIT)                             /* Size of card >= 64Mbytes ?*/
              Nf_send_address_odd ( ((Byte*)&gl_address)[1] );      /* 4th address cycle*/
            
            Nf_send_command_odd(NF_BLOCK_ERASE_CONFIRM_CMD);        /* Erase command */
          }
          if ( (byte_6 & 0xF8) == 0x10)                             /* Used block  */
          {
            last_physical_used_block_odd[i] = gl_address >> 5;
          }
        }

      }
      gl_address += (NF_ZONE_MAX_CPT << 5);
    }

    if (nf_spare_block_number[i] > tmp_spare)
    {
      nf_spare_block_number[i] = tmp_spare;
    }
  }
  
  Nf_CS_EVEN();
  Nf_wait_busy_even();
  /* Determine index for each correct lut */
  for (i = 0; i < NF_ZONE_MAX_CPT; i++)
  { 
    if (lut_is_present[i] == TRUE)                                  
    {
      gl_address = ((Uint32)(lut_block[i]) << 5);
      do
      {
        Nf_read_open_C_area_even(gl_address, 0x06);
        lut_index[i]++;
        gl_address += NB_PAGE_BY_LUT;
        Nf_wait_busy_even();
        byte_6 = Nf_rd_byte_even();
      }
      while ((byte_6 == 0xE8) && ((gl_address & 0x1F) != 0));

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美一级片在线看| 欧美日韩免费一区二区三区视频| 欧美亚洲综合网| 亚洲欧美日韩小说| 成人午夜电影网站| 国产亚洲综合av| 国产一区二区在线影院| 欧美大片在线观看一区二区| 日韩影院精彩在线| 欧美日韩国产片| 日韩精品欧美成人高清一区二区| 国产色一区二区| 日韩欧美的一区二区| 色综合激情五月| 亚洲一区二区视频在线| 欧美一区二区三区免费在线看| 99久久精品国产毛片| 亚洲在线免费播放| 国产精品免费视频网站| 91丨九色丨蝌蚪富婆spa| 亚洲成人免费电影| 91精品国产一区二区三区蜜臀| 97久久久精品综合88久久| 国产精品一区二区三区乱码 | 国产日韩v精品一区二区| 成人午夜精品在线| 国产麻豆一精品一av一免费 | 欧美va日韩va| 国产一区视频网站| 蜜臀久久99精品久久久画质超高清| 日韩情涩欧美日韩视频| 9人人澡人人爽人人精品| 午夜伊人狠狠久久| 亚洲国产色一区| 久久婷婷国产综合精品青草| 不卡的av中国片| 蜜桃av噜噜一区二区三区小说| 亚洲第一激情av| 亚洲线精品一区二区三区八戒| 综合自拍亚洲综合图不卡区| 91精品麻豆日日躁夜夜躁| 成人丝袜18视频在线观看| 国产精品18久久久| 日本女优在线视频一区二区| 国产精品久久久久久久久免费丝袜| 欧美日韩另类一区| 欧美午夜影院一区| 欧美疯狂做受xxxx富婆| 成人av免费网站| 成人午夜av影视| 99久久国产综合精品色伊| 色综合久久久久久久久久久| 色综合天天综合色综合av| 久草中文综合在线| 一片黄亚洲嫩模| 国产精品国模大尺度视频| 国产精品天干天干在线综合| 亚洲欧美自拍偷拍色图| 久久伊人蜜桃av一区二区| 久久久99精品免费观看不卡| 亚洲国产精品激情在线观看| 欧美成人vps| 中文一区在线播放| 亚洲黄色av一区| 亚洲欧美一区二区视频| 一区二区三区小说| 奇米精品一区二区三区四区| 亚洲bdsm女犯bdsm网站| 精品一区二区免费在线观看| 国产精品自拍毛片| 日本精品视频一区二区| 色噜噜久久综合| 欧美一级黄色录像| 国产精品久久久久久久裸模| 亚洲成av人片在线观看| 国产一区二区主播在线| 日本精品免费观看高清观看| 日韩免费一区二区| 国产精品看片你懂得| 性欧美大战久久久久久久久| 国产一区91精品张津瑜| 在线观看免费亚洲| 欧美在线免费视屏| 亚洲精品一区二区在线观看| 欧美成人精品福利| 亚洲欧美一区二区在线观看| 免费视频最近日韩| 99精品国产一区二区三区不卡| 欧美精品在线观看一区二区| 日本一区二区三区电影| 亚洲成人免费在线观看| 国产成人99久久亚洲综合精品| 国产精品一二二区| 欧美色视频一区| 国产日产欧产精品推荐色| 午夜电影一区二区| 美女www一区二区| 色综合婷婷久久| 国产片一区二区| 免费人成在线不卡| 一本到高清视频免费精品| 精品久久国产字幕高潮| 五月综合激情日本mⅴ| www.亚洲免费av| 久久综合色综合88| 天天综合日日夜夜精品| 91视视频在线观看入口直接观看www | 91精品国产综合久久久久久久久久 | 欧美韩日一区二区三区| 美女视频一区二区三区| 在线观看av一区| 国产精品久久久久久久久免费樱桃| 老司机精品视频一区二区三区| 国产精一品亚洲二区在线视频| 欧美日韩免费在线视频| 亚洲精选在线视频| 99re热这里只有精品视频| 国产午夜亚洲精品不卡| 韩国av一区二区三区| 成人国产精品免费观看动漫| 欧美精品一区二区三区视频| 日本中文一区二区三区| 欧美日韩色一区| 一区二区久久久久久| 91论坛在线播放| 亚洲欧美在线观看| 99精品桃花视频在线观看| 久久精品视频在线看| 极品销魂美女一区二区三区| 91精品一区二区三区久久久久久 | 4438x亚洲最大成人网| 亚洲夂夂婷婷色拍ww47| 欧美影院一区二区| 一区二区激情小说| 欧美色综合影院| 艳妇臀荡乳欲伦亚洲一区| 91亚洲永久精品| 亚洲黄色片在线观看| 欧美伊人久久大香线蕉综合69| 一区二区三区免费网站| 欧美综合欧美视频| 亚洲自拍偷拍网站| 欧美日韩一区二区三区四区五区| 亚洲一区日韩精品中文字幕| 欧美伊人久久久久久久久影院| 亚洲一区二区视频在线观看| 欧美日韩一二三区| 婷婷国产v国产偷v亚洲高清| 日韩欧美专区在线| 国产综合久久久久久鬼色| 国产午夜亚洲精品理论片色戒| 成人美女视频在线看| 亚洲人成网站在线| 欧美日本在线看| 精品一区二区三区免费视频| 欧美精品一区二区在线播放| 成人在线综合网| 亚洲精品高清视频在线观看| 91精品久久久久久蜜臀| 狠狠色狠狠色合久久伊人| 欧美国产欧美综合| 在线观看一区二区精品视频| 视频精品一区二区| 久久久精品2019中文字幕之3| 日韩精品五月天| 久久精品人人做人人爽97| 99久久精品久久久久久清纯| 偷拍与自拍一区| 欧美精品一区二区三区四区| av在线一区二区三区| 亚洲成a天堂v人片| 久久久一区二区三区捆绑**| 色综合色狠狠综合色| 日韩精品91亚洲二区在线观看| 久久亚洲一级片| 91视频在线观看| 老司机免费视频一区二区三区| 中文字幕一区二区三区蜜月| 在线不卡的av| 国产盗摄视频一区二区三区| 亚洲黄色录像片| www一区二区| 色欧美乱欧美15图片| 麻豆精品一区二区综合av| 国产精品成人免费| 欧美一区二区三区在线观看视频| 成人黄色网址在线观看| 日精品一区二区| 中文字幕在线观看一区二区| 欧美日本国产一区| 99精品视频在线观看| 久久电影网电视剧免费观看| 一区二区成人在线| 国产欧美日韩三级| 欧美一区在线视频| 91在线观看污| 国产麻豆日韩欧美久久| 亚洲成在线观看| 亚洲日本在线a| 国产性色一区二区|