📄 i2c.c.bak
字号:
#define uchar unsigned char
#define uint unsigned int
#define ulong unsigned long
#include "at89x51.h"
#include <absacc.h>
#include <intrins.h>
#define icadd 0x88
sbit da=P2^6;
sbit cl=P2^7;
main()
{
}
///////////////////////////////////////
void sta() //启动总线传输
{
da=1;
_nop_();
cl=1;
_nop_();
_nop_();
da=0;
_nop_();
_nop_();
cl=0;
}
//////////////////////////////////////////
void stop() //结束总线传输
{
da=0;
cl=1;
_nop_();
_nop_();
da=1;
_nop_();
_nop_();
da=0;
cl=0;
}
///////////////////////////////////////////
void mack()//发送应答位
{
da=0;
_nop_();
_nop_();
cl=1;
_nop_();
_nop_();
cl=0;
_nop_();
_nop_();
da=1;
}
/*
/////////////////////////////////////////////
void nmack()//发送非应答位
{
da=1;
_nop_();
_nop_();
cl=1;
_nop_();
_nop_();
cl=0;
da=0;
}
///////////////////////////////////////////
bit cack() //发送状态检测
{
bit a=0;
da=1;
cl=1;
if(da==0)
{
_nop_();
_nop_(); cl=0;
return(0);
}
else
{
_nop_();
_nop_(); cl=0;
return(1);
}
}
*/
//////////////////////////////////////////////
void senddata(uchar dat)
{
unsigned char i;
for(i=0;i<8;i++)
{
dat<<=1;
if(dat&0x80)
da=1;
else
da=0;
cl=0;
cl=1;
}
da=1;
while(da==1);
cl=0;
}
///////////////////////////////////////////
void wrdata(uchar dat1,uchar dat2)
{
sta();
senddata(icadd);
senddata(dat1);
senddata(dat2);
stop();
}
/////////////////////////////////////////////
/*
uchar rdbyt() //从总线上读取一个字节的数据
{
uchar a=0,i;
for(i=0;i<8;i++)
{
da=1;
cl=1;
if(da==1)
{
a=(a<<1)+1;
cl=0;
}
else if(da==0)
{
a=a<<1;
cl=0;
}
}
return(a);
}
////////////////////////////////////////////////////////////////////////////////
bit wrnbyt(uchar add,uchar start,uchar num,uchar *k) //向24C02(ADD)从字节(START)开始写(NUM)个字节
{
uchar *p=k;
uchar dk;
for(dk=0;dk<num;dk++,p++)
{
sta();
wrbyt(add);
mack();
wrbyt(start);
start=start+1;
mack();
wrbyt(*p);
mack();
stop();
delay50();
}
return(1);
}
/////////////////////////////////////////////////////////////
bit rdnbyt(uchar add,uchar start,uchar num,uchar a[]) //从24C02(ADD)字节(START)开始读取(NUM)个字节放到数据缓冲区A[]中
{
uchar *p=a;
uchar dk;
sta();
wrbyt(add);
if(cack())
return(1);
wrbyt(start);
if(cack())
return(1);
sta();
wrbyt(add+1);
if(cack())
return(1);
for(dk=0;dk<num;dk++,p++)
{
*p=rdbyt();
if(dk==num-1)
nmack();
else
mack();
}
stop();
return(0);
}
*/
//////////////////////////////////////////////////////////////////
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -