单片机C程序:求下面这个单片机IIC总线C程序的详细解释

单片机C程序:求下面这个单片机IIC总线C程序的详细解释,第1张

IIC协议有讲的,橘租每一次传输都有

起始

应答

错误

总线忙

非圆猜兆应答

等信号格式

NoACK就是非应答,兆侍他告诉iic传输的是最后一个数据,TestAck()

是发送一个字后等待从机应答

你这个例程应该是用io口模仿正数i2c,这里你没有给出sda的定义。我理解还有程序对其进行判断if(sda==1)输出念穗编码‘1’else 输出编码‘0’。经过for循环8次就输出了一个完整的8bit二进制数。比如temp=num=0x25sda=0x25&0x80就等于‘0x00’,这时io口输出‘0’,temp=temp<<1数据左移1位temp此时等于0x4a,再&0x80,经过8次移位io口输出的数据应该是00100101=0x25,这个数据传仔清卜输结束

#include"reg52.h"

#include"24c02.h"

#include"lcm.h"

#define max_freq 108000

#define min_freq 87500

unsigned char radio_write_data[5]={0xb1,0xa0,0x20,0x11,0x00} //要写入TEA5767的数据

unsigned char radio_write_data1[5]={0x31,0xa0,0x20,0x11,0x00} //要写入TEA5767的数据

unsigned char radio_read_data[5] /察陵/TEA5767读出的状态

unsigned int default_pll=0x29c2//0x29f9 //默认存台的pll,87.8MHz

unsigned int pll=0

float frequency=0

void get_frequency(void)

extern void sta()

extern void wrbyt(unsigned char byt)

extern bit iic_testack()

extern void mack()

extern void stop()

extern unsigned char rdbyt()

extern uchar frq[10]

sbit ds_1302=P1^5

void radio_write(void)

{

unsigned char i

stop()

sta()

wrbyt(0xc0) //洞粗TEA5767写地址

if(!iic_testack())

{

for(i=0i<5i++)

{

wrbyt(radio_write_data1[i])

mack()

}

}

stop()

}

//读TEA5767状态,并转换成频率

void radio_read(void)

{

unsigned char i

unsigned char temp_l,temp_h

pll=0

stop()

sta()

wrbyt(0xc1) //TEA5767读地址

if(!iic_testack())

{

for(i=0i<5i++)

{

radio_read_data[i]=rdbyt()

mack()

}

}

stop()

temp_l=radio_read_data[1]

temp_h=radio_read_data[0]

temp_h&=0x3f

pll=temp_h*256+temp_l

get_frequency()

}

//由频率计算PLL

void get_pll(void)

{

unsigned char hlsi

unsigned int twpll=0

hlsi=radio_write_data[2]&0x10

if (hlsi)

pll=(unsigned int)((float)((frequency+225)*4)/纳没镇(float)32.768) //频率单位:k

else

pll=(unsigned int)((float)((frequency-225)*4)/(float)32.768) //频率单位:k

}

//由PLL计算频率

void get_frequency(void)

{

unsigned char hlsi

unsigned int npll=0

npll=pll

hlsi=radio_write_data[2]&0x10

if (hlsi)

frequency=(unsigned long)((float)(npll)*(float)8.192-225) //频率单位:KHz

else

frequency=(unsigned long)((float)(npll)*(float)8.192+225) //频率单位:KHz

}

//手动设置频率,mode=1,+0.1MHzmode=0:-0.1MHz ,不用考虑TEA5767用于搜台的相关位:SM,SUD

void search(bit mode)

{

radio_read()

if(mode)

{

frequency+=50

if(frequency>max_freq)

frequency=min_freq

}

else

{

frequency-=50

if(frequency<min_freq)

frequency=max_freq

}

EA=0

get_pll()

radio_write_data1[0]=pll/256

radio_write_data1[1]=pll%256

radio_write_data1[2]=0x20

radio_write_data1[3]=0x11

radio_write_data1[4]=0x00

radio_write()

EA=1

}

void set_frq(uchar *frq_m)

{

EA=0

frequency=(float)((*frq_m)*1000+(*(frq_m+1))*100+(*(frq_m+2))*10+(*(frq_m+3)))*100

if((frequency<87500)||(frequency>108500))

{

EA=1

*frq_m=0

*(frq_m+1)=0

*(frq_m+2)=0

*(frq_m+3)=0

return

}

get_pll()

radio_write_data1[0]=pll/256

radio_write_data1[1]=pll%256

radio_write_data1[2]=0x20

radio_write_data1[3]=0x11

radio_write_data1[4]=0x00

radio_write()

EA=1

}

void auto_search(uchar dec)

{

int k=0

unsigned char aa[6]={0}

ds_1302=0

radio_write()

if(dec)

{

while(frequency<max_freq)

{

get_pll()

radio_write_data1[0]=pll/256

radio_write_data1[1]=pll%256

radio_write_data1[2]=0xA0

radio_write_data1[3]=0x11

radio_write_data1[4]=0x00

radio_write_data1[0]|=0x40

radio_write()

for(k=0k<20000k++)

EA=0

radio_read()

if((radio_read_data[0]&0x80))

{

EA=0

frequency+=50

return

}

}

frequency=min_freq

}

else

{

while(frequency>min_freq)

{

get_pll()

radio_write_data1[0]=pll/256

radio_write_data1[1]=pll%256

radio_write_data1[2]=0x20

radio_write_data1[3]=0x11

radio_write_data1[4]=0x00

radio_write_data1[0]|=0x40

radio_write()

for(k=0k<20000k++)

EA=0

radio_read()

if((radio_read_data[0]&0x80))

{

EA=0

frequency-=50

return

}

}

frequency=max_freq

}

}

程序太多,请查收你的邮箱!


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/12398594.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-25
下一篇 2023-05-25

发表评论

登录后才能评论

评论列表(0条)

保存