详谈IIC
前言
在嵌入式底层系统中,常见的通讯方式,串口,IIC,SPI,IIS等,一般IIC,SPI,IIS更多的采取IO模拟,其余CAN,UART均是硬件设计直接支持,而IIC主要用于多数传感器数据的读写,IIS更多用于语音驱动,SPI则用于传输要求较快的场景,如图像传输等,本文则着重阐述作者认知中的IIC,以及相关的实例和实际过程中的细微处理等,有机会和时间再慢慢写其他。
硬件设计注意
一般来说IIC主要有两根主要的线,SDA和SCL(去除电源相关的VCC和GND),硬件设计过程中SDA和SCL注意做上拉处理,电阻的选值在一定基础上也会影响到整体的通讯速率。
IIC的基础规则
1.基本约定
(1)总线上主和从、发和收的关系不是恒定的,而取决于此时数据传送方向。如果主机要发送数据给从器件,则主机首先寻址从器件,然后主动发送数据至从器件,最后由主机终止数据传送;如果主机要接收从器件的数据,首先由主器件寻址从器件.然后主机接收从器件发送的数据,最后由主机终止接收过程。在这种情况下.主机负责产生定时时钟和终止数据传送。
(2)通常来说IIC设备一般会存在一个设备编号,用于区分相关的设备,占7个bit,最后一个bit作为此次操作的读写处理位,最后一个bit为0表示写,为1表示读取(此处顺序是从高数据到低数据算的),例如51H—>0101 0001,当我们要写入数据的时候需要传输1010 0010 也就是A2H数据。
(3)发送到SDA 线上的每个字节必须为8 位,每次传输可以发送的字节数量不受限制。每个字节后必须跟一个响应位。首先传输的是数据的最高位(MSB),如果从机要完成一些其他功能后(例如一个内部中断服务程序)才能接收或发送下一个完整的数据字节,可以使时钟线SCL 保持低电平,迫使主机进入等待状态,当从机准备好接收下一个数据字节并释放时钟线SCL 后数据传输继续。
(4)规定,只允许SCL为高的时候,SDA的数据有效传输,也就是说我们在SCL为低的时候修改SDA的电平去表示你要传输的bit电平,修改稳定后我们将SCL拉高,另一个设备读取到SCL高的时候会去采样SDA的电平,注意这里的措辞是稳定,根据选型的芯片和通讯要求等,一般会做一定的延时,具体可以看相关的设备的手册。
(5)IIC是一个半双工,这是由其数据性决定的,SDA作为数据的主要传输线路,不可能同时传输两端数据。
2.IIC的基本传输流程
IIC根据SCL和SDA的线路情况将通讯的状态分为以下几种,空闲状态(IDLE状态),起始信号(START信号),确认信号(ACK/NACK),停止信号(STOP信号),相对实际通讯过程中,我们会多加几个通讯流程,数据传输阶段,等待确认信号。
3.相关传输流程的SCL和SDA的处理
以下会做一个简单的通讯过程的说明,以程序设计流程为示例,注意以下过程修改引脚的时候注意电平转换一般需要延时时间
空闲态:一开始没有数据传输的过程中会处于空闲态,SDA=SCL=1,两者均保持高电平,从一种角度上来说为什么建议加上拉,从抗干扰层次说也是,如果做键盘扫描没有加上拉的话,可能会体会更深,从软件上来说浮空就是1,但是实际上要从EDA设计角度来说,一般会认为是X,未知态。
起始信号:SCL=1,SDA-=1>SDA=0,当SCL为高的时候SDA由高为低,下降沿,从设计的角度来说,数据的传输必然是起始开始的,之所以设定在SCL高的时候,让SDA为0表示起始信号,个人理解是这样是设计让数据变化更快,只需要更改一根线的电平,可以参考格雷码的存在意义,起始信号一般是空闲态转后的状态。
数据传输:第一个传输的是地址+读写标志位组成的8bit数据,当起始信号的存在被检测后,将SCL=0,然后修改对应的SDA,认为SDA引脚稳定表达你想要的逻辑电平后,SCL=1,另一个设备检测到SCL为1后会开启采样,给予另一个设备足够的采样时间采用SDA,这样就完成1bit的传输。
ACK/NACK:当完成如上的8个bit数据传输后,设备会等待接收到数据的响应信号,当接收到数据的设备已经发完或者异常情况(常见的异常,请见下面补充),或者没有传输完成则会表示ACK让你进行下一步操作,告诉你已经做完一个数据步骤,ACK:SCL高电平时,SDA为低电平,NACK:SCL高电平时,SDA为高电平,按照个人理解的话,常见的程序存在两种,一种是不管直接进行下一个步骤就进行ACK判断,一种是会将释放SDA的控制,SCL=0,SDA=1,SCL=1,让另一个设备去拉低SDA来排除最后一个字节发送为0的时候的区分,作为等待ACK或者NACK的程序设计,NACK和空闲的状态表示一样。
停止信号:SCL=1,SDA=0–>SDA=1在SCL为高电平时,SDA上升沿。以停止信号作为整个程序的指令的结束。
具体事例流程说明
上图是VCNL4200传感器的协议流程图,采取的官方数据手册,白色是主设备做的,深色是VCNL做的。
1.先初始化IO口,对于我们来说SCL必然是我们一直控制的,做为主设备,设置输出,也可以将SDA=1做为输出,进入空闲态。
2.如图的第一个表示的是写数据,开始信号,由空闲进入开始,开始信号的要求是SCL的时候SDA一个下降沿,我们可以直接将SDA拉低即可。
3.传输数据地址,VCNL4200的地址是51H,通过上面的示例得到,我们写的时候变成了A2H,将SCL拉低,然后SDA拉高,后再将SCL拉高,如此处理8个bit。
4.进入等待阶段ACK阶段,按照上面的两种方式中的一种即可
5.后面同2-4,知道P阶段,先在SCL为低的情况下,拉低SDA,然后将SCL=1,SDA=1,产生一个上升沿作为结束。
6.对于读取来说,不一样的就是从设备读取的过程,在这个过程中仍然是主设备控制SCL,我们会释放SDA,将SCL拉低,给予从设备一段时间,然后其去修改SDA的电平,然后我们读取SDA的逻辑电平,用于表示读取到的bit数据,在读取到8bit数据后给予ACK或者NACK反应。
补充:
通讯过程中出现以下情况,总线上会出现NACK信号:
1)接收方忙于其他事情,不能接收数据
2)接收方不能理解收到的数据或者没有空间存储数据
3)主机读取数据完成,返回NACK告知从机读取完成。
相关文章:

详谈IIC
前言 在嵌入式底层系统中,常见的通讯方式,串口,IIC,SPI,IIS等,一般IIC,SPI,IIS更多的采取IO模拟,其余CAN,UART均是硬件设计直接支持,而IIC主要用于多数传感器数据的读写,…...

【Autoware】采集实验数据bag包并仿真运行
文章目录1. 官方demo包2. 控制底层地图采集3. 感知定位4. 规划控制5. 仿真或实车运行1. 官方demo包 wget http://db3.ertl.jp/autoware/sample_data/sample_moriyama_data.tar.gz wget http://db3.ertl.jp/autoware/sample_data/sample_moriyama_150324.tar.gz官方示例包的网上…...

名创优品怎么把创意做成生意?
最近,“主”无处不在,从让“依托答辩”梗火出圈的动画《三体》,到备受好评的电视剧《三体》,再到仍在刷新高票房成绩的《流浪地球2》。作为近些年来中国为数不多的爆款IP制造者,刘慈欣在《三体》中提出了一个著名的理论…...

springboot原项目配置文件迁移至nacos
目录一、配置文件迁移nacos1.安装nacos2.添加依赖3.改造service-product3.改造server-gateway一、配置文件迁移nacos 1.安装nacos 1,如果之前安装过nacos,nacos数据保存至mysql,先删除已安装的nacos,再安装 docker stop nacos …...

常用的shell脚步操作
文章目录一、如何开始一个shell脚本?1.基本语法2.变量定义规则二、特色变量1.$n2.$?三、条件判断1.基本语法2.运算符if,for,while四、字符串切割1.从指定位置开始截取从字符串左边开始计数从右边开始计数2.从指定字符(子字符串)开…...

Java on VS Code 2月更新|JUnit 5 并行测试与 Spring Boot 插件的过滤功能
作者:Nick Zhu - Senior Program Manager, Developer Division at Microsoft 排版:Alan Wang 大家好,欢迎来到我们的二月更新!在此博客中,我们将为您带来与 JUnit 5 并行测试相关的新功能以及用于 Spring Boot Dashboa…...

无线WiFi安全渗透与攻防(三)之Windows扫描wifi和破解WiFi密码
系列文章 无线WiFi安全渗透与攻防(一)之无线安全环境搭建 无线WiFi安全渗透与攻防(二)之打造专属字典 windows下wifi进行扫描和破解 1.wifi扫描 (1).软件介绍 WirelessMon是一款无线网络扫描工具,它可以帮助用户扫描附近的无线信号&…...

Python中的遍历字典的键和值
一、Python的字典在项目的开发过程中,如果遇到有映射关系的内容可以考虑使用Python中的字典进行存储数据,字典中冒号前的数据称为【键】、冒号后的数据称为【值】。二、Python字典的用法2.1、Python的定义#Python字典的定义 字典名称{键1:值1,键2:值2,键…...
三天Golang快速入门—结构体
Struct结构体什么是结构体结构体定义基本实例化new实例化键值对初始化结构体方法和接收者结构体说明结构体方法和接收者值类型和指针类型接收者struct与jsonstruct转json字符串json转structstruct tagTag结构体转化Json字符串Json字符串转成Tag结构体什么是结构体 1.Golang中没…...
日常算法刷题——力扣704
##2023/3/2 刷算法的第一天 针对力扣的704题:本题是二分查找的基本使用!在此需要注意二分查找的基本特点: 1.数列基本有序; 2.数列数据内容不可重复。 此题只需了解二分查找算法的基本概念,无坑可跳。但在力扣上刷题就…...

【服务器数据恢复】VMware虚拟机下的SQL Server数据库数据恢复案例
服务器数据恢复环境: 一台某品牌PowerEdge系列服务器和一台PowerVault系列存储,上层是ESXI虚拟机文件,虚拟机中运行SQL Server数据库。 服务器故障: 机房非正常断电导致虚拟机无法启动。管理员检查虚拟机发现虚拟机配置文件丢失&…...

详解旨在提升EVM底层性能的兼容公链Monad
EVM带来的繁荣2020年以太坊链上DeFi的蓬勃发展使得EVM成为关注焦点,大部分DeFi项目都开始基于以太坊公链,这也使得EVM成为行业的标杆,不少链都加入了EVM大军,比如polygon、BSC、fantom等等,而EVM也使得链上生态进一步繁…...
2023社会工作者证书怎么考 在哪里报名考试
考取社会工作者证需要在网上报名,社工证是证书考试,分为初级、中级和高级三个级别,一般情况下满足报考条件就可以进行报考了,在中国人事考试网上进行报名及缴费。 1考取社会工作者证的流程 1、社工证报名需要登录中国人事考试网&a…...
统计学 类别比变量的判断
文章目录类别比变量的判断一个类别变量的拟合优度检验两个类别变量的独立性检验列联表与 χ2\chi^2χ2 独立性检验应用 χ2\chi^2χ2 检验应该注意的问题两个类别变量的相关度检验φ\varphiφ 系数Cramers VVV 系数列联系数总结类别比变量的判断 一个类别变量的拟合优度检验 …...

2.基于Label studio的训练数据标注指南:(智能文档)文档抽取任务、PDF、表格、图片抽取标注等
文档抽取任务Label Studio使用指南 1.基于Label studio的训练数据标注指南:信息抽取(实体关系抽取)、文本分类等 2.基于Label studio的训练数据标注指南:(智能文档)文档抽取任务、PDF、表格、图片抽取标注等…...

如何在openKylin操作系统上搭建Qt开发环境
一、获取linux系统下的Qt安装包 Qt官网下载地址:https://download.qt.io 国内镜像下载地址:https://mirrors.cloud.tencent.com/qt/ 。建议用镜像下载速度快。集成安装包在 official_releases/qt 目录下,新地址:https://downloa…...

T_SQL和SQL的区别
一. SQL Server和T-SQL的区别(⭐T-SQL 包含了 SQL)SQL Server是结构化查询语言,是目前关系型数据库管理系统中使用最广泛的查询语言T-SQL是标准SQL语言的扩展,是SQL Server的核心,在SQL的的基础上添加了变量,运算符,函数和流程控制等,Microso…...

用Python自己写一个分词器,python实现分词功能,隐马尔科夫模型预测问题之维特比算法(Viterbi Algorithm)的Python实现
☕️ 本文系列文章汇总: (1)HMM开篇:基本概念和几个要素 (2)HMM计算问题:前后向算法 代码实现 (3)HMM学习问题:Baum-Welch算法 代码实现(…...

刷题笔记2 | 977.有序数组的平方 ,209.长度最小的子数组 ,59.螺旋矩阵II ,总结
977.有序数组的平方 给你一个按 非递减顺序 排序的整数数组 nums,返回 每个数字的平方 组成的新数组,要求也按 非递减顺序 排序。 输入:nums [-4,-1,0,3,10] 输出:[0,1,9,16,100] 解释:平方后,数组变为 […...

python 支付宝营销活动现金红包开发接入流程-含接口调用加签
1 创建网页/移动应用 2 配置接口加签方式 涉及到金额的需要上传证书,在上传页面有教程, 在支付宝开放平台秘钥工具中生成CSR证书,会自动保存应用公钥和私钥到电脑上,调用支付宝接口需要应用私钥进行加签 上传完CSR证书后会有三个…...

接口测试中缓存处理策略
在接口测试中,缓存处理策略是一个关键环节,直接影响测试结果的准确性和可靠性。合理的缓存处理策略能够确保测试环境的一致性,避免因缓存数据导致的测试偏差。以下是接口测试中常见的缓存处理策略及其详细说明: 一、缓存处理的核…...

Nuxt.js 中的路由配置详解
Nuxt.js 通过其内置的路由系统简化了应用的路由配置,使得开发者可以轻松地管理页面导航和 URL 结构。路由配置主要涉及页面组件的组织、动态路由的设置以及路由元信息的配置。 自动路由生成 Nuxt.js 会根据 pages 目录下的文件结构自动生成路由配置。每个文件都会对…...
【Go】3、Go语言进阶与依赖管理
前言 本系列文章参考自稀土掘金上的 【字节内部课】公开课,做自我学习总结整理。 Go语言并发编程 Go语言原生支持并发编程,它的核心机制是 Goroutine 协程、Channel 通道,并基于CSP(Communicating Sequential Processes࿰…...

从零开始打造 OpenSTLinux 6.6 Yocto 系统(基于STM32CubeMX)(九)
设备树移植 和uboot设备树修改的内容同步到kernel将设备树stm32mp157d-stm32mp157daa1-mx.dts复制到内核源码目录下 源码修改及编译 修改arch/arm/boot/dts/st/Makefile,新增设备树编译 stm32mp157f-ev1-m4-examples.dtb \stm32mp157d-stm32mp157daa1-mx.dtb修改…...

PL0语法,分析器实现!
简介 PL/0 是一种简单的编程语言,通常用于教学编译原理。它的语法结构清晰,功能包括常量定义、变量声明、过程(子程序)定义以及基本的控制结构(如条件语句和循环语句)。 PL/0 语法规范 PL/0 是一种教学用的小型编程语言,由 Niklaus Wirth 设计,用于展示编译原理的核…...

【Java_EE】Spring MVC
目录 Spring Web MVC 编辑注解 RestController RequestMapping RequestParam RequestParam RequestBody PathVariable RequestPart 参数传递 注意事项 编辑参数重命名 RequestParam 编辑编辑传递集合 RequestParam 传递JSON数据 编辑RequestBody …...
Caliper 配置文件解析:config.yaml
Caliper 是一个区块链性能基准测试工具,用于评估不同区块链平台的性能。下面我将详细解释你提供的 fisco-bcos.json 文件结构,并说明它与 config.yaml 文件的关系。 fisco-bcos.json 文件解析 这个文件是针对 FISCO-BCOS 区块链网络的 Caliper 配置文件,主要包含以下几个部…...

Map相关知识
数据结构 二叉树 二叉树,顾名思义,每个节点最多有两个“叉”,也就是两个子节点,分别是左子 节点和右子节点。不过,二叉树并不要求每个节点都有两个子节点,有的节点只 有左子节点,有的节点只有…...

Android 之 kotlin 语言学习笔记三(Kotlin-Java 互操作)
参考官方文档:https://developer.android.google.cn/kotlin/interop?hlzh-cn 一、Java(供 Kotlin 使用) 1、不得使用硬关键字 不要使用 Kotlin 的任何硬关键字作为方法的名称 或字段。允许使用 Kotlin 的软关键字、修饰符关键字和特殊标识…...
scikit-learn机器学习
# 同时添加如下代码, 这样每次环境(kernel)启动的时候只要运行下方代码即可: # Also add the following code, # so that every time the environment (kernel) starts, # just run the following code: import sys sys.path.append(/home/aistudio/external-libraries)机…...