⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 nf.c

📁 一个可作为mp3播放器固件的代码集,包括解码,播放,控制,任务管理等.
💻 C
📖 第 1 页 / 共 5 页
字号:
        Usb_write_byte(Nf_rd_byte_even());
        Usb_write_byte(Nf_rd_byte_even());
        Usb_write_byte(Nf_rd_byte_even());
        Usb_write_byte(Nf_rd_byte_even());
        Usb_write_byte(Nf_rd_byte_even());
        Usb_write_byte(Nf_rd_byte_even());
        Usb_write_byte(Nf_rd_byte_even());
        Usb_write_byte(Nf_rd_byte_even());
        Usb_write_byte(Nf_rd_byte_even());
        Usb_write_byte(Nf_rd_byte_even());
        Usb_write_byte(Nf_rd_byte_even());
        Usb_write_byte(Nf_rd_byte_even());
        Usb_write_byte(Nf_rd_byte_even());
        Usb_write_byte(Nf_rd_byte_even());
        Usb_write_byte(Nf_rd_byte_even());
        Usb_write_byte(Nf_rd_byte_even());
        Usb_write_byte(Nf_rd_byte_even());
        Usb_write_byte(Nf_rd_byte_even());
        Usb_write_byte(Nf_rd_byte_even());
        Usb_write_byte(Nf_rd_byte_even());
        Usb_write_byte(Nf_rd_byte_even());
        Usb_write_byte(Nf_rd_byte_even());
        Usb_write_byte(Nf_rd_byte_even());
        Usb_write_byte(Nf_rd_byte_even());
        Usb_write_byte(Nf_rd_byte_even());
        Usb_write_byte(Nf_rd_byte_even());
        Usb_write_byte(Nf_rd_byte_even());
        Usb_write_byte(Nf_rd_byte_even());
        Usb_write_byte(Nf_rd_byte_even());
        Usb_write_byte(Nf_rd_byte_even());
        Usb_write_byte(Nf_rd_byte_even());
        Usb_write_byte(Nf_rd_byte_even());
        Usb_write_byte(Nf_rd_byte_even());
        Usb_write_byte(Nf_rd_byte_even());
        Usb_write_byte(Nf_rd_byte_even());
        Usb_write_byte(Nf_rd_byte_even());
        Usb_write_byte(Nf_rd_byte_even());
        Usb_write_byte(Nf_rd_byte_even());
        Usb_write_byte(Nf_rd_byte_even());
        Usb_write_byte(Nf_rd_byte_even());
        Usb_write_byte(Nf_rd_byte_even());
        Usb_write_byte(Nf_rd_byte_even());
        Usb_write_byte(Nf_rd_byte_even());
        Usb_write_byte(Nf_rd_byte_even());
        if (begin_ping_pong)
        {
          begin_ping_pong = FALSE;
        }
        else
        {
          while (!Usb_tx_complete());         /* wait end of transfer */
          Usb_clear_TXCMPL();                 /* ack transfer         */
        }
        Usb_set_TXRDY();                      /* start usb transfer   */    
      }

    }
    gl_ptr_mem++;                             /* new page             */
    nf_parity_bit = ~nf_parity_bit;
    if ( !(((Byte*)&gl_ptr_mem)[3] & 0x3F) )  /* New block ?          */
    {
      nf_read_open(gl_ptr_mem);
    }
    nb_sector--;
  }
  while (nb_sector != 0);

  while (!Usb_tx_complete());             /* wait end of transfer */
  Usb_clear_TXCMPL();                     /* ack transfer */

  return OK;

}

/*F**************************************************************************
* NAME: nf_write_open
*----------------------------------------------------------------------------
*----------------------------------------------------------------------------
* PARAMS:
*   pos: address of the the next write data
*
* return:
*----------------------------------------------------------------------------
* PURPOSE:
*   Low level memory write update
*----------------------------------------------------------------------------
* EXAMPLE:
*----------------------------------------------------------------------------
* NOTE:
*----------------------------------------------------------------------------
* REQUIREMENTS:
*****************************************************************************/
bit nf_write_open (Uint32 pos)
{
Byte i;
Byte j;
bit change_zone = FALSE;


  gl_ptr_mem = pos;
  gl_cpt_page = 0;

  
  /* Determine the logical block value */
  nf_logical_block = (gl_ptr_mem >> 6);              /* 64 pages by block */
  nf_zone = 0;

  while (nf_logical_block > 999)
  {
    nf_logical_block -= 1000;
    nf_zone++;
  }

  if (nf_zone != nf_old_zone)
  {
    change_zone = TRUE;
    if (nf_lut_modified)
    { /* save old lut */
      i = nf_old_zone;
      nf_old_zone = nf_zone;
      nf_zone = i;
      nf_reassign_block();
      nf_lut_modified = FALSE;
      nf_zone = nf_old_zone;
    }
    else
    { /* update old zone value */
      nf_old_zone = nf_zone;
    }
    nf_block_min        = 0xFFFF;
    nf_gl_buf_free_idx  = 0;
  }

  if ( (nf_logical_block >= nf_block_min) && (nf_logical_block < (nf_block_min + NF_BUFFER_SIZE - 4))) 
  { /* we don't have to update the buffer */
    nf_calc_logical_block();
    nf_gl_buf_idx = nf_logical_block - nf_block_min;
  }
  else 
  { /* we have to update the buffer */
    /* Store the look up table block address */
    nf_look_up_table_block =  lut_block[nf_zone];
    /* If LUT have been modified */
    if (nf_lut_modified)           
    {
      nf_reassign_block();      /* update the LUT */
    }
    /* Calculate the address for LUT access */
    gl_address = (((Uint32)(nf_look_up_table_block))<<5);
    gl_address += (((Uint32)(lut_index[nf_zone]))<<3);
    gl_address += ((Uint32)(nf_logical_block) >> 7);
    nf_calc_logical_block();                        /* Calculate the redundant block address value  */
    i = nf_logical_block & 0x7F;                    /* i = logical % 128                            */
    nf_spare_block = nf_spare_block_number[nf_zone];/* initialize the number of spare block         */
    nf_block_min = nf_logical_block;                /* logical block range value                    */
    block_max = ( (nf_logical_block + NF_BUFFER_SIZE) > 999) ? (1000 - nf_logical_block) : NF_BUFFER_SIZE;

    Nf_CS_EVEN();
    Nf_wait_busy_even();                                            /* Open the look-up table     */
    if (nf_logical_block & 0x40)
    {
      Nf_send_command_even(NF_READ_B_AREA_CMD);                     /* 2nd half page              */
      Nf_send_address_even((Byte)(nf_logical_block & 0x3F) << 2); 
    }
    else
    {
      Nf_send_command_even(NF_READ_A_AREA_CMD);                     /* first half page            */
      Nf_send_address_even((Byte)(nf_logical_block & 0x3F) << 2);
    }

    Nf_send_address_even ( ((Byte*)&gl_address)[3] );               /* 2nd address cycle          */
    Nf_send_address_even ( ((Byte*)&gl_address)[2] );               /* 3rd address cycle          */
    if (NF_4_CYCLE_ADDRESS_BIT)                                     /* Size of card >= 64Mbytes ? */
      Nf_send_address_even ( ((Byte*)&gl_address)[1] );             /* 4th address cycle          */

    Nf_wait_busy_even();

    for (j = 0; j < block_max ; j++)
    {
      /* Read conversion table : 64 datas */
      buf[j].even.b[0] = Nf_rd_byte_even();
      buf[j].even.b[1] = Nf_rd_byte_even();
      buf[j].odd.b[0]  = Nf_rd_byte_even();
      buf[j].odd.b[1]  = Nf_rd_byte_even();
      i++;
      if (i >= 0x80)
      {
        i = 0;
        gl_address++;
        Nf_read_open_A_area_even(gl_address, 0x00);
      }
    }
  
    if (change_zone)        /* If it is a new zone, then load the spare buffer */
    {
      gl_address = ((Uint32)(nf_look_up_table_block)<<5);
      gl_address += (Uint32)(lut_index[nf_zone])<<3;
      gl_address += (NB_PAGE_BY_LUT - 1);            /*  = offset for page of free blocks */
      Nf_read_open_B_area_even(gl_address, 160);

      for (i = 0; i <= nf_spare_block; i++)
      {
        buf_free[i].even  = (Uint16)(Nf_rd_byte_even()<<8);
        buf_free[i].even  += Nf_rd_byte_even();
        buf_free[i].odd   = (Uint16)(Nf_rd_byte_even()<<8);
        buf_free[i].odd   += Nf_rd_byte_even();
      }
    }
    nf_gl_buf_idx = 0;           /* initialize index for main buffer         */
    nf_gl_buf_idx_max = 0;       /* initialize the max index for the buffer  */
    nf_gl_buf_free_idx = 0;

  }
  
  /* if block is already assigned, then invert with a spare block */
  nf_block_used = ( !(buf[nf_gl_buf_idx].even.w & 0x8000) ) ? TRUE : FALSE;
  if (nf_block_used)
  {
    if ((buf_free[nf_gl_buf_free_idx].even & 0x7FFF) == nf_look_up_table_block)
    {
      nf_gl_buf_free_idx++;
      if (nf_gl_buf_free_idx >= nf_spare_block  )
      {
        nf_gl_buf_free_idx = 0;
      }      
    }
    /* assign block to be deleted */
    nf_block_to_be_deleted_even = buf[nf_gl_buf_idx].even.w;
    nf_block_to_be_deleted_odd  = buf[nf_gl_buf_idx].odd.w;
    
    buf[nf_gl_buf_idx].even.w = buf_free[nf_gl_buf_free_idx].even;
    buf[nf_gl_buf_idx].odd.w  = buf_free[nf_gl_buf_free_idx].odd;
    
    buf_free[nf_gl_buf_free_idx].even = nf_block_to_be_deleted_even | 0x8000;
    buf_free[nf_gl_buf_free_idx].odd  = nf_block_to_be_deleted_odd  | 0x8000;
    
    nf_gl_buf_free_idx++;

    /* increase the index for spare block buffer */
    if (nf_gl_buf_free_idx >= nf_spare_block  )
    {
      nf_gl_buf_free_idx = 0;
    }

  }
  
  /* Mark block as assigned */
  buf[nf_gl_buf_idx].even.w &= 0x7FFF;  
  buf[nf_gl_buf_idx].odd.w &= 0x7FFF;     

  if (nf_gl_buf_idx > nf_gl_buf_idx_max)
    nf_gl_buf_idx_max = nf_gl_buf_idx;

  /* Update the current physical sector address */
  nf_current_physical_sector_addr_even = ((Uint32)(buf[nf_gl_buf_idx].even.w) << 5);
  nf_current_physical_sector_addr_odd = ((Uint32)(buf[nf_gl_buf_idx].odd.w) << 5);


  if ( nf_block_used )                   /* Fisrt block already used block ?  */
  { 
    nf_copy_block_head();             /* Copy the first part of the block  */
  }
  else                                 
  { 
    nf_init_spare();                   /* else init spare data for new logical block  */
  }

  nf_busy = FALSE;                     /* Clear flag busy */

  nf_lut_modified = TRUE;

    /* Calculate the address for LUT access */
  gl_address = (((Uint32)(nf_look_up_table_block))<<5);
  gl_address += (((Uint32)(lut_index[nf_zone]))<<3);

  /* mark LUT as modified */
  Nf_CS_EVEN();
  Nf_wait_busy_even();    
  Nf_write_open_C_area_even(gl_address, 0x00);
  Nf_wr_byte_even(0x00);
  Nf_send_command_even(NF_PAGE_PROGRAM_CMD);
  Nf_wait_busy_even();
  if (((Byte*)&gl_ptr_mem)[3]  & 0x01)
    nf_parity_bit = NF_ODD;
  else
    nf_parity_bit = NF_EVEN;
  return OK; 
}


/*F**************************************************************************
* NAME: nf_write_close
*----------------------------------------------------------------------------
* PARAMS:
*
* return:
*----------------------------------------------------------------------------
* PURPOSE:
*   Low level memory write close: release NF 
*----------------------------------------------------------------------------
* EXAMPLE:
*----------------------------------------------------------------------------
* NOTE:
*----------------------------------------------------------------------------
* REQUIREMENTS:
*****************************************************************************/
bit nf_write_close (void)
{ 
  if (gl_cpt_page != 0)                   /* uncomplete write page session  */
  {
    if (nf_parity_bit == NF_ODD)
    {
      while (((Byte*)&gl_cpt_page)[0] != 0x02) 
      {
        Nf_wr_byte_odd(0x00);
        gl_cpt_page++;
      }
      nf_update_spare_data();
      Nf_send_command_odd(NF_PAGE_PROGRAM_CMD);
      nf_current_physical_sector_addr_odd++;
    }
    else

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -