FLASH页写入

一、简介

       由于FLASH特性,页写入,扇区擦除。因此在写入时,需要考虑写入地址和写入长度并对其做相应处理,以下是代码实现,使用的FLASH模块是MX25L12835F。

二、代码实现

#define PAGE_SIZE  256

void FLASH_PAGE_WRITE(uint8_t* buf, uint32_t wICAddr, uint16_t numByteToWrite)
{
  uint8_t numOfPage, numOfSingle, offsetAddr, count;
  //写入整页数
  numOfPage = numByteToWrite / PAGE_SIZE;
  //写入整页后剩余字节数
  numOfSingle = numByteToWrite % PAGE_SIZE;
  //写入地址在页中的偏移量
  offsetAddr = wICAddr % PAGE_SIZE;
  //页中剩余可写入字节
  count = PAGE_SIZE - offsetAddr;

  //写入地址为整
  if (offsetAddr == 0)
  {
    //不足一页
    if (numOfPage == 0)
    {
      flash_write(wICAddr, buf, numOfSingle);
    }
    //超过一页
    else
    {
      //整页处理
      while (numOfPage --)
      {
        flash_write(wICAddr, buf, PAGE_SIZE);
        wICAddr += PAGE_SIZE;
        buf += PAGE_SIZE;
      }

      //不足一页处理
      if (numOfSingle != 0)
      {
        flash_write(wICAddr, buf, numOfSingle);
      }
    }
  }
  //写入地址不为整
  else
  {
    //不足一页
    if (numOfPage == 0)
    {
      //写入字节数不超过页中剩余可写入字节
      if (numOfSingle <= count)
      {
        flash_write(wICAddr, buf, numOfSingle);
      }
      //写入字节数超过页中剩余可写入字节
      else
      {
        flash_write(wICAddr, buf, count);
        wICAddr += count;
        buf += count;
        flash_write(wICAddr, buf, numOfSingle - count);
      }
    }
    //超过一页
    else
    {
      flash_write(wICAddr, buf, count);
      wICAddr += count;
      buf += count;
      numOfPage = (numByteToWrite - count) / PAGE_SIZE;
      numOfSingle = (numByteToWrite - count) % PAGE_SIZE;
      
      //整页处理
      while (numOfPage --)
      {
        flash_write(wICAddr, buf, PAGE_SIZE);
        wICAddr += PAGE_SIZE;
        buf += PAGE_SIZE; 
      }

      //不足一页的处理
      if (numOfSingle != 0)
      {
        flash_write(wICAddr, buf, numOfSingle );
      }
    }
  }
}

### NAND Flash 的最小写入单元 对于NAND Flash而言,Page是其最小的读写单位[^1]。这意味着任何一次有效的数据写入操作都至少要以一个完整的Page为基本粒度来进行。不同的制造商生产的NAND Flash设备中,Page的具体大小可能有所不同;常见的尺寸包括256字节、512字节、1024字节以及2048字节等选项[^3]。 尽管如此,在某些特定情境下,如果目标位置之前已被清零,则可以实现按单个字节级别的更新动作——即向指定面内的具体字节地址处写入新值。然而这种灵活性并不改变这样一个事实:从整体架构设计角度出发,仍然是Flash存储器最基础也是不可分割的操作对象之一[^4]。 因此,当提到“最小写入单元”的时候,应该理解为虽然理论上可以在已擦除区域按照更细颗粒度(比如字节级)来完成编程工作,但从硬件特性和标准协议层面看,Page才是真正的最低限度边界。 ```python # Python伪代码展示如何在一个已经擦除过的NAND Flash面上进行字节级别写入 def write_byte_to_page(page_address, byte_offset, data): """ 向给定面中的某个偏移量位置写入一字节数值 参数: page_address (int): 面起始地址 byte_offset (int): 字节偏移量 data (byte): 要写入的数据 返回: bool: 成功与否的状态标志 """ # 验证参数有效性... try: # 执行低层命令序列以设置目标位置并传输data send_command("SET_PAGE", page_address) send_command("WRITE_BYTE_AT_OFFSET", byte_offset, data) return True # 表明成功完成了该次写入请求 except Exception as e: print(f"Error during writing process: {e}") return False ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值