OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 2326|回复: 4

IIC停止信号的一个疑问

[复制链接]

12

主题

68

帖子

0

精华

初级会员

Rank: 2

积分
176
金钱
176
注册时间
2016-9-20
在线时间
56 小时
发表于 2017-9-15 16:19:52 | 显示全部楼层 |阅读模式
1金钱
先上原子的例程代码
//产生IIC停止信号
void IIC_Stop(void)
{
SDA_OUT();//sda线输出
IIC_SCL=0;
IIC_SDA=0;//STOP:when CLK is high DATA change form low to high
  delay_us(4);
IIC_SCL=1;
IIC_SDA=1;//发送I2C总线结束信号
delay_us(4);           
}

然后IIC停止的时序信号是当SCL处于逻辑高的时候,SDA由低到高跳变,产生IIC停止信号。

那按照如下代码是否也是可以?
void IIC_Stop(void)
{
SDA_OUT();//sda线输出
IIC_SCL=1;
IIC_SDA=0;//STOP:when CLK is high DATA change form low to high
  delay_us(4);
IIC_SDA=1;//发送I2C总线结束信号
delay_us(4);           
}

正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

12

主题

68

帖子

0

精华

初级会员

Rank: 2

积分
176
金钱
176
注册时间
2016-9-20
在线时间
56 小时
 楼主| 发表于 2017-9-15 16:24:52 | 显示全部楼层
我自己分析过下面的代码、觉得有漏洞但是我觉得应该也是可以的、在停止位出现之前、假如SCL和SDA都处于逻辑高,这个时候SCL=1;SDA=0;delay(4us);相当于给了一个开始信号,但是后面紧接着SDA=1;delay(4us);有相当于给了一个停止信号。求高手指点
回复

使用道具 举报

81

主题

1002

帖子

0

精华

论坛大神

Rank: 7Rank: 7Rank: 7

积分
1876
金钱
1876
注册时间
2014-9-10
在线时间
208 小时
发表于 2017-9-15 18:02:20 | 显示全部楼层
IIC_SCL=1;//SCL=1期间,除了开始停止信号,SDA不允许跳变
IIC_SDA=0;//可能会产生新的起始信号
小小蜗牛
回复

使用道具 举报

54

主题

372

帖子

0

精华

高级会员

Rank: 4

积分
979
金钱
979
注册时间
2016-6-15
在线时间
474 小时
发表于 2017-9-15 19:43:57 | 显示全部楼层
(假如SCL和SDA都处于逻辑高,这个时候SCL=1;SDA=0;delay(4us);相当于给了一个开始信号) ,起始信号启动之后,SCL =1时SDA不允许变化。
回复

使用道具 举报

2

主题

13

帖子

0

精华

新手上路

积分
37
金钱
37
注册时间
2017-9-19
在线时间
8 小时
发表于 2017-9-20 15:00:38 | 显示全部楼层
SCL为高期间,SDA上的数据必须保持稳定(SDA不能拉高或拉低),所以个人认为最好的逻辑是SCL的初始状态就是0
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-6-18 05:56

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表