📄 eeprom.lst
字号:
C51 COMPILER V8.02 EEPROM 05/28/2013 22:23:42 PAGE 1
C51 COMPILER V8.02, COMPILATION OF MODULE EEPROM
OBJECT MODULE PLACED IN eeprom.OBJ
COMPILER INVOKED BY: C:\Keil\C51\BIN\C51.EXE eeprom.c BROWSE DEBUG OBJECTEXTEND
line level source
1 #include <reg51.H>
2 #include <intrins.H>
3
4 typedef unsigned char INT8U;
5 typedef unsigned int INT16U;
6
7 sfr IAP_DATA = 0xC2;
8 sfr IAP_ADDRH = 0xC3;
9 sfr IAP_ADDRL = 0xC4;
10 sfr IAP_CMD = 0xC5;
11 sfr IAP_TRIG = 0xC6;
12 sfr IAP_CONTR = 0xC7;
13 //定义Flash 操作等待时间及允许IAP/ISP/EEPROM 操作的常数
14 //#define ENABLE_ISP 0x80 //系统工作时钟<30MHz 时,对IAP_CONTR 寄存器设置此值
15 //#define ENABLE_ISP 0x81 //系统工作时钟<24MHz 时,对IAP_CONTR 寄存器设置此值
16 #define ENABLE_ISP 0x82 //系统工作时钟<20MHz 时,对IAP_CONTR 寄存器设置此值
17 //#define ENABLE_ISP 0x83 //系统工作时钟<12MHz 时,对IAP_CONTR 寄存器设置此值
18 //#define ENABLE_ISP 0x84 //系统工作时钟<6MHz 时,对IAP_CONTR 寄存器设置此值
19 //#define ENABLE_ISP 0x85 //系统工作时钟<3MHz 时,对IAP_CONTR 寄存器设置此值
20 //#define ENABLE_ISP 0x86 //系统工作时钟<2MHz 时,对IAP_CONTR 寄存器设置此值
21 //#define ENABLE_ISP 0x87 //系统工作时钟<1MHz 时,对IAP_CONTR 寄存器设置此值操作等待时间及允
22 #define DEBUG_DATA 0x5A //本测试程序最终存储在 EEPROM 单元的数值
23 #define DATA_FLASH_START_ADDRESS 0x00 //STC5Axx 系列 EEPROM 测试起始地址
24 union union_temp16
25 {
26 INT16U un_temp16;
27 INT8U un_temp8[2];
28 }my_unTemp16;
29
30 INT8U Byte_Read(INT16U add); //读一字节,调用前需打开IAP 功能
31 void Byte_Program(INT16U add, INT8U ch); //字节编程,调用前需打开IAP 功能
32 void Sector_Erase(INT16U add); //擦除扇区
33 void IAP_Disable(); //关闭IAP 功能
34 void Delay();
35
36 void main (void)
37 {
38 1 INT16U eeprom_address;
39 1 INT8U read_eeprom;
40 1
41 1 P1 = 0xF0; //演示程序开始,让 P1[3:0] 控制的灯亮
42 1 Delay(); //延时
43 1 P1 = 0x0F; //演示程序开始,让 P1[7:4] 控制的灯亮
44 1 Delay() ; //延时
45 1
46 1 //将EEPROM 测试起始地址单元的内容读出
47 1 eeprom_address = DATA_FLASH_START_ADDRESS; //将测试起始地址送eeprom_address
48 1 read_eeprom = Byte_Read(eeprom_address); //读EEPROM的值,存到read_eeprom
49 1
50 1 if (DEBUG_DATA == read_eeprom)
51 1 { //数据是对的,亮 P1.7 控制的灯,然后在 P1 口上将 EEPROM 的数据显示出来
52 2 P1 = ~0x80;
53 2 Delay() ; //延时
54 2 P1 = ~read_eeprom;
55 2 }
C51 COMPILER V8.02 EEPROM 05/28/2013 22:23:42 PAGE 2
56 1 else
57 1 { //数据是错的,亮 P1.3 控制的灯,然后在 P1 口上将 EEPROM 的数据显示出来
58 2 //再将该EEPROM所在的扇区整个擦除,将正确的数据写入后,亮 P1.5 控制的灯
59 2 P1 = ~0x08;
60 2 Delay() ; //延时
61 2 P1 = ~read_eeprom;
62 2 Delay() ; //延时
63 2
64 2 Sector_Erase(eeprom_address); //擦除整个扇区
65 2 Byte_Program(eeprom_address, DEBUG_DATA);//将 DEBUG_DATA 写入 EEPROM
66 2
67 2 P1 = ~0x20; //熄灭 P1.3 控制的灯,亮 P1.5 控制的灯
68 2 }
69 1
70 1 while (1); //CPU 在此无限循环执行此句
71 1 }
72
73 //读一字节,调用前需打开IAP 功能,入口:DPTR = 字节地址,返回:A = 读出字节
74 INT8U Byte_Read(INT16U add)
75 {
76 1 IAP_DATA = 0x00;
77 1 IAP_CONTR = ENABLE_ISP; //打开IAP 功能, 设置Flash 操作等待时间
78 1 IAP_CMD = 0x01; //IAP/ISP/EEPROM 字节读命令
79 1
80 1 my_unTemp16.un_temp16 = add;
81 1 IAP_ADDRH = my_unTemp16.un_temp8[0]; //设置目标单元地址的高8 位地址
82 1 IAP_ADDRL = my_unTemp16.un_temp8[1]; //设置目标单元地址的低8 位地址
83 1
84 1 //EA = 0;
85 1 IAP_TRIG = 0x5A; //先送 5Ah,再送A5h 到ISP/IAP 触发寄存器,每次都需如此
86 1 IAP_TRIG = 0xA5; //送完A5h 后,ISP/IAP 命令立即被触发起动
87 1 _nop_();
88 1 //EA = 1;
89 1 IAP_Disable(); //关闭IAP 功能, 清相关的特殊功能寄存器,使CPU 处于安全状态,
90 1 //一次连续的IAP 操作完成之后建议关闭IAP 功能,不需要每次都关
91 1 return (IAP_DATA);
92 1 }
93
94 //字节编程,调用前需打开IAP 功能,入口:DPTR = 字节地址, A= 须编程字节的数据
95 void Byte_Program(INT16U add, INT8U ch)
96 {
97 1 IAP_CONTR = ENABLE_ISP; //打开 IAP 功能, 设置Flash 操作等待时间
98 1 IAP_CMD = 0x02; //IAP/ISP/EEPROM 字节编程命令
99 1
100 1 my_unTemp16.un_temp16 = add;
101 1 IAP_ADDRH = my_unTemp16.un_temp8[0]; //设置目标单元地址的高8 位地址
102 1 IAP_ADDRL = my_unTemp16.un_temp8[1]; //设置目标单元地址的低8 位地址
103 1
104 1 IAP_DATA = ch; //要编程的数据先送进IAP_DATA 寄存器
105 1 //EA = 0;
106 1 IAP_TRIG = 0x5A; //先送 5Ah,再送A5h 到ISP/IAP 触发寄存器,每次都需如此
107 1 IAP_TRIG = 0xA5; //送完A5h 后,ISP/IAP 命令立即被触发起动
108 1 _nop_();
109 1 //EA = 1;
110 1 IAP_Disable(); //关闭IAP 功能, 清相关的特殊功能寄存器,使CPU 处于安全状态,
111 1 //一次连续的IAP 操作完成之后建议关闭IAP 功能,不需要每次都关
112 1 }
113
114 //擦除扇区, 入口:DPTR = 扇区地址
115 void Sector_Erase(INT16U add)
116 {
117 1 IAP_CONTR = ENABLE_ISP; //打开IAP 功能, 设置Flash 操作等待时间
C51 COMPILER V8.02 EEPROM 05/28/2013 22:23:42 PAGE 3
118 1 IAP_CMD = 0x03; //IAP/ISP/EEPROM 扇区擦除命令
119 1
120 1 my_unTemp16.un_temp16 = add;
121 1 IAP_ADDRH = my_unTemp16.un_temp8[0]; //设置目标单元地址的高8 位地址
122 1 IAP_ADDRL = my_unTemp16.un_temp8[1]; //设置目标单元地址的低8 位地址
123 1
124 1 //EA = 0;
125 1 IAP_TRIG = 0x5A; //先送 5Ah,再送A5h 到ISP/IAP 触发寄存器,每次都需如此
126 1 IAP_TRIG = 0xA5; //送完A5h 后,ISP/IAP 命令立即被触发起动
127 1 _nop_();
128 1 //EA = 1;
129 1 IAP_Disable(); //关闭IAP 功能, 清相关的特殊功能寄存器,使CPU 处于安全状态,
130 1 //一次连续的IAP 操作完成之后建议关闭IAP 功能,不需要每次都关
131 1 }
132
133 void IAP_Disable()
134 {
135 1 //关闭IAP 功能, 清相关的特殊功能寄存器,使CPU 处于安全状态,
136 1 //一次连续的IAP 操作完成之后建议关闭IAP 功能,不需要每次都关
137 1 IAP_CONTR = 0; //关闭IAP 功能
138 1 IAP_CMD = 0; //清命令寄存器,使命令寄存器无命令,此句可不用
139 1 IAP_TRIG = 0; //清命令触发寄存器,使命令触发寄存器无触发,此句可不用
140 1 IAP_ADDRH = 0;
141 1 IAP_ADDRL = 0;
142 1 }
143
144 void Delay()
145 {
146 1 INT8U i;
147 1 INT16U d=5000;
148 1 while (d--)
149 1 {
150 2 i=255;
151 2 while (i--);
152 2 }
153 1 }
MODULE INFORMATION: STATIC OVERLAYABLE
CODE SIZE = 202 ----
CONSTANT SIZE = ---- ----
XDATA SIZE = ---- ----
PDATA SIZE = ---- ----
DATA SIZE = 2 3
IDATA SIZE = ---- ----
BIT SIZE = ---- ----
END OF MODULE INFORMATION.
C51 COMPILATION COMPLETE. 0 WARNING(S), 0 ERROR(S)
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -