共2条
1/1 1 跳转至页
I2C 关于I2C总线的调试问题,大家都进来看看
问
我想用430和24WC02进行相连,它们使用的是I2C总线,我也找了好多I2C总线的资料,但调试程序却不知从何下手(比如说用哪种方法能看到从机是否给响应信号了,怎样才能确定读出的数据正确,等等),哪位大侠能给点儿意见,小弟不胜感激。
答 1:
430的iic程序现在有很多了,c与汇编的。测试从机过来的
信号一般用bit.b 指令,然后判断z标志。如果是接受数据,用bit指令后可用rlc接收。 答 2: 请教斑竹各位大虾:
下面是一个I2C总线接收程序
Byte I2CReceiveByte(void)
{
uchar i=8;
Byte ddata=0;
SDA=1;//??此处为什么要把数据线置1
while (i--)
{
ddata<<=1;
SCL=0;SomeNOP();
SCL=1;SomeNOP();
ddata|=SDA;
}
SCL=0;
return ddata;
}
参考书说明在接收数据之前一定要把SDA置一,我有点不明白?
接收时在时钟线上产生一个脉冲信号,就把RAM中的一个BIT位移入SDA数据线,不就把原先SDA上的数据覆盖掉了吗?
为什么在哪(程序注解处)非得置一 答 3: 数据线变为输入状态自然就变高了,不必再特意置1了吧! 答 4: 430的io口是完全双向的,这点是不同于51核mcu的。
在做i2c的时候是可以挂很多从机的,把方向设置为输入可以防止总线冲突,并靠上拉电阻将口线拉高。输出方向输出1也可以把口线拉高,但在做i2c接口的时候一般都按前者做。
在你的程序里,SDA=1就是把sda口设为输入方向,是正确的。 答 5: 谢谢刘工、各位大虾指导!
信号一般用bit.b 指令,然后判断z标志。如果是接受数据,用bit指令后可用rlc接收。 答 2: 请教斑竹各位大虾:
下面是一个I2C总线接收程序
Byte I2CReceiveByte(void)
{
uchar i=8;
Byte ddata=0;
SDA=1;//??此处为什么要把数据线置1
while (i--)
{
ddata<<=1;
SCL=0;SomeNOP();
SCL=1;SomeNOP();
ddata|=SDA;
}
SCL=0;
return ddata;
}
参考书说明在接收数据之前一定要把SDA置一,我有点不明白?
接收时在时钟线上产生一个脉冲信号,就把RAM中的一个BIT位移入SDA数据线,不就把原先SDA上的数据覆盖掉了吗?
为什么在哪(程序注解处)非得置一 答 3: 数据线变为输入状态自然就变高了,不必再特意置1了吧! 答 4: 430的io口是完全双向的,这点是不同于51核mcu的。
在做i2c的时候是可以挂很多从机的,把方向设置为输入可以防止总线冲突,并靠上拉电阻将口线拉高。输出方向输出1也可以把口线拉高,但在做i2c接口的时候一般都按前者做。
在你的程序里,SDA=1就是把sda口设为输入方向,是正确的。 答 5: 谢谢刘工、各位大虾指导!
共2条
1/1 1 跳转至页
回复
有奖活动 | |
---|---|
【有奖活动】分享技术经验,兑换京东卡 | |
话不多说,快进群! | |
请大声喊出:我要开发板! | |
【有奖活动】EEPW网站征稿正在进行时,欢迎踊跃投稿啦 | |
奖!发布技术笔记,技术评测贴换取您心仪的礼品 | |
打赏了!打赏了!打赏了! |
打赏帖 | |
---|---|
【换取逻辑分析仪】-基于ADI单片机MAX78000的简易MP3音乐播放器被打赏48分 | |
我想要一部加热台+树莓派PICO驱动AHT10被打赏38分 | |
【换取逻辑分析仪】-硬件SPI驱动OLED屏幕被打赏36分 | |
换逻辑分析仪+上下拉与多路选择器被打赏29分 | |
Let'sdo第3期任务合集被打赏50分 | |
换逻辑分析仪+Verilog三态门被打赏27分 | |
换逻辑分析仪+Verilog多输出门被打赏24分 | |
【分享评测,赢取加热台】使用8051单片机驱动WS2812被打赏40分 | |
【换取逻辑分析仪】rtthread添加RRH62000传感器驱动-基于野火启明6M5被打赏48分 | |
换逻辑分析仪+Verilog多输入门被打赏27分 |