就是用I2C总线发过去一个数据再读回来的程序,可是读回来的数据就是不对,不知道为什么。。。不管发什么,读回来的总是0xff。
#include<reg52.h>
#define uchar unsigned char
uchar a;
sbit sda=P2^0;
sbit scl=P2^1;
void delay()
{;;}
void delay1(int z)
{
int x,y;
for(x=0;x<z;x++)
for(y=0;y<110;y++);
}
void start()
{
sda=1;
delay();
scl=1;
delay();
sda=0;
delay();
}
void stop()
{
sda=0;
delay();
scl=1;
delay();
sda=1;
delay();
}
void respond()
{
uchar i;
scl=1;
delay();
while((sda==1)&&(i<250))
i++;
scl=0;
delay();
}
void init()
{
sda=1;
delay();
scl=1;
}
void write_byte(uchar dat)
{
uchar j;
uchar temp=dat;
for(j=0;j<8;j++)
{
temp=temp<<1;
scl=0;
delay();
sda=CY;
delay();
scl=1;
delay();
}
scl=0;
delay();
sda=1;
delay();
}
uchar read_byte()
{
uchar i,j,k;
scl=0;
delay();
sda=1;
delay();
for(i=0;i<8;i++)
{
scl=1;
delay();
if(sda==1)
j=1;
else
j=0;
k=((k<<1)|j);
scl=0;
delay();
}
return k;
}
void main()
{
init();
start();
write_byte(0xa0);
respond();
write_byte(3);
respond();
write_byte(0xfe);
respond();
stop();
delay1(100);
start();
write_byte(0xa0);
respond();
write_byte(3);
respond();
start();
write_byte(0xa1);
respond();
P1=read_byte();
stop();
}
51 c I2C
------解决方案--------------------
一般都是时序的问题
------解决方案--------------------
直接用delay出来的时钟够慢吗?
先确认下时序满不满足要求
------解决方案--------------------
读时序好像是:
Start, SlaveAddr(W), RegAddr, ReStart, SlaveAddr(R), Data, Ack, Data, Nak, Stop.
具体记不太清楚了。
读操作的Stop前要发Nak, 要不后面读出的数据会出错。
------解决方案--------------------
unsingned char ROM_read_byte()
{
unsinged char a,b,c;
SCL=0;
SomeNop();
SDA=1;
SomeNop();
for (a=0;a<8;a++)
{
SCL=1;
SomeNop();
b=SDA;
if (SDA==1)
b=1;
else
b=0;
c=(c<<1)
------解决方案--------------------
b;
SCL=0;
SomeNop();
}
SomeNop();
return c;
}
读字节函数有点问题,其实可以不用做判断,郭天祥只是写了一个判断,但得先给b赋值。
for ()
{
SCL=1;
SomeNop();
b=(b<<1)
------解决方案--------------------
SDA;
SCL=0;
SomeNop();
}
SomeNop();
return b;
我也在看郭天祥的视频,大家多交流交流。