单片机STC12CXX系列EEPROM的问题
高手们好,我想请问一下用过STC12CXX单片机EEPROM的使用,本人在资料上看了一下STC的EEPROM的使用,如果我用内部的EEPROM来代替24c02,要怎样先把...
高手们好,我想请问一下用过STC12CXX单片机EEPROM的使用,本人在资料上看了一下STC的EEPROM的使用,如果我用内部的EEPROM来代替24c02,要怎样先把要写到24c02的数据写到STC里的EEPROM里。
我要写的程序是单片机上电后从24c02里面读出数据到单片机里去运行,不知道怎样用STC系列的单片机里面的EEPROM来实现而不用24c02。谢谢
非常感谢大家的回答,我对c语言不是很透彻,我会慢慢研究。谢谢 展开
我要写的程序是单片机上电后从24c02里面读出数据到单片机里去运行,不知道怎样用STC系列的单片机里面的EEPROM来实现而不用24c02。谢谢
非常感谢大家的回答,我对c语言不是很透彻,我会慢慢研究。谢谢 展开
5个回答
展开全部
下面的代码是官方给出的测试代码,你不妨按这个来试下;
如果你把数据写在了内部的EEPROM的话,在你下次下载的时候数据是会没的,也就是说会被擦除,复位不会影响里面的数据,可以上电读出数据。
希望你成功!
/*
--- STC International Limited ----------------
STC12C5AxxAD 系列单片机 EEPROM/IAP 功能测试程序演示
STC12C52xxAD 系列单片机 EEPROM/IAP 功能测试程序演示
STC11xx 系列单片机 EEPROM/IAP 功能测试程序演示
STC10xx 系列单片机 EEPROM/IAP 功能测试程序演示
本演示程序在STC-ISP Ver 3.0A.PCB 的下载编程工具上测试通过,EEPROM 的数据在P1 口上显示*/
#include <reg51.H>
#include <intrins.H>
typedef unsigned char INT8U;
typedef unsigned int INT16U;
sfr IAP_DATA = 0xC2;
sfr IAP_ADDRH = 0xC3;
sfr IAP_ADDRL = 0xC4;
sfr IAP_CMD = 0xC5;
sfr IAP_TRIG = 0xC6;
sfr IAP_CONTR = 0xC7;
//定义Flash 操作等待时间及允许IAP/ISP/EEPROM 操作的常数
//#define ENABLE_ISP 0x80 //系统工作时钟<30MHz 时,对IAP_CONTR 寄存器设置此值
//#define ENABLE_ISP 0x81 //系统工作时钟<24MHz 时,对IAP_CONTR 寄存器设置此值
#define ENABLE_ISP 0x82 //系统工作时钟<20MHz 时,对IAP_CONTR 寄存器设置此值
//#define ENABLE_ISP 0x83 //系统工作时钟<12MHz 时,对IAP_CONTR 寄存器设置此值
//#define ENABLE_ISP 0x84 //系统工作时钟<6MHz 时,对IAP_CONTR 寄存器设置此值
//#define ENABLE_ISP 0x85 //系统工作时钟<3MHz 时,对IAP_CONTR 寄存器设置此值
//#define ENABLE_ISP 0x86 //系统工作时钟<2MHz 时,对IAP_CONTR 寄存器设置此值
//#define ENABLE_ISP 0x87 //系统工作时钟<1MHz 时,对IAP_CONTR 寄存器设置此值
#define DEBUG_DATA 0x5A //本测试程序最终存储在 EEPROM 单元的数值
#define DATA_FLASH_START_ADDRESS 0x00 //STC5Axx 系列 EEPROM 测试起始地址
union union_temp16
{
INT16U un_temp16;
INT8U un_temp8[2];
}my_unTemp16;
INT8U Byte_Read(INT16U add); //读一字节,调用前需打开IAP 功能
void Byte_Program(INT16U add, INT8U ch); //字节编程,调用前需打开IAP 功能
void Sector_Erase(INT16U add); //擦除扇区
void IAP_Disable(); //关闭IAP 功能
void Delay();
void main (void)
{
INT16U eeprom_address;
INT8U read_eeprom;
P1 = 0xF0; //演示程序开始,让 P1[3:0] 控制的灯亮
Delay(); //延时
P1 = 0x0F; //演示程序开始,让 P1[7:4] 控制的灯亮
Delay() ; //延时
//将EEPROM 测试起始地址单元的内容读出
eeprom_address = DATA_FLASH_START_ADDRESS; //将测试起始地址送eeprom_address
read_eeprom = Byte_Read(eeprom_address); //读EEPROM的值,存到read_eeprom
if (DEBUG_DATA == read_eeprom)
{ //数据是对的,亮 P1.7 控制的灯,然后在 P1 口上将 EEPROM 的数据显示出来
P1 = ~0x80;
Delay() ; //延时
P1 = ~read_eeprom;
}
else
{ //数据是错的,亮 P1.3 控制的灯,然后在 P1 口上将 EEPROM 的数据显示出来
//再将该EEPROM所在的扇区整个擦除,将正确的数据写入后,亮 P1.5 控制的灯
P1 = ~0x08;
Delay() ; //延时
P1 = ~read_eeprom;
Delay() ; //延时
Sector_Erase(eeprom_address); //擦除整个扇区
Byte_Program(eeprom_address, DEBUG_DATA);//将 DEBUG_DATA 写入 EEPROM
P1 = ~0x20; //熄灭 P1.3 控制的灯,亮 P1.5 控制的灯
}
while (1); //CPU 在此无限循环执行此句
}
//读一字节,调用前需打开IAP 功能,入口:DPTR = 字节地址,返回:A = 读出字节
INT8U Byte_Read(INT16U add)
{
IAP_DATA = 0x00;
IAP_CONTR = ENABLE_ISP; //打开IAP 功能, 设置Flash 操作等待时间
IAP_CMD = 0x01; //IAP/ISP/EEPROM 字节读命令
my_unTemp16.un_temp16 = add;
IAP_ADDRH = my_unTemp16.un_temp8[0]; //设置目标单元地址的高8 位地址
IAP_ADDRL = my_unTemp16.un_temp8[1]; //设置目标单元地址的低8 位地址
//EA = 0;
IAP_TRIG = 0x5A; //先送 5Ah,再送A5h 到ISP/IAP 触发寄存器,每次都需如此
IAP_TRIG = 0xA5; //送完A5h 后,ISP/IAP 命令立即被触发起动
_nop_();
//EA = 1;
IAP_Disable(); //关闭IAP 功能, 清相关的特殊功能寄存器,使CPU 处于安全状态,
//一次连续的IAP 操作完成之后建议关闭IAP 功能,不需要每次都关
return (IAP_DATA);
}
//字节编程,调用前需打开IAP 功能,入口:DPTR = 字节地址, A= 须编程字节的数据
void Byte_Program(INT16U add, INT8U ch)
{
IAP_CONTR = ENABLE_ISP; //打开 IAP 功能, 设置Flash 操作等待时间
IAP_CMD = 0x02; //IAP/ISP/EEPROM 字节编程命令
my_unTemp16.un_temp16 = add;
IAP_ADDRH = my_unTemp16.un_temp8[0]; //设置目标单元地址的高8 位地址
IAP_ADDRL = my_unTemp16.un_temp8[1]; //设置目标单元地址的低8 位地址
IAP_DATA = ch; //要编程的数据先送进IAP_DATA 寄存器
//EA = 0;
IAP_TRIG = 0x5A; //先送 5Ah,再送A5h 到ISP/IAP 触发寄存器,每次都需如此
IAP_TRIG = 0xA5; //送完A5h 后,ISP/IAP 命令立即被触发起动
_nop_();
//EA = 1;
IAP_Disable(); //关闭IAP 功能, 清相关的特殊功能寄存器,使CPU 处于安全状态,
//一次连续的IAP 操作完成之后建议关闭IAP 功能,不需要每次都关
}
//擦除扇区, 入口:DPTR = 扇区地址
void Sector_Erase(INT16U add)
{
IAP_CONTR = ENABLE_ISP; //打开IAP 功能, 设置Flash 操作等待时间
IAP_CMD = 0x03; //IAP/ISP/EEPROM 扇区擦除命令
my_unTemp16.un_temp16 = add;
IAP_ADDRH = my_unTemp16.un_temp8[0]; //设置目标单元地址的高8 位地址
IAP_ADDRL = my_unTemp16.un_temp8[1]; //设置目标单元地址的低8 位地址
//EA = 0;
IAP_TRIG = 0x5A; //先送 5Ah,再送A5h 到ISP/IAP 触发寄存器,每次都需如此
IAP_TRIG = 0xA5; //送完A5h 后,ISP/IAP 命令立即被触发起动
_nop_();
//EA = 1;
IAP_Disable(); //关闭IAP 功能, 清相关的特殊功能寄存器,使CPU 处于安全状态,
//一次连续的IAP 操作完成之后建议关闭IAP 功能,不需要每次都关
}
void IAP_Disable()
{
//关闭IAP 功能, 清相关的特殊功能寄存器,使CPU 处于安全状态,
//一次连续的IAP 操作完成之后建议关闭IAP 功能,不需要每次都关
IAP_CONTR = 0; //关闭IAP 功能
IAP_CMD = 0; //清命令寄存器,使命令寄存器无命令,此句可不用
IAP_TRIG = 0; //清命令触发寄存器,使命令触发寄存器无触发,此句可不用
IAP_ADDRH = 0;
IAP_ADDRL = 0;
}
void Delay()
{
INT8U i;
INT16U d=5000;
while (d--)
{
i=255;
while (i--);
}
}
如果你把数据写在了内部的EEPROM的话,在你下次下载的时候数据是会没的,也就是说会被擦除,复位不会影响里面的数据,可以上电读出数据。
希望你成功!
/*
--- STC International Limited ----------------
STC12C5AxxAD 系列单片机 EEPROM/IAP 功能测试程序演示
STC12C52xxAD 系列单片机 EEPROM/IAP 功能测试程序演示
STC11xx 系列单片机 EEPROM/IAP 功能测试程序演示
STC10xx 系列单片机 EEPROM/IAP 功能测试程序演示
本演示程序在STC-ISP Ver 3.0A.PCB 的下载编程工具上测试通过,EEPROM 的数据在P1 口上显示*/
#include <reg51.H>
#include <intrins.H>
typedef unsigned char INT8U;
typedef unsigned int INT16U;
sfr IAP_DATA = 0xC2;
sfr IAP_ADDRH = 0xC3;
sfr IAP_ADDRL = 0xC4;
sfr IAP_CMD = 0xC5;
sfr IAP_TRIG = 0xC6;
sfr IAP_CONTR = 0xC7;
//定义Flash 操作等待时间及允许IAP/ISP/EEPROM 操作的常数
//#define ENABLE_ISP 0x80 //系统工作时钟<30MHz 时,对IAP_CONTR 寄存器设置此值
//#define ENABLE_ISP 0x81 //系统工作时钟<24MHz 时,对IAP_CONTR 寄存器设置此值
#define ENABLE_ISP 0x82 //系统工作时钟<20MHz 时,对IAP_CONTR 寄存器设置此值
//#define ENABLE_ISP 0x83 //系统工作时钟<12MHz 时,对IAP_CONTR 寄存器设置此值
//#define ENABLE_ISP 0x84 //系统工作时钟<6MHz 时,对IAP_CONTR 寄存器设置此值
//#define ENABLE_ISP 0x85 //系统工作时钟<3MHz 时,对IAP_CONTR 寄存器设置此值
//#define ENABLE_ISP 0x86 //系统工作时钟<2MHz 时,对IAP_CONTR 寄存器设置此值
//#define ENABLE_ISP 0x87 //系统工作时钟<1MHz 时,对IAP_CONTR 寄存器设置此值
#define DEBUG_DATA 0x5A //本测试程序最终存储在 EEPROM 单元的数值
#define DATA_FLASH_START_ADDRESS 0x00 //STC5Axx 系列 EEPROM 测试起始地址
union union_temp16
{
INT16U un_temp16;
INT8U un_temp8[2];
}my_unTemp16;
INT8U Byte_Read(INT16U add); //读一字节,调用前需打开IAP 功能
void Byte_Program(INT16U add, INT8U ch); //字节编程,调用前需打开IAP 功能
void Sector_Erase(INT16U add); //擦除扇区
void IAP_Disable(); //关闭IAP 功能
void Delay();
void main (void)
{
INT16U eeprom_address;
INT8U read_eeprom;
P1 = 0xF0; //演示程序开始,让 P1[3:0] 控制的灯亮
Delay(); //延时
P1 = 0x0F; //演示程序开始,让 P1[7:4] 控制的灯亮
Delay() ; //延时
//将EEPROM 测试起始地址单元的内容读出
eeprom_address = DATA_FLASH_START_ADDRESS; //将测试起始地址送eeprom_address
read_eeprom = Byte_Read(eeprom_address); //读EEPROM的值,存到read_eeprom
if (DEBUG_DATA == read_eeprom)
{ //数据是对的,亮 P1.7 控制的灯,然后在 P1 口上将 EEPROM 的数据显示出来
P1 = ~0x80;
Delay() ; //延时
P1 = ~read_eeprom;
}
else
{ //数据是错的,亮 P1.3 控制的灯,然后在 P1 口上将 EEPROM 的数据显示出来
//再将该EEPROM所在的扇区整个擦除,将正确的数据写入后,亮 P1.5 控制的灯
P1 = ~0x08;
Delay() ; //延时
P1 = ~read_eeprom;
Delay() ; //延时
Sector_Erase(eeprom_address); //擦除整个扇区
Byte_Program(eeprom_address, DEBUG_DATA);//将 DEBUG_DATA 写入 EEPROM
P1 = ~0x20; //熄灭 P1.3 控制的灯,亮 P1.5 控制的灯
}
while (1); //CPU 在此无限循环执行此句
}
//读一字节,调用前需打开IAP 功能,入口:DPTR = 字节地址,返回:A = 读出字节
INT8U Byte_Read(INT16U add)
{
IAP_DATA = 0x00;
IAP_CONTR = ENABLE_ISP; //打开IAP 功能, 设置Flash 操作等待时间
IAP_CMD = 0x01; //IAP/ISP/EEPROM 字节读命令
my_unTemp16.un_temp16 = add;
IAP_ADDRH = my_unTemp16.un_temp8[0]; //设置目标单元地址的高8 位地址
IAP_ADDRL = my_unTemp16.un_temp8[1]; //设置目标单元地址的低8 位地址
//EA = 0;
IAP_TRIG = 0x5A; //先送 5Ah,再送A5h 到ISP/IAP 触发寄存器,每次都需如此
IAP_TRIG = 0xA5; //送完A5h 后,ISP/IAP 命令立即被触发起动
_nop_();
//EA = 1;
IAP_Disable(); //关闭IAP 功能, 清相关的特殊功能寄存器,使CPU 处于安全状态,
//一次连续的IAP 操作完成之后建议关闭IAP 功能,不需要每次都关
return (IAP_DATA);
}
//字节编程,调用前需打开IAP 功能,入口:DPTR = 字节地址, A= 须编程字节的数据
void Byte_Program(INT16U add, INT8U ch)
{
IAP_CONTR = ENABLE_ISP; //打开 IAP 功能, 设置Flash 操作等待时间
IAP_CMD = 0x02; //IAP/ISP/EEPROM 字节编程命令
my_unTemp16.un_temp16 = add;
IAP_ADDRH = my_unTemp16.un_temp8[0]; //设置目标单元地址的高8 位地址
IAP_ADDRL = my_unTemp16.un_temp8[1]; //设置目标单元地址的低8 位地址
IAP_DATA = ch; //要编程的数据先送进IAP_DATA 寄存器
//EA = 0;
IAP_TRIG = 0x5A; //先送 5Ah,再送A5h 到ISP/IAP 触发寄存器,每次都需如此
IAP_TRIG = 0xA5; //送完A5h 后,ISP/IAP 命令立即被触发起动
_nop_();
//EA = 1;
IAP_Disable(); //关闭IAP 功能, 清相关的特殊功能寄存器,使CPU 处于安全状态,
//一次连续的IAP 操作完成之后建议关闭IAP 功能,不需要每次都关
}
//擦除扇区, 入口:DPTR = 扇区地址
void Sector_Erase(INT16U add)
{
IAP_CONTR = ENABLE_ISP; //打开IAP 功能, 设置Flash 操作等待时间
IAP_CMD = 0x03; //IAP/ISP/EEPROM 扇区擦除命令
my_unTemp16.un_temp16 = add;
IAP_ADDRH = my_unTemp16.un_temp8[0]; //设置目标单元地址的高8 位地址
IAP_ADDRL = my_unTemp16.un_temp8[1]; //设置目标单元地址的低8 位地址
//EA = 0;
IAP_TRIG = 0x5A; //先送 5Ah,再送A5h 到ISP/IAP 触发寄存器,每次都需如此
IAP_TRIG = 0xA5; //送完A5h 后,ISP/IAP 命令立即被触发起动
_nop_();
//EA = 1;
IAP_Disable(); //关闭IAP 功能, 清相关的特殊功能寄存器,使CPU 处于安全状态,
//一次连续的IAP 操作完成之后建议关闭IAP 功能,不需要每次都关
}
void IAP_Disable()
{
//关闭IAP 功能, 清相关的特殊功能寄存器,使CPU 处于安全状态,
//一次连续的IAP 操作完成之后建议关闭IAP 功能,不需要每次都关
IAP_CONTR = 0; //关闭IAP 功能
IAP_CMD = 0; //清命令寄存器,使命令寄存器无命令,此句可不用
IAP_TRIG = 0; //清命令触发寄存器,使命令触发寄存器无触发,此句可不用
IAP_ADDRH = 0;
IAP_ADDRL = 0;
}
void Delay()
{
INT8U i;
INT16U d=5000;
while (d--)
{
i=255;
while (i--);
}
}
展开全部
//EEPROM第一个扇区初始地址
#define EEPROM_STAR_ADDRH 0x2a
#define EEPROM_STAR_ADDRL 0x00
void sector_erase()//扇区擦除
{
ISP_ADDRH=EEPROM_STAR_ADDRH;
ISP_ADDRL=EEPROM_STAR_ADDRL;
ISP_CONTR=0x84;
ISP_CMD=3;
ISP_TRIG=0x46;
ISP_TRIG=0xb9;
ISP_CONTR=0;
ISP_CMD=0;
ISP_TRIG=0;
ISP_ADDRH=0;
ISP_ADDRL=0;
}
void write_byte(uchar d,uchar addrl)//写1字节
{
ISP_DATA=d;
ISP_ADDRH=EEPROM_STAR_ADDRH;
ISP_ADDRL=addrl;
ISP_CONTR=0x84;
ISP_CMD=2;
ISP_TRIG=0x46;
ISP_TRIG=0xb9;
ISP_CONTR=0;
ISP_CMD=0;
ISP_TRIG=0;
ISP_ADDRH=0;
ISP_ADDRL=0;
}
uchar read_byte(uchar addrl)//读1字节
{
ISP_ADDRH=EEPROM_STAR_ADDRH;
ISP_ADDRL=addrl;
ISP_CONTR=0x84;
ISP_CMD=1;
ISP_TRIG=0x46;
ISP_TRIG=0xb9;
ISP_CONTR=0;
ISP_CMD=0;
ISP_TRIG=0;
ISP_ADDRH=0;
ISP_ADDRL=0;
return ISP_DATA;
}
这个三个函数已经在项目(单片机为STC12C5410AD)应用中的,是完全没有问题的。
你需要先看看单片机的DATASHEET,然后利用这三个函数写入一个数据,再读出数据,测试和理解后,再加以改变应用到你的项目中去。
注意擦除函数是只能扇区擦除,不能字节擦除,STC12C5410AD共4个扇区,每个扇区512字节。每次重写数据之前都需要擦除,因此每组数据最好在同一扇区,需要修改这组数据的时候先执行扇区擦除命令,再执行写命令。
#define EEPROM_STAR_ADDRH 0x2a
#define EEPROM_STAR_ADDRL 0x00
void sector_erase()//扇区擦除
{
ISP_ADDRH=EEPROM_STAR_ADDRH;
ISP_ADDRL=EEPROM_STAR_ADDRL;
ISP_CONTR=0x84;
ISP_CMD=3;
ISP_TRIG=0x46;
ISP_TRIG=0xb9;
ISP_CONTR=0;
ISP_CMD=0;
ISP_TRIG=0;
ISP_ADDRH=0;
ISP_ADDRL=0;
}
void write_byte(uchar d,uchar addrl)//写1字节
{
ISP_DATA=d;
ISP_ADDRH=EEPROM_STAR_ADDRH;
ISP_ADDRL=addrl;
ISP_CONTR=0x84;
ISP_CMD=2;
ISP_TRIG=0x46;
ISP_TRIG=0xb9;
ISP_CONTR=0;
ISP_CMD=0;
ISP_TRIG=0;
ISP_ADDRH=0;
ISP_ADDRL=0;
}
uchar read_byte(uchar addrl)//读1字节
{
ISP_ADDRH=EEPROM_STAR_ADDRH;
ISP_ADDRL=addrl;
ISP_CONTR=0x84;
ISP_CMD=1;
ISP_TRIG=0x46;
ISP_TRIG=0xb9;
ISP_CONTR=0;
ISP_CMD=0;
ISP_TRIG=0;
ISP_ADDRH=0;
ISP_ADDRL=0;
return ISP_DATA;
}
这个三个函数已经在项目(单片机为STC12C5410AD)应用中的,是完全没有问题的。
你需要先看看单片机的DATASHEET,然后利用这三个函数写入一个数据,再读出数据,测试和理解后,再加以改变应用到你的项目中去。
注意擦除函数是只能扇区擦除,不能字节擦除,STC12C5410AD共4个扇区,每个扇区512字节。每次重写数据之前都需要擦除,因此每组数据最好在同一扇区,需要修改这组数据的时候先执行扇区擦除命令,再执行写命令。
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
EEPROM没有用,我当时是用的flash,不过思路应该是一样的,无非就是擦出、写、读、跟24c02/08/16区别很大的。你要是存储量准许的话就用FLASH也是可以的啊,我把我的flash子程序附上去你参考一下吧。(已经过实际项目测试没问题的,不过是老早之前的程序了,呵呵)
/*************************************************
EEPROM写程序
*************************************************/
void eeprom_write(void)
{
unsigned char j;
ISP_ADDRH=0x22;//选择存放数据的高八位地址寄存器
ISP_ADDRL=0x22;//选择存放数据的低八位地址寄存器
ISP_CMD=0x02;//命令模式触发对flash写 ,0x01读,0x02写,0x03擦除
ISP_DATA=TSET1;//存放数据
ISP_CONTR=0x9a;//使能ISP、IAP,,ISPEN=1允许改变FLASH,SWBS=0程序从主程序启动,等待时间为010
ISP_TRIG=0X46;//对ISP_TRIG先写0x46
ISP_TRIG=0XB9;//对ISP_TRIG先写0xB9,使ISP/IAP命令生效
for(j=0;j<2;j++);
}
/********************************************
EEPROM读程序
********************************************/
unsigned char eeprom_read(void)
{
unsigned char j;
ISP_ADDRH=0x22;
ISP_ADDRL=0x22;
ISP_CMD=0x01;
ISP_CONTR=0x9a;
ISP_TRIG=0X46;
ISP_TRIG=0XB9;
for(j=0;j<2;j++);
return(ISP_DATA);
}
/***********************************************
EEPROM擦出程序
***********************************************/
void eeprom_erase(void)
{
unsigned char j;
ISP_ADDRH=0x22;
ISP_ADDRL=0x22;
ISP_CMD=0x03;
ISP_CONTR=0x9a;
ISP_TRIG=0X46;
ISP_TRIG=0XB9;
for(j=0;j<2;j++);
}
/*************************************************
EEPROM写程序
*************************************************/
void eeprom_write(void)
{
unsigned char j;
ISP_ADDRH=0x22;//选择存放数据的高八位地址寄存器
ISP_ADDRL=0x22;//选择存放数据的低八位地址寄存器
ISP_CMD=0x02;//命令模式触发对flash写 ,0x01读,0x02写,0x03擦除
ISP_DATA=TSET1;//存放数据
ISP_CONTR=0x9a;//使能ISP、IAP,,ISPEN=1允许改变FLASH,SWBS=0程序从主程序启动,等待时间为010
ISP_TRIG=0X46;//对ISP_TRIG先写0x46
ISP_TRIG=0XB9;//对ISP_TRIG先写0xB9,使ISP/IAP命令生效
for(j=0;j<2;j++);
}
/********************************************
EEPROM读程序
********************************************/
unsigned char eeprom_read(void)
{
unsigned char j;
ISP_ADDRH=0x22;
ISP_ADDRL=0x22;
ISP_CMD=0x01;
ISP_CONTR=0x9a;
ISP_TRIG=0X46;
ISP_TRIG=0XB9;
for(j=0;j<2;j++);
return(ISP_DATA);
}
/***********************************************
EEPROM擦出程序
***********************************************/
void eeprom_erase(void)
{
unsigned char j;
ISP_ADDRH=0x22;
ISP_ADDRL=0x22;
ISP_CMD=0x03;
ISP_CONTR=0x9a;
ISP_TRIG=0X46;
ISP_TRIG=0XB9;
for(j=0;j<2;j++);
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
仔细看数据手册。24C02和单片机内部EEPROM写数据方式是不一样的。
24C02可以一字节一字节写,写入之前不需要擦除。
而单片机内部的EEPROM,擦除必须一块一块的擦除,根据单片机的不同,块的大小有64字节128字节等等。而且写之前需要先擦除原先的数据(因为每一字节的位只能清零,而不能置高),所以写数据比24c02麻烦,你好好看看数据手册,就没什么问题了。
24C02可以一字节一字节写,写入之前不需要擦除。
而单片机内部的EEPROM,擦除必须一块一块的擦除,根据单片机的不同,块的大小有64字节128字节等等。而且写之前需要先擦除原先的数据(因为每一字节的位只能清零,而不能置高),所以写数据比24c02麻烦,你好好看看数据手册,就没什么问题了。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
我使用过STC12cxx的EEPROM。
不过只是用做固化一些数据,也可以在代码执行的过程中使用ISP对其进行操作。但我固化的数据是一些表格之类的。
对内部EEPROM,代码对其的读写都是单字节的,比较麻烦。只要初始化好控制寄存器和连续对触发寄存器的两次赋值就可以触发读写功能。具体方法在datasheet里有一个汇编的范例。内部EEPROM的擦除只能是对页操作。好像内部分页是0.5K一页吧。
个人感觉,对内部EEPROM的读写只能针对数据,但不能将代码取出到ROM来执行。不足之处还请见谅,同时也期待着大家的意见。
不过只是用做固化一些数据,也可以在代码执行的过程中使用ISP对其进行操作。但我固化的数据是一些表格之类的。
对内部EEPROM,代码对其的读写都是单字节的,比较麻烦。只要初始化好控制寄存器和连续对触发寄存器的两次赋值就可以触发读写功能。具体方法在datasheet里有一个汇编的范例。内部EEPROM的擦除只能是对页操作。好像内部分页是0.5K一页吧。
个人感觉,对内部EEPROM的读写只能针对数据,但不能将代码取出到ROM来执行。不足之处还请见谅,同时也期待着大家的意见。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询