eeprom 调用数据 数码管不显示
时间:10-02
整理:3721RD
点击:
#include<reg52.h>
#include<intrins.h>
#define uint unsigned int
#define uchar unsigned char
#define RdCommand 0x01
#define PrgCommand 0x02
#define EraseCommand 0x03
#define WaitTime 0x01
sfr ISP_DATA=0xe2;
sfr ISP_ADDRH=0xe3;
sfr ISP_ADDRL=0xe4;
sfr ISP_CMD=0xe5;
sfr ISP_TRIG=0xe6;
sfr ISP_CONTR=0xe7;
uchar code table[]={~0x3f,~0x06,~0x5b,~0x4f,~0x66,~0x6d,~0x7d,~0x07,~0x7f,~0x6f,~0x77,~0x7c,~0x39,~0x5e,~0x79,~0x71}; //数码管低电平有效。
sbit led1=P3^1;
uchar num,num2,ge,DATA;
void delayms(uint xms)
{
uint i,j;
for(i=xms;i>0;i--)
for(j=110;j>0;j--);
}
void display(uchar ge)
{
P0=table[ge];
delayms(5);
}
/*打开ISP,IAP*/
void ISP_IAP_enable()
{
EA=0;
ISP_CONTR=ISP_CONTR&0x18;
ISP_CONTR=ISP_CONTR|WaitTime;
ISP_CONTR=ISP_CONTR|0x80;
}
/*关闭ISP,IAP*/
void ISP_IAP_disable()
{
ISP_CONTR=ISP_CONTR&0x7f;
ISP_TRIG=0x00;
EA=1;
}
/*触发代码*/
void ISPgoon()
{
ISP_IAP_enable();
ISP_TRIG=0x46;
ISP_TRIG=0xb9;
_nop_();
}
/*读字节*/
uchar byte_read(uint byte_addr)
{
ISP_ADDRH=(uchar) (byte_addr>>8);
ISP_ADDRL=(uchar) byte_addr&0x00ff;
ISP_CMD=ISP_CMD&0xf8;
ISP_CMD=ISP_CMD|RdCommand;
ISPgoon();
ISP_IAP_disable();
return(ISP_DATA);
}
/*擦出*/
void SoctorErase(uint sector_addr)
{
uint iSectorAddr;
iSectorAddr=(sector_addr&0xff00);
ISP_ADDRH=(uchar) (iSectorAddr>>8);
ISP_ADDRL=0x00;
ISP_CMD=ISP_CMD&0xf8;
ISP_CMD=ISP_CMD|EraseCommand;
ISPgoon();
ISP_IAP_disable();
}
/*写字节*/
void byte_write(uint byte_addr,uchar original_data)
{
ISP_ADDRH=(uchar) (byte_addr>>8);
ISP_ADDRL=(uchar)(byte_addr&0x00ff);
ISP_CMD=ISP_CMD&0xf8;
ISP_CMD=ISP_CMD|PrgCommand;
ISP_DATA=original_data;
ISPgoon();
ISP_IAP_disable();
}
main()
{
uchar a;
TMOD=0x01; //定时器0为工作方式
TH0=(65536-50000)/256;
TL0=(65536-50000)%256;
EA=1;
ET0=1;
TR0=1;
DATA =byte_read(0x200);
while(1)
{
if(num2==20)
{
num2=0;
DATA++;
SoctorErase(0x200);
byte_write(0x200,DATA);
a=DATA%10;
}
display(a); //显示数码管函数
}
}
void time0()interrupt 1
{
TH0=(65536-50000)/256;
TL0=(65536-50000)%256;
num2++;
}
#include<intrins.h>
#define uint unsigned int
#define uchar unsigned char
#define RdCommand 0x01
#define PrgCommand 0x02
#define EraseCommand 0x03
#define WaitTime 0x01
sfr ISP_DATA=0xe2;
sfr ISP_ADDRH=0xe3;
sfr ISP_ADDRL=0xe4;
sfr ISP_CMD=0xe5;
sfr ISP_TRIG=0xe6;
sfr ISP_CONTR=0xe7;
uchar code table[]={~0x3f,~0x06,~0x5b,~0x4f,~0x66,~0x6d,~0x7d,~0x07,~0x7f,~0x6f,~0x77,~0x7c,~0x39,~0x5e,~0x79,~0x71}; //数码管低电平有效。
sbit led1=P3^1;
uchar num,num2,ge,DATA;
void delayms(uint xms)
{
uint i,j;
for(i=xms;i>0;i--)
for(j=110;j>0;j--);
}
void display(uchar ge)
{
P0=table[ge];
delayms(5);
}
/*打开ISP,IAP*/
void ISP_IAP_enable()
{
EA=0;
ISP_CONTR=ISP_CONTR&0x18;
ISP_CONTR=ISP_CONTR|WaitTime;
ISP_CONTR=ISP_CONTR|0x80;
}
/*关闭ISP,IAP*/
void ISP_IAP_disable()
{
ISP_CONTR=ISP_CONTR&0x7f;
ISP_TRIG=0x00;
EA=1;
}
/*触发代码*/
void ISPgoon()
{
ISP_IAP_enable();
ISP_TRIG=0x46;
ISP_TRIG=0xb9;
_nop_();
}
/*读字节*/
uchar byte_read(uint byte_addr)
{
ISP_ADDRH=(uchar) (byte_addr>>8);
ISP_ADDRL=(uchar) byte_addr&0x00ff;
ISP_CMD=ISP_CMD&0xf8;
ISP_CMD=ISP_CMD|RdCommand;
ISPgoon();
ISP_IAP_disable();
return(ISP_DATA);
}
/*擦出*/
void SoctorErase(uint sector_addr)
{
uint iSectorAddr;
iSectorAddr=(sector_addr&0xff00);
ISP_ADDRH=(uchar) (iSectorAddr>>8);
ISP_ADDRL=0x00;
ISP_CMD=ISP_CMD&0xf8;
ISP_CMD=ISP_CMD|EraseCommand;
ISPgoon();
ISP_IAP_disable();
}
/*写字节*/
void byte_write(uint byte_addr,uchar original_data)
{
ISP_ADDRH=(uchar) (byte_addr>>8);
ISP_ADDRL=(uchar)(byte_addr&0x00ff);
ISP_CMD=ISP_CMD&0xf8;
ISP_CMD=ISP_CMD|PrgCommand;
ISP_DATA=original_data;
ISPgoon();
ISP_IAP_disable();
}
main()
{
uchar a;
TMOD=0x01; //定时器0为工作方式
TH0=(65536-50000)/256;
TL0=(65536-50000)%256;
EA=1;
ET0=1;
TR0=1;
DATA =byte_read(0x200);
while(1)
{
if(num2==20)
{
num2=0;
DATA++;
SoctorErase(0x200);
byte_write(0x200,DATA);
a=DATA%10;
}
display(a); //显示数码管函数
}
}
void time0()interrupt 1
{
TH0=(65536-50000)/256;
TL0=(65536-50000)%256;
num2++;
}
不外乎2种情况:
1,数码管的驱动显示函数有问题
2,硬件有问题
碰到这样的问题,如果你自己实在难找出问题,你就应该屏蔽掉其他代码,只留下数码管驱动函数,然后只驱动点亮某一段,能点亮后就再回头添加其他代码。
谢谢啊 我解决了 用你的方法 太感谢了
就是硬件的问题 太感谢了 三克油