📄 read_24c02.i
字号:
// CodeVisionAVR C Compiler
// (C) 1998-2004 Pavel Haiduc, HP InfoTech S.R.L.
// I/O registers definitions for the ATmega8
#pragma used+
sfrb TWBR=0;
sfrb TWSR=1;
sfrb TWAR=2;
sfrb TWDR=3;
sfrb ADCL=4;
sfrb ADCH=5;
sfrw ADCW=4; // 16 bit access
sfrb ADCSRA=6;
sfrb ADMUX=7;
sfrb ACSR=8;
sfrb UBRRL=9;
sfrb UCSRB=0xa;
sfrb UCSRA=0xb;
sfrb UDR=0xc;
sfrb SPCR=0xd;
sfrb SPSR=0xe;
sfrb SPDR=0xf;
sfrb PIND=0x10;
sfrb DDRD=0x11;
sfrb PORTD=0x12;
sfrb PINC=0x13;
sfrb DDRC=0x14;
sfrb PORTC=0x15;
sfrb PINB=0x16;
sfrb DDRB=0x17;
sfrb PORTB=0x18;
sfrb EECR=0x1c;
sfrb EEDR=0x1d;
sfrb EEARL=0x1e;
sfrb EEARH=0x1f;
sfrw EEAR=0x1e; // 16 bit access
sfrb UBRRH=0x20;
sfrb UCSRC=0X20;
sfrb WDTCR=0x21;
sfrb ASSR=0x22;
sfrb OCR2=0x23;
sfrb TCNT2=0x24;
sfrb TCCR2=0x25;
sfrb ICR1L=0x26;
sfrb ICR1H=0x27;
sfrw ICR1=0x26; // 16 bit access
sfrb OCR1BL=0x28;
sfrb OCR1BH=0x29;
sfrw OCR1B=0x28; // 16 bit access
sfrb OCR1AL=0x2a;
sfrb OCR1AH=0x2b;
sfrw OCR1A=0x2a; // 16 bit access
sfrb TCNT1L=0x2c;
sfrb TCNT1H=0x2d;
sfrw TCNT1=0x2c; // 16 bit access
sfrb TCCR1B=0x2e;
sfrb TCCR1A=0x2f;
sfrb SFIOR=0x30;
sfrb OSCCAL=0x31;
sfrb TCNT0=0x32;
sfrb TCCR0=0x33;
sfrb MCUCSR=0x34;
sfrb MCUCR=0x35;
sfrb TWCR=0x36;
sfrb SPMCR=0x37;
sfrb TIFR=0x38;
sfrb TIMSK=0x39;
sfrb GIFR=0x3a;
sfrb GICR=0x3b;
sfrb SPL=0x3d;
sfrb SPH=0x3e;
sfrb SREG=0x3f;
#pragma used-
// Interrupt vectors definitions
// CodeVisionAVR C Compiler
// (C) 1998-2000 Pavel Haiduc, HP InfoTech S.R.L.
#pragma used+
void delay_us(unsigned int n);
void delay_ms(unsigned int n);
#pragma used-
extern const unsigned char seg_table[16];
extern void display(void);
unsigned char led_buff[4];
/*************************************************************************
I2C总线写一个字节
返回0:写成功
返回非0:写失败
Wdata:写入到AT24C02
RomAddress:写数据到AT24C02的址址
*************************************************************************/
unsigned char i2c_write(unsigned char wdata,unsigned char romaddress)
{
Start(); //I2C启动
wait();
if(testack()!=start) return 1; //测试响应
write8bit(0xa0); //写I2C从器件并设为写方式
wait();
if(testack()!=mt_sla_ack) return 1; //测试响应
write8bit(romaddress);//写24C02的ROM地址
wait();
if(testack()!=mt_data_ack) return 1;//测试响应
write8bit(wdata); //写数据到24C02的ROM
wait();
if(testack()!=mt_data_ack) return 1; //测试响应
stop(); //I2C停止
delay_ms(10); //延时等EEPROM写写
return 0;
}
/*************************************************************
I2C总线读一个字节
如果读失败也返回1
**************************************************************/
unsigned char i2c_read(unsigned char romaddress)
{
unsigned char temp;
start(); // 启动I2C
wait();
if(testack()!=start) return 1; //测试响应
write8bit(0xa0); //写I2C从器件地址并设置为写方式
wait();
if(testack()!=mt_sla_ack) return 1;
write8bit(romaddress); //写24C02的ROM地址
wait();
if(testack()!=mt_data_ack) return 1; //测试响应
start(); //重新启动
wait();
if(testack()!=re_start) return 1; //测试响应
write8bit(0xa1);//写I2C从器件地址并设置为读方式
wait();
if(testack()!=mr_sla_ack) return 1 //测试响应
temp=TWDR; //读取I2C接收数据
stop();
return temp;
}
unsigned char i2c_add,i2c_dat; //定义变量存放AT24C02的ROM地址和数据
unsigned char mode; //修改模标志
// 刷新LED缓冲区函数
void fill_buff(void)
{
led_buff[1]=seg_table[i2c_dat/16];//刷新数据
led_buff[0]=seg_table[i2c_dat%16];//刷新数据
led_buff[3]=seg_table[i2c_add/16];//刷新地址
led_buff[2]=seg_table[i2c_add/16];//刷新地址
if(mode==0)
{
led_buff[0]&=0x7f;
}
else
{
led_buff[2]&=0x7f;
}
}
void display(void)
{
}
// main函数
void main(void)
{
unsigned char i;
unsigned char add_old,dat_old,mode_old;
TWBR=32; //对TWI总线进行设置,产生合格的SCK频率
TWSR=00; //清除TWJ状态
mode=0xff; //mode=0修改数据,!=0修改地址
for(i=0;i<4;i++) //复位后4位LED全部显示8
{
led_buff[i]=seg_table[8];
}
display();
for(i=0;i<200;i++) ; //显示8888保持一定的时间
i2c_add=0; //初始化AT24C02地址为0
i2c_dat=i2c_read(i2c_add); //读AT24C02数据
fill_buff(); //刷新LED缓冲区
add_old=i2c_add; //保存当前状态
dat_old=i2c_dat; //
mode_old=mode;
while(1)
{
if(add_old!=i2c_add) //如果地址有改变刷新数据
add_old=i2c_add;
i2c_dat=i2c_read(i2c_add);//读AT24C02
dat_old=i2c_dat;
fill_buff(); //刷新LED缓冲区
display(); //显示对应数据
}
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -