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

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

?? nf.c

?? nand型flash的讀、寫、擦除程序
?? C
?? 第 1 頁 / 共 4 頁
字號:
/*C**************************************************************************
* NAME:         nf.c
*----------------------------------------------------------------------------
* Copyright (c) 2004 leeyc.
*----------------------------------------------------------------------------
* RELEASE:      kt-1.0
* REVISION:     1.0   
*----------------------------------------------------------------------------
* PURPOSE:
* This file contains the high level NF routines
*****************************************************************************/
 
/*_____ I N C L U D E S ____________________________________________________*/
#include "includes.h"
#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 Uint16 nf_send_cmd = NF_CMD_LATCH_ENABLE_ADD; /* Command */
xdata Uint16 nf_send_add = NF_ADD_LATCH_ENABLE_ADD; /* Address */
xdata Uint16 volatile nf_data = NF_ADDRESS_CMD_DATA;/* Data    */


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

extern void send8(INT16U, INT8U);
extern void send16(INT16U, INT16U);
extern void send32(INT16U, INT32U);
extern void sendstr(INT16U, char *);
extern bit nf_erase_all_block (void);

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] = (Uint16)(gl_address >> 5);
 
          				}
          				/* Determine the last physical used block */
          				if ((byte_6 & 0xF8) == 0x10)         /* Used block */
          				{
            					last_physical_used_block[i] = (Uint16)(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[1] = Nf_rd_byte();     /* Read logical block address */
            					block2.b[0] = Nf_rd_byte();
            					if ((block2.b[1] & 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[0]] = block >> 8;
                						gl_buffer[2 * block2.b[0] + 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 = (Uint16)(temp_address >> 5);
            					gl_buffer[j] = (free_bloc_pos >> 8) | 0x80;
            					gl_buffer[j + 1] = free_bloc_pos;
          				}
        			}
        			if (half_page == 0)
        			{

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美肥妇毛茸茸| 成人夜色视频网站在线观看| 在线视频欧美区| 一区二区三区国产豹纹内裤在线| 一本色道亚洲精品aⅴ| 亚洲激情在线播放| 欧美三级电影在线看| 亚洲国产成人精品视频| 91精品国产高清一区二区三区 | 大胆亚洲人体视频| 中文字幕一区二区三区不卡在线 | 欧美性做爰猛烈叫床潮| 婷婷夜色潮精品综合在线| 日韩视频国产视频| 大陆成人av片| 亚洲一区二区三区在线| 在线91免费看| 国产精品一区二区果冻传媒| 国产精品毛片大码女人| 欧美专区日韩专区| 激情欧美一区二区三区在线观看| 中文字幕精品三区| 欧美日韩在线播| 国产乱子伦一区二区三区国色天香 | 麻豆免费看一区二区三区| 国产女人18水真多18精品一级做| 91免费观看视频在线| 日韩va亚洲va欧美va久久| 欧美经典三级视频一区二区三区| 色域天天综合网| 狠狠色综合色综合网络| ●精品国产综合乱码久久久久| 欧美日韩视频在线第一区| 国产成人综合在线观看| 亚洲在线视频免费观看| 日韩欧美国产综合| 色系网站成人免费| 国内精品视频666| 一区二区三区精品| 欧美国产成人精品| 91精品国产色综合久久久蜜香臀| 成人美女在线观看| 看片的网站亚洲| 亚洲人成在线观看一区二区| 日韩女优视频免费观看| 欧美亚洲尤物久久| 9人人澡人人爽人人精品| 免费日本视频一区| 亚洲高清视频在线| 《视频一区视频二区| 久久精品夜色噜噜亚洲a∨| 欧美精品乱码久久久久久| 99re在线视频这里只有精品| 九九视频精品免费| 久久精品国产色蜜蜜麻豆| 亚洲人妖av一区二区| 国产日韩欧美不卡| 日韩一级二级三级| 欧美日本一区二区在线观看| 91在线视频播放地址| 国产超碰在线一区| 九色|91porny| 久久疯狂做爰流白浆xx| 日本不卡免费在线视频| 亚洲电影欧美电影有声小说| 一区二区视频在线看| 国产精品毛片a∨一区二区三区| 26uuu欧美| 久久这里只有精品首页| 日韩精品一区二区三区在线播放| 欧美三级视频在线| 欧美日韩精品一区二区三区| 欧美性xxxxxxxx| 欧美亚洲高清一区| 91视频国产观看| 成人一区在线观看| 国模无码大尺度一区二区三区| 午夜av一区二区| 亚洲成人自拍一区| 亚洲婷婷综合色高清在线| 国产日韩欧美精品一区| 2020国产成人综合网| 精品精品国产高清一毛片一天堂| 欧美日韩国产一级| 欧美体内she精视频| 国产综合久久久久久鬼色 | 欧美精品一二三| 99久久综合色| 成人精品亚洲人成在线| 国产精品12区| 99精品欧美一区二区三区小说| 懂色av噜噜一区二区三区av| 紧缚捆绑精品一区二区| 久久99久久精品| 精品综合久久久久久8888| 韩国成人福利片在线播放| 美女视频黄久久| 国产精品亚洲午夜一区二区三区 | 狠狠狠色丁香婷婷综合激情| 九九国产精品视频| 国产精品99久久久| 国产在线播放一区| 国产二区国产一区在线观看| 国产精品99久久久久久久女警| 丁香婷婷深情五月亚洲| 国产mv日韩mv欧美| 成人高清在线视频| 色哟哟一区二区在线观看 | 亚洲精品视频在线观看网站| 曰韩精品一区二区| 婷婷综合久久一区二区三区| 蜜乳av一区二区| 国产精品白丝jk黑袜喷水| 国产美女一区二区三区| 国产伦精品一区二区三区免费迷| 国产成人免费视频一区| 91蜜桃在线观看| 欧美私人免费视频| 欧美国产精品久久| 亚洲最大的成人av| 麻豆成人91精品二区三区| 国产精品一区二区三区乱码| 91网站黄www| 69堂成人精品免费视频| 精品国产一区久久| 亚洲福利视频一区| 极品美女销魂一区二区三区免费| 国产成人8x视频一区二区| 一本到一区二区三区| 欧美一区二区在线视频| 欧美激情综合五月色丁香 | 国产清纯白嫩初高生在线观看91 | 中文在线一区二区| 亚洲国产一区二区在线播放| 日韩av成人高清| 国产99久久久国产精品潘金网站| 97精品久久久午夜一区二区三区 | 91在线一区二区三区| 91精品国产91综合久久蜜臀| 国产欧美一区在线| 日日噜噜夜夜狠狠视频欧美人| 国产精品99久久久| 欧美理论在线播放| 国产欧美日韩综合精品一区二区| 亚洲国产成人av| 成人高清视频在线观看| 日韩视频一区二区三区在线播放| 国产精品卡一卡二| 久久国产福利国产秒拍| 成人激情午夜影院| 久久久久久久久久久久久久久99| 亚洲综合视频在线| 成人一级视频在线观看| 亚洲一区在线看| 国产激情一区二区三区四区 | 日韩一区二区免费电影| 国产精品成人免费在线| 午夜日韩在线电影| av亚洲精华国产精华精华| 日韩欧美国产综合在线一区二区三区| 亚洲黄色在线视频| jvid福利写真一区二区三区| 精品日韩99亚洲| 日韩中文字幕区一区有砖一区| 91麻豆高清视频| 欧美日韩高清一区二区不卡| 一区二区三区四区国产精品| 成人毛片老司机大片| 久久影院视频免费| 麻豆传媒一区二区三区| 欧美日韩国产综合一区二区| 日韩一区在线免费观看| 久久精品久久精品| 久久久久久久久久电影| 狠狠色伊人亚洲综合成人| 日韩免费高清视频| 日韩av二区在线播放| 欧美电影一区二区| 亚洲成人福利片| 91精品国产91久久综合桃花| 亚洲精品老司机| 色呦呦网站一区| 一区二区三区小说| 色国产精品一区在线观看| 一区二区三区在线免费| 亚洲aⅴ怡春院| 日韩精品一区在线| 久久精品国产99| 精品国产一区二区三区av性色| 美女精品自拍一二三四| 欧美一区二区三区成人| 蜜桃久久久久久久| 国产精品视频看| 91天堂素人约啪| 亚洲无人区一区| 在线成人av网站| 免费在线观看一区| 国产无人区一区二区三区| 成人一道本在线| 亚洲一区在线播放|