您的位置 首页 嵌入式

STC单片机 EEPROM/IAP 功用测验程序演示

*—STCInternationalLimited—————-一个完整的EEPROM测试程序,用宏晶的下载板可以直接测试STC12C5AxxAD系列单片

/*

— STC International Limited —————-
一个完好的EEPROM 测验程序,用宏晶的下载板能够直接测验

STC12C5AxxAD 系列单片机 EEPROM/IAP 功用测验程序演示
STC12C52xxAD 系列单片机 EEPROM/IAP 功用测验程序演示
STC11xx 系列单片机 EEPROM/IAP 功用测验程序演示
STC10xx 系列单片机EEPROM/IAP 功用测验程序演示
— STC International Limited ——————
— 宏晶科技 规划 2009/1/12 V1.0 ————–
— Mobile: 13922805190 ————————
— Fax: 0755-82944243 ————————-
— Tel: 0755-82948412 ————————-
— Web:www.MCU-Memory.com——————–
本演示程序在STC-ISP Ver 3.0A.PCB 的下载编程东西上测验通过,EEPROM 的数据
在P1 口上显现, 假如要在程序中运用或在文章中引证该程序,请在程序中或文章中
注明运用了宏晶科技的资料及程序
*/

#include
#include

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 测验开端地址

unionunion_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–);
}

声明:本文内容来自网络转载或用户投稿,文章版权归原作者和原出处所有。文中观点,不代表本站立场。若有侵权请联系本站删除(kf@86ic.com)https://www.86ic.net/qianrushi/255024.html

为您推荐

联系我们

联系我们

在线咨询: QQ交谈

邮箱: kf@86ic.com

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

返回顶部