/*將數據寫入AT24C02的0地址處,再讀出,并用數碼管顯示*/
#include"reg51.h"
sbit SDA=P2^0;
sbit SCL=P2^1;
sbit duan=P2^6;
sbit wei=P2^7;
void delay()
{;;
}
void init()
{SCL=1;
SDA=1;
delay();
}
void start()
{SDA=1;
delay();
SCL=1;
delay();
SDA=0;
delay();
}
void stop()
{SDA=0;
delay();
SCL=1;
delay();
SDA=1;
delay();
}
void ack()
{unsigned char i;
SCL=1;
while((SDA==1)&&(i<255))i++;
SCL=0;
delay();
}
void write(unsigned char date)
{unsigned char i,temp;
temp=date;
for(i=0;i<8;i++)
{SCL=0;
delay();
temp<<=1;
SDA=CY;
delay();
SCL=1;
delay();
}
SCL=0;
delay();
SDA=1;
delay();
}
unsigned char read()
{unsigned char i,j;
SCL=0;
delay();
SDA=1;
delay();
for(i=0;i<8;i++)
{SCL=1;
delay();
j=(j<<1)|SDA;
SCL=0;
delay();
}
return j;
}
write_addr(unsigned char date,unsigned char addr)
{start();
write(0xa0);
ack();
write(addr);
ack();
write(date);
ack();
stop();
}
unsigned char read_addr(unsigned char addr)
{unsigned char i;
start();
write(0xa0);
ack();
write(addr);
ack();
start();
write(0xa1);
ack();
i=read();
stop();
return i;
}
void shumaguan(unsigned char dat,unsigned char addr)
{unsigned char ziku[18]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71,0x40,0x00};
unsigned char wzk[8]={0x7f,0xbf,0xdf,0xef,0xf7,0xfb,0xfd,0xfe};
duan=0;
P0=wzk[addr];
wei=1;
wei=0;
P0=ziku[dat];
duan=1;
delay();
P0=0;
duan=0;
}
main()
{unsigned char i;
init();
write_addr(0x11,0);
i=read_addr(0);
while(1)
{shumaguan(i%10,0);
shumaguan(i/10%10,1);
shumaguan(i/100,2);
}
}
我調試成功的,只是寫的:
void IIC_START()
{
//DAT_PIN_OUT();
SDIO=1;
NOP();
SCLK=1;
NOP();
SDIO=0;
NOP();
SCLK=0;
}
//------------------------------------------------------------
void IIC_STOP()
{
//DAT_PIN_OUT();
SCLK=0;
NOP();
SDIO=0;
NOP();
SCLK=1;
NOP();
SDIO=1;
}
//---------------------------------------------------
void IIC_ACK()
{
SCLK=0;
NOP();
NOP();
NOP();
_pbc = 0b10111111; //DAT_PIN_IN();
SDIO=1;
NOP();
NOP();
SCLK=1;
NOP();
NOP();
if(SDIO){
NOP();
}
SCLK=0;
_pbc = 0b00111111; //DAT_PIN_OUT();
SDIO=0;
SCLK=0;
}
//-----------------寫一字節數據---------------------
void IICWrByte(uchar DAT)
{
uchar i;
//DAT_PIN_OUT();
//----------------------------------
NOP();
for(i=0;i<8;i++) {
NOP();
SCLK=0;
NOP();
if(DAT & 0X01){
SDIO=1;
}
else {
SDIO=0;
}
NOP();
SCLK=1;
NOP();
SCLK=0;
DAT >>= 1;
}
}
不好意思,后面那段發錯了,不是24C02的!一般用示波器看就可以找出問題來的!
IIC的器件的通信協議是一樣的。都可以通用的。有些新的器件速度高一些,和速度低得比較,可以加少一些空操作(NOP)。但低速器件的程序可以用在高速器件上。
樓主的程序不是一點兩點的問題。
在IIC協議中,不管是主控器件還是從器件,1、向總線發送一個字節數據后,就要檢查應答信號,看看接收器件是否“字節接受完成”。
2、接收器件正確接收到一個字節的數據后,也要發送一個應答信號(1bit),告訴發送器件“字節接收完成”
如果接收器件接收不正確,則不會發送應答信號。發送器件就檢測不到“應答信號”,這時就要從“開始”步驟重來。
這里就有了這么幾個環節:“應答信號(1bit,低位)”、“非應答信號(1bit,高位)、“檢測應答信號”。
讀的流程:1發送開始信號-->2發送器件地址(含“寫”指令位)-->3檢測應答-->4發送字節地址-->5檢測應答-->6發送開始信號(含“讀”指令位)
-->7檢測應答-->8讀一個字節-->(9發送應答信號-->......(重復第8步)讀第2~N字節)-->發送非應答信號-->發送停止信號
寫的流程:1發送開始信號-->2發送器件地址(含“寫”指令位)-->3檢測應答-->4發送字節地址-->5檢測應答-->6寫一個字節-->7檢測應答信號
-->(......(重復第6步)寫第2~N字節-->(重復第7步)檢測應答信號-->)發送停止信號
如果是單字節讀寫括號內不用。
| 歡迎光臨 (http://www.denmoz.com/bbs/) | Powered by Discuz! X3.1 |