u8 nandflash_write_buffer[NAND_SERECT_FULL_SIZE];

static int currentBlock = -1;

static int currentPage = -1;

//带缓冲的nand读取,不支持跨扇区

void NAND_Read_Addr_Mal(u32 addr,u8* buffer,u32 length)

{

u32 i = 0;

u32 readBlock = ((addr/NAND_SERECT_SIZE)/NAND_PAGE_NUM);//获取要写入的块

u32 readPage = ((addr/NAND_SERECT_SIZE)%NAND_PAGE_NUM);//获取要写入的页面

u32 readoffset = (addr%NAND_SERECT_SIZE);//写入位置偏移

u32 readPageCount = ((length + readoffset)/NAND_SERECT_SIZE);//获取一共需要写入的页

if(((length + readoffset)%NAND_SERECT_SIZE) != 0)readPageCount++;//比如刚好2048的时候,就还是在一页

if(readPageCount == 1)//仅读取一个快

{

//先检查当前需要读取的数据是不是在缓冲区中

if(currentBlock >= 0 && currentPage >= 0)

{

if(readBlock == currentBlock && readPage == currentPage)

{

//在缓冲区中读取数据

for(i = 0; i < length; i++)

{

buffer[i] = nandflash_write_buffer[readoffset+i];

}

}

else

{

//在物理设备中读取数据

NAND_Read_Random_Page(readBlock,readPage,readoffset,buffer,length);

}

}

else if(currentBlock == -1 && currentPage == -1)

{

//缓冲区为空,直接进行物理读取

NAND_Read_Random_Page(readBlock,readPage,readoffset,buffer,length);

}

}

else

{

//      printf("2 or up sector not vailed \r\n");

}

}

//带缓冲nand写入,不支持跨扇区

void NAND_Write_Addr_Mal(u32 addr,u8* buffer,u32 length)

{

u32 writeBlock = (addr/NAND_SERECT_SIZE)/NAND_PAGE_NUM; //获取要写入的块

u32 writePage = (addr/NAND_SERECT_SIZE)%NAND_PAGE_NUM;  //获取要写入的页面

u32 writeoffset = (addr%NAND_SERECT_SIZE);              //写入位置偏移

u32 i = 0;

u32 copy;

if(currentBlock >= 0 && currentPage >= 0)

{

if(currentBlock == writeBlock && currentPage == writePage)//没有切换页面,那么数据更新依旧在缓存中

{

for(i = writeoffset; i < writeoffset+length ;i++)

{

nandflash_write_buffer[i] = buffer[i-writeoffset];

}

}

else

{

//更新了页面的写入,先将缓存中数据写入物理设备,进行新的一轮缓存操作

copy = (currentBlock/42)+NAND_COPYBACL_BLOCK_START;

//擦除交换分区

NAND_Erase_Block(copy);

for(i = 0; i < NAND_PAGE_NUM;i++)//拷贝数据到交换分区

{

if(i != currentPage)

{

NAND_Copy_Back_Page(currentBlock,i,copy,i);

}

}

//擦除源分区

NAND_Erase_Block(currentBlock);

//将原来数据拷贝回去

for(i = 0; i < NAND_PAGE_NUM;i++)//拷贝数据到交换分区

{

if(i != currentPage)

{

NAND_Copy_Back_Page(copy,i,currentBlock,i);

}

}

//将缓存数据拷贝到目的分区

NAND_Write_Page_full(currentBlock,currentPage,NAND_SERECT_FULL_SIZE,nandflash_write_buffer);

//到这里缓存的写入物理设备完成,接下来开始新一轮缓存

NAND_Read_Full_Page(writeBlock,writePage,nandflash_write_buffer,NAND_SERECT_FULL_SIZE);

currentBlock = writeBlock;

currentPage = writePage;//更新标记

//接下来更新数据,数据更新在缓存中进行,切换的时候写入

for(i = writeoffset; i < writeoffset+length ;i++)

{

nandflash_write_buffer[i] = buffer[i-writeoffset];

}

}

}

else if(currentBlock == -1 && currentPage == -1)//当前缓存包里面没有数据

{

//从nand中读出来

NAND_Read_Full_Page(writeBlock,writePage,nandflash_write_buffer,NAND_SERECT_FULL_SIZE);

currentBlock = writeBlock;

currentPage = writePage;//更新标记

//接下来更新数据,数据更新在缓存中进行,切换的时候写入

for(i = writeoffset; i < writeoffset+length ;i++)

{

nandflash_write_buffer[i] = buffer[i-writeoffset];

}

}

}

void Nand_Flush(void)   //nand缓冲区刷入设备

{

u32 copy;

u32 i = 0;

//将还没有写入的数据刷新到nand中,标记归零

if(currentBlock >= 0 && currentPage >= 0)

{

//更新了页面的写入,先将缓存中数据写入物理设备,进行新的一轮缓存操作

copy = (currentBlock/42)+NAND_COPYBACL_BLOCK_START;

//擦除交换分区

NAND_Erase_Block(copy);

for(i = 0; i < NAND_PAGE_NUM;i++)//拷贝数据到交换分区

{

if(i != currentPage)

{

NAND_Copy_Back_Page(currentBlock,i,copy,i);

}

}

//擦除源分区

NAND_Erase_Block(currentBlock);

//将原来数据拷贝回去

for(i = 0; i < NAND_PAGE_NUM;i++)//拷贝数据到交换分区

{

if(i != currentPage)

{

NAND_Copy_Back_Page(copy,i,currentBlock,i);

}

}

//将缓存数据拷贝到目的分区

NAND_Write_Page_full(currentBlock,currentPage,NAND_SERECT_FULL_SIZE,nandflash_write_buffer);

currentBlock = -1;

currentPage = -1;

}

}

结合之前写的USB做U盘的例子来看,能降低写文件的时候的擦除次数

一种比较简单的在USB U盘中访问nandflash的方法的更多相关文章

  1. 一种基于自定义代码的asp.net网站访问IP过滤方法!

    对于一些企业内部核心系统,特别是外网访问的时候,为了信息安全,可能需要对外部访问的IP地址作限制,虽然IIS中也提供了根据IP地址或IP地址段进行限制或允许,但并没有提供根据IP地址所在的城市进行限制 ...

  2. CSharpGL(40)一种极其简单的半透明渲染方法

    CSharpGL(40)一种极其简单的半透明渲染方法 开始 这里介绍一个实现半透明渲染效果的方法.此方法极其简单,不拖累渲染速度,但是不能适用所有的情况. 如下图所示,可以让包围盒显示为半透明效果. ...

  3. I.MX6 简单电路模拟USB设备的插入

    /**************************************************************************** * I.MX6 简单电路模拟USB设备的插入 ...

  4. 用 Java 技术创建 RESTful Web (服务 JAX-RS:一种更为简单、可移植性更好的替代方式)

    作者: Dustin Amrhein, 软件工程师, IBM Nick Gallardo, 软件工程师, IBM 出处: http://www.ibm.com/developerworks/cn/we ...

  5. [1.6W字] 浏览器跨域请求限制的详细原理分析&寻找一种最简单的方式实现XHR跨域(9种方法, 附大招可以纯前端实现跨域!)

    Title/ 浏览器跨域(CrossOrigin)请求的原理, 以及解决方案详细指南 #flight.Archives011 序: 最近看到又有一波新的创作活动了, 官方给出的话题中有一个" ...

  6. 自己实现简单的AOP(二)引入Attribute 为方法指定增强对象

    话续前文 : 自己实现简单的AOP(一)简介 在前一篇文章中,对AOP的实现方式做了一个简单介绍.接下来,引入Attribute 为方法指定增强对象,由此实现一个简单的AOP. 注意:指定的是增强对象 ...

  7. 一种面向云服务的UCON多义务访问控制方法及系统

    )设置每一云服务的义务项:建立每一云服务所包含的义务图:2)根据用户所请求的云服务查找该云服务的所有强制义务图和可选义务图,并提取该用户对该云服务的历史完成情况:3)对每一强制义务图,监控其每一义务项 ...

  8. USB2.0协议学习笔记---USB工作过程(类的方法)

    前面学习了那么多的概念,这里需要记住一点分层概念即设备 ---> 配置 ---> 接口 ---> 端点,这种分层的概念结构 . 也可以理解为端点构成接口,接口组成配置,配置组成设备. ...

  9. macbook pro的usb串口失效的的处理方法

    macbook pro的usb串口失效的的处理方法 2011-08-24 12:14:32|  分类: mac|举报|字号 订阅     今天开电脑,无端端一个usb的串口失效了,接入鼠标 iphon ...

随机推荐

  1. LightOJ 1030 Discovering Gold 数学期望计算

    题目大意:给出长度为n的一条隧道,每个位置都有一定数量的财宝.给你一枚骰子,roll到几点就前进几步,如果即将到达的地方超过了这条隧道长度,就重新roll一次,走到n点结束.求这个过程能收获多少财宝. ...

  2. php 版本比较

    判断当前运行的 PHP 版本是否高于或等于你提供的版本号. function is_php($version) { static $_is_php; $version = (string) $vers ...

  3. 内联函数 inline 漫谈

    内联函数存在的结论是: 引入内联函数是为了解决函数调用效率的问题 由于函数之间的调用,会从一个内存地址调到另外一个内存地址,当函数调用完毕之后还会返回原来函数执行的地址.函数调用会有一定的时间开销,引 ...

  4. 快学Scala-第六章 对象

    知识点: 1.单例对象 使用object语法结构达到静态方法和静态字段的目的,如下例,对象定义某个类的单个实例,包含想要的特性,对象的构造器在该对象第一次被使用时调用. object Account{ ...

  5. org.apache.lucene.queryParser.ParseException: Encountered "<EOF>" at line 1, column 0.

    如果出现了下列错误,那是因为用错了函数.把queryParser.Query改称queryParser.parse就通过了 org.apache.lucene.queryParser.ParseExc ...

  6. elasticsearch高级配置之(二)----线程池设置

    elasticsearch 配置 线程池  一个Elasticsearch节点会有多个线程池,但重要的是下面四个:  索引(index):主要是索引数据和删除数据操作(默认是cached类型)  搜索 ...

  7. ubuntu 解压 windows 生成的 zip 文件乱码问题

    在windows上压缩的文件,是以系统默认编码中文来压缩文件.由于zip文件中没有声明其编码,所以linux上的unzip一般以默认编码解压,中文文件名会出现乱码. 有两种方式解决问题:(建议采用方法 ...

  8. Kyoto Cabinet--nosql型单机数据库

    摘要: Kyoto Cabinet是轻量级nosql型本地内存数据库 简介 Kyoto Cabinet是一个数据库管理的 lib,是 Tokyo Cabinet 的改进版本.数据库是一个简单的包含记录 ...

  9. hadoop伪分布式安装

    hadoop的伪分布安装:一台实体机或虚拟机的安装. 环境:Windows7.VMWare.CentOS 1.1 设置ip地址 说明:在CentOS中的网络的类型: 仅主机模式:虚拟机在Windows ...

  10. 手机号码抽奖系统(JS)

    <html><head><title>手机号码抽奖</title><meta http-equiv="Content-Type" ...