当前位置:首页 > 嵌入式 > 嵌入式硬件

下面是按页读操作函数的C语言代码。
sbit RdyorBsy=P0^0;
unsigned ch ar xdata * data pK9F;
void PageRead(unsigned int ColAdd,unsigned long
RowAdd,unsigned int len)
{
unsigned int i=0;
unsigned ch ar ColTemp,RowTemp;
ColTemp=(unsigned ch ar)(ColAdd>>8);
RowTemp=(unsigned ch ar)(RowAdd>>16);
ColTemp &=0x0F;
RowTemp &=0x01;

pK9F=0x8002;
* pK9F=0x00;
pK9F=0x8001;
* pK9F=(unsigned ch ar)(ColAdd);
* pK9F=ColTemp;
* pK9F=(unsigned cha r)(RowAdd);
* pK9F=(unsigned ch ar)(RowAdd>>8);
* pK9F=RowTemp;
pK9F=0x8002;
* pK9F=0x30;

while(RdyorBsy);
while(!RdyorBsy);
pK9F=0x8000;
for(i=0;i
OutputData[i]= * pK9F;
}
3.2 页编程
向器件写入数据时先将数据写入数据寄存器中,器件写入操作是基于页进行的,同时允许在一个页编程周期内对一页内的连续部分编程。若不进行擦除,则对同一页的连续部分编程不能超过4次。
器件支持在1页范围内的随机数据输入,由随机输入命令码85H启动,如图6中虚线框内部分所示,在1页范围内可以启动任意多次随机输入操作。数据输入完毕后,写入页编程确认命令10H,将数据寄存器中的内容写入存储区。写入完成后,需要读状态寄存器(通过写入70H实现)判断操作是否成功。若未能成功写入,应将当前块声明为坏块,并进行块数据替换操作,以保证整个系统的可靠性。
此外应注意,同一块内页编程时必须从地址最低的页开始向高地址的页依次编程,页地址随机的页编程是被禁止的。
下面是页编程子函数的C语言代码。

unsigned ch ar PageWrite(unsigned int ColAdd,unsigned long
RowAdd)
{
unsigned int data i=0;
unsigned ch ar data Status=0;
unsigned c har data ColTemp,RowTemp;

ColTemp=(unsigned ch ar)(ColAdd>>8);
RowTemp=(unsigned c har)(RowAdd>>16);
ColTemp &=0x0F;
RowTemp &=0x01;

pK9F=0x8002;
* pK9F=0x80;
pK9F=0x8001;
* pK9F=(unsigned cha r)(ColAdd);
* pK9F=ColTemp;
* pK9F=(unsigned ch ar)(RowAdd);
* pK9F=(unsigned ch ar)(RowAdd>>8);
* pK9F=RowTemp;
pK9F=0x8000;
for(i=0;i<2112;i++)
* pK9F=InputData[i];
pK9F=0x8002;
* pK9F=0x10;

while(RdyorBsy);
while(!RdyorBsy);

pK9F=0x8002;
* pK9F=0x70;
pK9F=0x8000;
Status=* pK9F;
Status &=0x01;
return (Status);
}
3.3 块擦除
擦除操作以块为单位进行,由于器件分为2 048块,因此输入的地址码中只有A18~A2的11位有效,其余位将被忽略。通过输入确认命令码来启动擦除以防止误操作。块擦除流程如图7所示。同页编程操作类似,擦除完毕后也应该读状态寄存器并处理返回结果。


3.4 页复制
页复制操作用来快速有效地实现页间数据移动,这是由于省去了比较费时的与片外设备之间的读写操作。这一特性的优势在块替换操作用于页间数据复制时体现尤为明显。其实该操作是按页读与页编程操作的复合,页复制读命令35H将页中数据移至数据寄存器中,而页复制写命令85H将数据复制到目标页中。页复制流程图如图8所示。


该操作也可以将原始页中的数据修改后写入目标页,如流程图8中虚线框内部分。
需要注意的是,页复制操作只能在奇数页之间或偶数页之间进行,奇偶页之间的数据移动将被禁止。
3.5 缓存区编程
芯片中除1页大小的数据寄存器外,还有一个1页大小的缓冲寄存器。该缓冲寄存器可以在数据寄存器参与页编程的同时接收外部数据,等待数据寄存器空闲时将数据转移其中,然后继续接收数据。因此,采用缓存区编程操作在连续写入多页数据时将会大大提高效率。
缓存区编程流程如图9所示。当第一组数据写入缓冲寄存器时,写入缓存命令15H,将数据传递给数据寄存器并启动页编程,然后使缓冲寄存器空闲,准备接收下一组数据。在这个过程中芯片将处于忙状态,若内部编程操作未完成,忙状态持续的时间将被延长。


需要注意的是,该操作只能在同一块内进行,因此在多块数据写入时需要注意每块的最后一页。若系统仅仅通过芯片的Ready/Busy引脚监测编程进度,则最后一页的写入操作应该由页编程命令10H启动。另外也可以通过读状态寄存器中的I/O 5位来判断。
K9F2G08U0M 是一种新型的超大容量Flash存储器,以其非易失、功耗低、操作简单而在单片嵌入式系统中得到广泛应用。本文在管道通径仪的开发过程中,根据对外部存储器接口的深入理解,将存储器芯片的两个控制线ALE和CLE用作地址线,使得对存储器的操作更简捷高效。文中的程序已经过实际验证,限于篇幅,只给出按页读和页编程部分的代码。

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

在可持续能源蓬勃发展的当下,如何高效获取、存储并利用能源,已成为全球科技创新的核心议题。随着全球气候变化和能源需求增长的双重压力,清洁能源的高效利用正成为全球关注的焦点。而在新能源时代,能量收集与存储技术的重要性愈加凸显...

关键字: 新能源 能量 存储技术

June 24, 2025 ---- 近期市场对于NVIDIA RTX PRO 6000系列产品的讨论声量高,预期在需求支撑下,整体出货将有不俗表现。然而,TrendForce集邦咨询资深研究副总吴雅婷认为,该系列产品受...

关键字: 存储器 供应链 边缘AI

上海 2025年6月20日 /美通社/ -- 6月18日,上海世界移动通信大会(MWC 2025)在上海新国际博览中心盛大启幕。德明利以"智存无界,全栈智能&qu...

关键字: 嵌入式 AI 全栈 存储技术

在人工智能训练、实时图形渲染与科学计算领域,存储器带宽已成为制约系统性能的核心瓶颈。HBM3与GDDR7作为当前显存技术的两大巅峰之作,分别通过三维堆叠与信号调制技术的突破,为不同应用场景提供了差异化解决方案。本文从架构...

关键字: 存储器 HBM3

传统存储器技术逼近物理极限,铁电场效应晶体管(FeFET)凭借其独特的极化翻转机制与非易失性逻辑特性,成为突破冯·诺依曼架构瓶颈的关键技术。FeFET通过将铁电材料集成至晶体管栅极,实现了存储与逻辑功能的深度融合,其物理...

关键字: FeFET 存储器

数字化转型与人工智能技术驱动,数据中心存储架构正经历从传统磁盘阵列向全闪存与新型内存技术的深度变革。全闪存阵列(AFA)凭借亚毫秒级延迟与高IOPS性能重塑存储性能基准,而持久化内存(PMEM)则通过填补DRAM与SSD...

关键字: 数据中心 存储器

AI算力与数据中心规模持续扩张,存储器纠错码(ECC)技术已成为保障数据完整性的核心防线。从硬件加速架构到算法优化,ECC技术正通过多维度创新,将内存错误率降低至每万亿小时1次以下,为关键任务系统提供接近零故障的可靠性保...

关键字: 存储器 ECC

存储器供应链安全已成为国家战略的核心命题,从晶圆代工到封装测试,中国存储器产业正通过关键环节的技术突破与生态重构,走出一条从“受制于人”到“自主可控”的替代之路。这条路径不仅关乎产业安全,更承载着数字经济时代的技术主权。

关键字: 存储器 国产化替

AI算力需求爆炸式增长,存储器封装技术正经历从2.5D到3D异构集成的范式变革。这种变革不仅重构了芯片间的物理连接方式,更对散热设计与信号完整性提出了全新挑战。本文从封装架构演进、散热机制创新与信号完整性保障三个维度,解...

关键字: 存储器 散热

数据成为核心生产要素的时代,存储器安全技术已成为保障数字资产隐私与完整性的关键防线。从早期基于硬件的加密引擎到现代可信执行环境(TEE)的生态构建,存储器安全技术经历了从单一防护到体系化协同的演进。本文从硬件加密引擎、存...

关键字: 存储器 TEE
关闭