当前位置:首页 > 单片机 > 单片机
[导读]STC单片机的内部EEPROM是用DATAFLASH模拟出来的,不是真正的EEPROM存储器,不能用普通的方法来操作下面是一些注意点:1.字节写之前要先将这个字节所在扇区的其它有效数据读取到RAM暂存(这步不是必须的)2.暂存完之后再对

STC单片机的内部EEPROM是用DATAFLASH模拟出来的,不是真正的EEPROM存储器,不能用普通的方法来操作
下面是一些注意点:
1.字节写之前要先将这个字节所在扇区的其它有效数据读取到RAM暂存(这步不是必须的)
2.暂存完之后再对整个扇区(512字节)进行擦除操作,擦拭完后,整个扇区每个地址中数据都变成0xFF
3.将欲写入的N个字节数据,用字节写函数写入EEPROM
4.将暂存到RAM的其它有用的EEPROM值再用字节写函数写回EEPROM
5.STC用FLASH模拟出来的EEPROM的字节写功能只能将1变成0,而不能将0变成1,
只有扇区擦除后数据才是全1,
例如:在地址0x21f0处第1次写11010110,第2次写111010,读出结果是这2个值的相与10010
所以如果一个地址处的值不是0xff时写入新的数据是不对的,要先执行扇区擦除,变为0xff,
对于单个字节的写入,我们可以先检查该地址处的数据是否为0xff,是的话就不用擦除扇区了

----------------------------------------------------------------------
STC89C52单片机内部EEPROM 的读写过程
1 配置ISP_CONTR寄存器,使能第7位ISPEN,让ISP_IAP功能生效,并配置低3位的等待时间
2 写指令: 读/写/擦除扇区 这3个命令
3 赋值: ISP_ADDRH和ISP_ADDRL的地址值
4 关闭总中断EA,因为下面要写的2个触发指令必须是连续操作的,不能被中断
5 执行公用的 ISP_IAP 触发指令,触发后读写操作才能进行
6 打开中断 EA,关闭ISP_IAP功能:清相关寄存器

C代码

#include"my51.h"

/******************定义命令字节******************/

#defineread_cmd0x01//字节读数据命令

#definewirte_cmd0x02//字节编程数据命令

#defineerase_cmd0x03//扇区擦除数据命令

/****************特殊功能寄存器声明****************/

sfrISP_DATA=0xe2;

sfrISP_ADDRH=0xe3;

sfrISP_ADDRL=0xe4;

sfrISP_CMD=0xe5;

sfrISP_TRIG=0xe6;

sfrISP_CONTR=0xe7;

/*定义Flash操作等待时间及允许IAP/ISP/EEPROM操作的常数******************/

//#defineenable_waitTime0x80//系统工作时钟<30MHz时,对IAP_CONTR寄存器设置此值

//#defineenable_waitTime0x81//系统工作时钟<24MHz时,对IAP_CONTR寄存器设置此值

//#defineenable_waitTime0x82//系统工作时钟<20MHz时,对IAP_CONTR寄存器设置此值

#defineenable_waitTime0x83//系统工作时钟<12MHz时,对IAP_CONTR寄存器设置此值

//#defineenable_waitTime0x84//系统工作时钟<6MHz时,对IAP_CONTR寄存器设置此值

voidISP_IAP_disable(void)//关闭ISP_IAP

{

EA=1;//恢复中断

ISP_CONTR=0x00;

ISP_CMD=0x00;

ISP_TRIG=0x00;

}

voidISP_IAP_trigger()//触发

{

EA=0;//下面的2条指令必须连续执行,故关中断

ISP_TRIG=0x46;//送触发命令字0x46

ISP_TRIG=0xB9;//送触发命令字0xB9

}

voidISP_IAP_readData(u16beginAddr,u8*pBuf,u16dataSize)//读取数据

{

ISP_DATA=0;//清零,不清也可以

ISP_CMD=read_cmd;//指令:读取

ISP_CONTR=enable_waitTime;//开启ISP_IAP,并送等待时间

while(dataSize--)//循环读取

{

ISP_ADDRH=(u8)(beginAddr>>8);//送地址高字节

ISP_ADDRL=(u8)(beginAddr&0x00ff);//送地址低字节

ISP_IAP_trigger();//触发

beginAddr++;//地址++

*pBuf++=ISP_DATA;//将数据保存到接收缓冲区

}

ISP_IAP_disable();//关闭ISP_IAP功能

}

voidISP_IAP_writeData(u16beginAddr,u8*pDat,u16dataSize)//写数据

{

ISP_CONTR=enable_waitTime;//开启ISP_IAP,并送等待时间

ISP_CMD=wirte_cmd;//送字节编程命令字

while(dataSize--)

{

ISP_ADDRH=(u8)(beginAddr>>8);//送地址高字节

ISP_ADDRL=(u8)(beginAddr&0x00ff);//送地址低字节

ISP_DATA = *pDat++; //送数据

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

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

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

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

关键字: 存储器 HBM3

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

关键字: FeFET 存储器

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

关键字: 数据中心 存储器

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

关键字: 存储器 ECC

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

关键字: 存储器 国产化替

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

关键字: 存储器 散热

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

关键字: 存储器 TEE

采用51单片机最小开发板,由8位自制独立按键控制。单片机芯片为STC89C52RC,晶振为@12.000 mhz。8X8LED点阵屏模块由MAX7219驱动,MAX7219包含一个自动扫描电路。你只需要把要显示的数据发送...

关键字: 51单片机 MAX7219 寄存器

May 13, 2025 ---- 根据TrendForce集邦咨询最新半导体封测研究报告,2024年全球封测(OSAT)市场面临技术升级和产业重组的双重挑战。从营收分析,日月光控股、Amkor(安靠)维持领先地位,值得...

关键字: 自制化 AI 汽车电子 存储器
关闭