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

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

?? nf.c

?? 該原碼為在ateml的單片機(jī)上實(shí)現(xiàn)的mp3播放器.里面有電路圖和完整的源程序.
?? C
?? 第 1 頁(yè) / 共 4 頁(yè)
字號(hào):
/*C**************************************************************************
* NAME:         nf.c
*----------------------------------------------------------------------------
* Copyright (c) 2003 Atmel.
*----------------------------------------------------------------------------
* RELEASE:      snd1c-refd-nf-4_0_3      
* REVISION:     1.26     
*----------------------------------------------------------------------------
* PURPOSE:
* This file contains the high level NF 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_512B
  #error NF_CONFIG must be defined with NF_1X_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 ________________________________________________*/

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; /* address of current phys. sect. */  
data  Uint32  gl_address;                      /* general address variable */
data  Uint16  nf_look_up_table_block;          /* lut address (block) */
data  Byte    nf_zone;                         /* current zone number */
data  Byte    nf_gl_buf_idx;                   /* idx for cache */
data  Byte    gl_buf_free_idx ;                /* idx for cache for free blocks */
data  Uint16  gl_cpt_page;                     /* internal page counter */

bdata bit     nf_block_used;                    /* set when a block was used */
bdata bit     nf_busy;                          /* nand flash busy flag */
bdata bit     nf_lut_modified;                  /* LUT modified flag */
bdata bit     nf_reserved_space = FALSE;

idata Uint16  nf_logical_block;                /* current logical block */
idata Byte    nf_gl_buf_idx_max;               /* max index for updating lut */

xdata Byte    nf_spare_block;                  /* number of free block */
xdata Uint16  nf_lut_block[NF_ZONE_MAX];       /* lut address / zone (block) */
xdata Uint16  nf_buf_free[24];                 /* contain free physical block address */
xdata Uint16  nf_block_to_be_deleted;          /* give the address of the next deleted block */
xdata Uint16  nf_block_min;                    /* first address block in the buffer */
xdata Uint16  nf_block_max;                    /* last address block in the buffer */
xdata Union16 nf_buf[NF_BUFFER_SIZE];          /* cache 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 */

extern idata Uint16 nf_redundant_logical_block_value;/* Logical block value in the redundant area  */

#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 */
#endif


xdata Uint32 nf_mem_size;
xdata Uint32 nf_reserved_space_start;
/*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;
Uint16 block;
Uint16 j;                       /* counter */
Union16 block2;
bit   block_valid;
xdata Uint16 last_physical_used_block[NF_ZONE_MAX]; /* Last physical block used */

#define half_page block_valid
#define temp_address gl_ptr_mem
#define i nf_zone
#define start gl_cpt_page
#define end nf_look_up_table_block
#define free_bloc_pos nf_logical_block

  Nf_CS_ON();
  Nf_wait_busy();
  /* Global media initialization */
  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 */
  gl_buf_free_idx = 0;                      /* Free physical buffer idx */
  nf_old_zone = 0xFF;                       /* Previous zone number */
  for (i = 0; i < NF_ZONE_MAX_CPT; i++)
  {
    nf_lut_index[i] = 0;                    /* LUT index */
  }
  lut_is_present = 0x00;

  /***************************************************/
  /* For each zone, this following lines :           */
  /*   Search bad block                              */
  /*   Determine if a LUT is present                 */
  /*   Determine the last physical block             */ 
  /***************************************************/
  gl_address = 0;                           /* Start from physical sector 0 */
  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) << 10;/* Initialize the last used physical block value */

    for (j = NF_BLOCK_PER_ZONE; j != 0; j--)/* for each block */ 
    {
      Nf_read_open_C_area(gl_address, 0x05);
      if ( Nf_rd_byte() != 0xFF )           /* block status data : valid/invalid block */
      {
        nf_spare_block_number[i]--;         /* Defect block */
      }
      else                                  /* Block is valid */
      {
                                            /* Determine if the block is a specific block */
        byte_6 = Nf_rd_byte();
        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 |= (0x01) << i;
              nf_lut_block[i] = gl_address >> 5;
 
          }
          /* Determine the last physical used block */
          if ((byte_6 & 0xF8) == 0x10)         /* Used block */
          {
            last_physical_used_block[i] = gl_address >> 5;
          }
        }
      }
      gl_address += 32;
    }
  }


  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]) << 5;
      do
      {
        Nf_wait_busy();
        Nf_read_open_C_area(gl_address, 0x06);
        nf_lut_index[i]++;
        gl_address+=4;
      }
      while (Nf_rd_byte() == 0xE8);
      nf_lut_index[i]-=2;
      gl_address = gl_address - 8;
      Nf_read_open_C_area(gl_address, 0x00);
      if (Nf_rd_byte() != 0xFF)             /* LUT has been modified */
      {
        nf_block_erase(gl_address);
        lut_is_present &= ~((0x01) << i);   /* Reset bit */
        nf_lut_index[i] = 0;
      }
    }
  }
  /*****************************************************************/
  /*          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) << 10;            /* starting value for each zone */
      j = 0;
      if (block == start)                   /* starting block for scan */
      {
        block = start + 1023;
      }
      block_valid = FALSE;                  /* init flag block valid */
      Nf_wait_busy();
      do
      {
        gl_address = (Uint32)(block) << 5;
        Nf_read_open_C_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 */
        {
          block_valid = TRUE;               /* find a correct block */
        }
        else                                /* else decrease block number */
        {
          if (block == start)                       
          {
            block = start + 1023;
          }
          else
          {
            block--;
          }
        }
        j++;
      }
      while ((!block_valid ) && (j < 1024));
      if (j == 1024)
        return KO;
  
      nf_lut_block[i] = block;              /* Update look up table address */
    }
  }

  /**********************************************************/
  /* Create the look-up table                               */
  /* Process is done zone per zone and by step of 256 blocks*/
  /* ********************************************************/
  for (nf_zone = 0; nf_zone < NF_ZONE_MAX_CPT; nf_zone++)   /* for each zone */
  {
    half_page = 0;
    if (!(lut_is_present & (0x01 << nf_zone)))  /* If not LUT */
    {
      start = 0x00;
      end   = 0x80;     /* 256 bytes for gl_buffer <-> 128 blocks */                            
      free_bloc_pos = (Uint16)(last_physical_used_block[nf_zone]);
      gl_address    = (Uint32)(nf_lut_block[nf_zone]) << 5;        
      do
      {
        nf_init_buffer();                         /* Reinitialize the buffer */
        temp_address = (Uint32)(nf_zone) << 15;   /* We start at the beginning */
        block        = (Uint16)(nf_zone) << 10;
        Nf_wait_busy();
        for (j = NF_BLOCK_PER_ZONE; j != 0 ; j--) /* for each block */
        { 
          Nf_read_open_C_area(temp_address, 0x05);
          byte_5 = Nf_rd_byte();            /* Block status byte */
          if (byte_5 == 0xFF)               /* If not a bad block */
          {
            block2.b[0] = Nf_rd_byte();     /* Read logical block address */
            block2.b[1] = Nf_rd_byte();
            if ((block2.b[0] & 0xF8) == 0x10)
            {
              
              block2.w = (block2.w & 0x0FFF) >> 1;          
              if ((block2.w < end) && (block2.w >= start)) 
              { /* Save logical block value in the buffer */
                gl_buffer[2 * block2.b[1]] = block >> 8;
                gl_buffer[2 * block2.b[1] + 1] = block;
              }
            }
          }
          temp_address += 32; 
          block++;
        }
          
        /* affect to the free physical block a fictive logical block */
        /* free physical block => gl_buffer[x] = 0xFF */
        temp_address = (Uint32)(free_bloc_pos) << 5;
        for (j = 0; j <= 0xFE; j += 2)
        {
          if (gl_buffer[j] == 0xFF)
          {
            do                              /* Search free physical block */
            {
              temp_address += 32;
              if (temp_address >= ((Uint32)(nf_zone + 1) << 15))
                  temp_address = (Uint32)(nf_zone) << 15;
    
              Nf_read_open_C_area(temp_address, 0x05);
              
              byte_5 = Nf_rd_byte();        /* Invalid/Valid block */
              byte_6 = Nf_rd_byte();        /* Used/Unused block */
            }
            while (((byte_6 != 0xFF) && (byte_6 != 0xE8)) || (byte_5 != 0xFF));
  
            free_bloc_pos = temp_address >> 5;
            gl_buffer[j] = (free_bloc_pos >> 8) | 0x80;
            gl_buffer[j + 1] = free_bloc_pos;
          }
        }
        
        if (half_page == 0)
        {
          Nf_write_open_A_area(gl_address, 0x00); /* Write first part of LUT */
          nf_download_buffer();                   /* Write buffer */
          Nf_send_command(NF_PAGE_PROGRAM_CMD);   /* Launch programmation */

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产一区二区h| 在线观看一区二区精品视频| 一区二区三区在线免费播放| 日韩精品在线看片z| 91在线观看一区二区| 美女脱光内衣内裤视频久久网站| 亚洲三级电影全部在线观看高清| 精品剧情v国产在线观看在线| 91猫先生在线| 成人中文字幕在线| 久久99久久99小草精品免视看| 一区二区三区四区乱视频| 久久久久国产精品免费免费搜索 | 欧美午夜视频网站| k8久久久一区二区三区| 精品一区二区在线免费观看| 亚洲丶国产丶欧美一区二区三区| 亚洲天堂中文字幕| 亚洲国产成人在线| 国产日本一区二区| 精品国产一区二区三区久久久蜜月| 欧美亚洲愉拍一区二区| 99免费精品视频| 高清在线观看日韩| 国产盗摄精品一区二区三区在线 | 亚洲欧美日韩国产综合| 国产无遮挡一区二区三区毛片日本| 日韩一区二区三区观看| 在线成人免费视频| 欧美精品自拍偷拍动漫精品| 欧美亚洲国产一区二区三区| 色偷偷久久人人79超碰人人澡| 菠萝蜜视频在线观看一区| 成人午夜看片网址| 成人app软件下载大全免费| 国产69精品久久久久毛片| 国产麻豆精品久久一二三| 狠狠色丁香婷婷综合| 狠狠色综合日日| 国产精品一卡二卡| 成人夜色视频网站在线观看| 成人性生交大片免费| 成人av免费观看| 色综合久久99| 欧美视频在线一区二区三区 | 欧洲精品中文字幕| 91国产丝袜在线播放| 欧美男人的天堂一二区| 7777精品伊人久久久大香线蕉完整版 | 亚洲国产精品久久人人爱蜜臀| 亚洲精品成人悠悠色影视| 玉足女爽爽91| 午夜精品久久久久久不卡8050| 天堂资源在线中文精品| 日本一区中文字幕 | 欧美色图免费看| 欧美人牲a欧美精品| 欧美videos中文字幕| 国产亚洲美州欧州综合国| 国产精品乱人伦中文| 亚洲欧美视频一区| 亚洲18色成人| 国产一区二区不卡老阿姨| 99精品国产热久久91蜜凸| 欧美日韩国产首页| 精品日韩av一区二区| 国产精品免费人成网站| 亚洲韩国精品一区| 蜜臀av性久久久久蜜臀aⅴ流畅| 国产成人精品一区二区三区四区| 91视频com| 日韩欧美国产系列| 亚洲欧洲日韩综合一区二区| 亚洲国产欧美一区二区三区丁香婷| 蜜桃av一区二区| 成人激情视频网站| 7777精品伊人久久久大香线蕉最新版| 337p日本欧洲亚洲大胆色噜噜| 国产精品九色蝌蚪自拍| 天天影视涩香欲综合网| 国产精品一区二区在线观看不卡 | 中文字幕日韩一区| 日日夜夜免费精品| 国产99久久久国产精品潘金| 欧美日韩一级黄| 中文字幕免费一区| 日本成人在线电影网| 成人爱爱电影网址| 欧美成人免费网站| 亚洲激情校园春色| 国产馆精品极品| 欧美日韩在线不卡| 中文字幕一区二区三区乱码在线| 免费视频最近日韩| 色哟哟欧美精品| 久久久国产精品麻豆| 午夜精品久久久久影视| 99riav一区二区三区| 精品国产91九色蝌蚪| 亚洲国产精品麻豆| 色综合中文字幕国产| 欧美v亚洲v综合ⅴ国产v| 亚洲午夜免费电影| www.欧美色图| 久久―日本道色综合久久| 婷婷国产在线综合| 在线观看日韩毛片| 自拍偷在线精品自拍偷无码专区 | 久久激情综合网| 欧美日韩亚洲综合一区| 国产精品久久免费看| 国产一区二区在线视频| 91精品国产手机| 天天综合网 天天综合色| 在线观看区一区二| 亚洲欧美在线视频观看| 国产精品66部| 久久综合色之久久综合| 日韩主播视频在线| 欧美高清视频不卡网| 亚洲一区二区不卡免费| 91一区二区在线| 中文字幕五月欧美| 99久久精品免费| 中文字幕一区二区三区四区| 大胆亚洲人体视频| 国产肉丝袜一区二区| 国产最新精品精品你懂的| 精品电影一区二区三区| 久久99久久久欧美国产| 精品美女在线播放| 国产综合成人久久大片91| 精品少妇一区二区三区在线视频| 美女视频黄久久| 欧美精品一区二区久久婷婷| 精品一区二区三区不卡| 精品久久久久久久一区二区蜜臀| 美女免费视频一区| 26uuu色噜噜精品一区二区| 国产精品一二二区| 日本一区二区三区电影| 波多野结衣精品在线| **欧美大码日韩| 欧美亚洲图片小说| 日日摸夜夜添夜夜添精品视频 | 亚洲精品一线二线三线无人区| 久久精品国产亚洲高清剧情介绍| 日韩午夜精品视频| 国产综合成人久久大片91| 国产女主播视频一区二区| 99久久伊人精品| 夜夜精品视频一区二区| 91麻豆精品国产91久久久资源速度 | 欧美性极品少妇| 日本欧美在线观看| 久久―日本道色综合久久| 成人av网址在线| 亚洲综合一二区| 日韩视频免费观看高清完整版在线观看| 免费观看成人鲁鲁鲁鲁鲁视频| 久久久精品影视| 91免费国产在线| 性做久久久久久免费观看| 精品国产免费久久| 99久久精品国产毛片| 亚洲国产欧美在线人成| 精品日产卡一卡二卡麻豆| 99久久婷婷国产精品综合| 亚洲成av人片在线| 2019国产精品| 91麻豆精品在线观看| 日本成人在线一区| 国产精品污污网站在线观看| 欧美在线观看一二区| 久久99精品久久久久久动态图| 中文字幕一区二区日韩精品绯色| 欧美日韩一区成人| 国产伦理精品不卡| 夜夜揉揉日日人人青青一国产精品| 欧美r级在线观看| 色又黄又爽网站www久久| 久久99久久久欧美国产| 一区二区在线观看不卡| 精品成人佐山爱一区二区| 91亚洲精品一区二区乱码| 蜜臀久久久99精品久久久久久| 亚洲色图视频网站| 精品日韩在线一区| 欧美专区在线观看一区| 国产成a人无v码亚洲福利| 午夜精品久久久久影视| 亚洲视频你懂的| 国产亚洲午夜高清国产拍精品 | 精品久久久三级丝袜| 欧美综合欧美视频| 国产xxx精品视频大全| 美女在线一区二区| 亚洲大片一区二区三区| 国产精品美女久久久久高潮| 日韩欧美成人一区|