1、IIC物理层

  1. IIC通信属于同步半双工通信,IIC总线由两根信号线组成。一根是数据线SDA,一根是时钟线SCL,时钟线只能由主机发送给从机,数据线可以双向进行通信,总线上可挂载多个设备,挂载数量受到总线最大电容400pF限制,同时也受地址位数的影响。
  2. 连接在IIC总线上的设备都有自己的地址,主机可以通过地址寻找到挂载在总线上的设备,如果是一个MCU与外部设备例如OLED进行连接的时候,MCU的地址可以通过软件进行修改,外部设备如OLED(无法直接进行程序配置的设备)则可以通过修改它的硬件电路进行设备地址的修改。
  3. IIC总线上支持挂载多个IIC设备,包括主机设备和从机设备,当多个主机使用总线的时候,为了防止数据冲突,会利用仲裁的方式决定哪个设备占用总线。
  4. IIC总线会外接上拉电阻。当总线空闲的时候,两根线都为高电平。

2、IIC通信协议

1、IIC的开始与结束信号

• 空闲时:SCL和SDA在上拉电阻的作用下变为高电平。

• 开始时:SCL为高电平时,SDA由高电平变为低电平。

• 结束时:SCL为高电平,SDA由低电平变为高电平。

2、传输数据的过程

• 当SCL为高电平的时候,SDA稳定不变,此时SDA传输数据有效。

• 当SCL为低电平的时候,SDA可以改变高低电平,改变传输数据的bit位。

3、应答信号

  IIC设备进行通信的时候,例如数据和地址传输的时候,会带有响应机制。接收数据的时候,当发送数据端讲地址或者数据发送过来之后,若希望继续发送数据,接收端会向发送端发送 “ ACK ”信号表示希望对方继续发送数据,若接收端希望结束数据传输,则发送“ NACK(非应答信号) ”,发送端就会停止发送数据。

  在我们看到的代码和例程中很多都是这样写的,stm32的参考手册上也是一步一个检验,工程上这样使用是没有问题的,但是在IIC的通信协议上实际上并没有特别规定 ACK 信号什么时候发送和接收,在一些代码里面我们也可以看到,主从机关于应答信号这一块是我们人为设定的,也就是说,如果我们将主从机的程序设定好,也可以不用或者减少使用 ACK 应答的模式,这一点是一个写IIC驱动程序的时候的误区。

4、读写操作

• 写操作

1、主机要先发送start起始信号

2、主机发送I2C地址和和写操作位

3、从机返回ACK信号

4、之后主机发送寄存器地址

5、从机再次返回Ack信号

6、主机给从机发送数据

7、从机发送ACK信号,主机可以发送stop信号,也可以继续发送数据,继续进行通信。

单次读写

8、如果要写入多个数据只需要发送端继续发送数据,然后接收ACK信号即可。

多次读写

• 读操作

1.主机发送START信号,等待ACK应答。

2.从机发送ACK信号。

3.主机发送从机地址和写操作位,等待ACK应答信号。

4.从机发送ACK信号。

5.主机接收到ACK信号,发送从机寄存器地址,等待ACK信号。

6.从机发送ACK信号。

7.主机发送START起始信号,等待ACK应答

8.从机发送ACK信号给主机。

9.从机发送数据给主机,等待主机发送ACK信号

10.若想继续读取数据,主机可以继续发送ACK信号给从机,若不想继续读取,则发送NACK信号,停止接收数据。

读操作过程

  值得一提的是 7,8 这两步是为了照顾从机的响应时间而设置的,若从机响应足够快,或者主从机约定好通信时间,这两步可以取消。从这个读操作我们就可以看出实际上从机并没有能力直接把数据发送给主机,一切都是由主机引导的,所谓的从机发送数据给主机,实际上是依靠主机发送命令以后,从从机寄存器的地址读取数据来达到双向通信的。

硬件IIC驱动原理的更多相关文章

  1. STM32硬件IIC驱动设计(转)

    源: STM32硬件IIC驱动设计 参考: STM32—硬件IIC主机通信 STM32’s I2C 硬件BUG引发的血案(qzm) 解决STM32 I2C接口死锁在BUSY状态的方法讨论

  2. 九、IIC驱动原理分析

    学习目标:学习IIC驱动原理: 一.IIC总线协议 IIC串行总线包括一条数据线(SDA)和一条时钟线(SCL),支持“一主多从”和“多主机”模式:每个从机设备都有唯一的地址来识别. 图 1 IIC ...

  3. 4、CC2541芯片中级教程-OSAL操作系统(简单AT指令实现+IIC软件和硬件实现驱动MPU6050)

    本文根据一周CC2541笔记汇总得来—— 适合概览和知识快速索引—— 全部链接: 中级教程-OSAL操作系统\OSAL操作系统-实验01 OSAL初探 [插入]SourceInsight-工程建立方法 ...

  4. Android中Input型输入设备驱动原理分析(一)

    转自:http://blog.csdn.net/eilianlau/article/details/6969361 话说Android中Event输入设备驱动原理分析还不如说Linux输入子系统呢,反 ...

  5. Android中Input型输入设备驱动原理分析<一>

    话说Android中Event输入设备驱动原理分析还不如说Linux输入子系统呢,反正这个是没变的,在android的底层开发中对于Linux的基本驱动程序设计还是没变的,当然Android底层机制也 ...

  6. Android之 看“马达”如何贯通Android系统 (从硬件设计 --> 驱动 --> HAL --> JNI --> Framework --> Application)

    在Android 2.3(Gingerbread) 系统的时候,我写过一篇关于“Android 震动马达系统“的文章,当时的Linux内核还是2.6版本的.写那篇文章的目的,是想彻底的了解从硬件到驱动 ...

  7. pwm驱动原理和代码实现

    学这个pwm真是非常曲则,首先是看s3c2440的datasheet,全英文的,并且还有硬件的时序图(非常多是硬件的工作原理,和软件控制不相关). 看了非常久加上网上看了资料才把这个pwm弄通. 当然 ...

  8. STM32 IIC双机通信—— HAL库硬件IIC版

    参考传送门 关于IIC的原理这里我就不多说了,网上有很多很好的解析,如果要看我个人对IIC的理解的话,可以点击查看,这里主要讲一下怎样利用STM32CubeMx实现IIC的通讯,经过个人实践,感觉HA ...

  9. IIC驱动学习笔记,简单的TSC2007的IIC驱动编写,测试

    IIC驱动学习笔记,简单的TSC2007的IIC驱动编写,测试 目的不是为了编写TSC2007驱动,是为了学习IIC驱动的编写,读一下TSC2007的ADC数据进行练习,, Linux主机驱动和外设驱 ...

随机推荐

  1. 基于SqlSugar的开发框架循序渐进介绍(7)-- 在文件上传模块中采用选项模式【Options】处理常规上传和FTP文件上传

    在基于SqlSugar的开发框架的服务层中处理文件上传的时候,我们一般有两种处理方式,一种是常规的把文件存储在本地文件系统中,一种是通过FTP方式存储到指定的FTP服务器上.这种处理应该由程序进行配置 ...

  2. JS:undefined number

    undefined数据类型:未定义属性 undefined 表示不含值 <script> var t1=""; var t2; if (t1===undefined) ...

  3. VirtualBox虚拟机安装Ubuntu系统后,增加内存空间和处理器核心数

    对于Linux爱好者而言,初次使用虚拟机时,一般都会使用默认的设置,例如硬盘空间.内存空间等等. 而往往在熟悉之后,安装了某些必要的软件,或者熟悉了实际的开发场景后,却发现原本给虚拟机分配的物理资源是 ...

  4. sql-sql优化

    SQL执行流程 a. 编写过程: select dinstinct .. from .. join .. on .. where .. group by .. having .. order by . ...

  5. nginx 出现An error occurred错误

    原因是我nginx中conf文件的配置里面 location中的 这一块内容是 #注释的那两行 所以报错出现这个错误. 后来将这两行注释掉,改成这两个就好了. root html; index ind ...

  6. CSS进阶内容——布局技巧和细节修饰

    CSS进阶内容--布局技巧和细节修饰 我们在之前的文章中已经掌握了CSS的大部分内容,但仍有一些内容我们没有涉略,这篇文章就是为了补充前面没有涉及的内容,为我们的知识做出补充并且介绍一些布局技巧 当然 ...

  7. 腾讯云EKS 上部署 eshopondapr

    腾讯云容器服务(Tencent Kubernetes Engine,TKE)基于原生 kubernetes 提供以容器为核心的.高度可扩展的高性能容器管理服务.腾讯云容器服务完全兼容原生 kubern ...

  8. java包机制

  9. 5-6 Elasticsearch

    Elasticsearch概述 什么是Elasticsearch elastic:富有弹性的 search:搜索 在计算机开发界简称ES 这个软件不是SpringCloud的组件,甚至其他语言都可以使 ...

  10. Template -「高斯消元」

    #include <cstdio> #include <vector> #include <algorithm> using namespace std; doub ...