DW_apb_i2c学习笔记之I2C协议部分

2023-10-27 18:50

本文主要是介绍DW_apb_i2c学习笔记之I2C协议部分,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

i2c 协议

START & STOP condition

![[Pasted image 20220905111501.png]]

  • bus为IDLE的时候,SCL和SDA都为高
  • 当SCL为高的时候,把SDA拉低发出START condition
  • 当SCL为高的时候,把SDA拉高发出STOP condition
  • 在SCL为low的时候可以改变数据,但是当SCL为1的时候必须要保持数据stable

address slave protocl

  • 7 bit address format bits 7:1 表示slave地址,bit0表示读写 0为写,1为读[[Pasted image 20220905113648.png]]

  • 10 bit address format 由2个byte组成第一个byte的前5个bits表示告诉slave这是一个10 bits address,图中A9,A8 A7-A0都用来表示10bit的地址 在这里插入图片描述

    • 第一个byte的定义 在这里插入图片描述

Transmitting & Receiving protocol

  • master- transmitter and slave-receiver

    • 所有的data都是以byte长度进行传输,
    • master发送address和R/W信号之后,slave需要response一个acknowledege信号
    • master传输完每1 byte data之后slave也需要ACK,注意这里的ACK是receiver必须发给transmiter的,有可能发给master,也有可能发给slave
    • 如果slave没有respond ACK pulse,master会用STOP去中断传输,slave必须拉高SDA这样master才能中断传输
    • ![[Pasted image 20220905134332.png]]
  • master-receiver and slave-transmitter

    • master每接收一个byte都要发一个ACK给slave,但是在最后1个byte的时候,master会发一个NACK表示这是最后1个byte。
    • 在slave检测到master发出的NACK,会拉高SDA(释放SDA line) ,这样master才可以issue一个STOP condition,如果master不想交出总线,可以发出一个RESTART conditon之后他可以重新选择一次地址和R/W,如下图10bit的情况 在这里插入图片描述

START BYTE transfer protol

当没有板上的i2c HW module的时候,需要一个START BYTE的协议,比如和DW_apb_i2c交互的时候。为什么需要START BYTE,因为硬件上面没有处理器这种可以轮询的device的时候需要让软件去轮询总线的行为,使用常规的START condition的时候容易错过,因此扩展START BYTE为‘00000001’并用较低频率去采样SDA line,只要查到7个0中的任何1个0,就改为高速。

  • 当DW_apb_i2c作为slave的时候i2c bus会一直处于最高速的状态,不需要START BYTE transfer
  • 当DW_apb_i2c作为master的时候需要在每一个transfer的开头加上START BYTE,以确保slave device接收到了
  • START byte的过程:
    1. master 产生 START condition
    2. master transmit START byte ’00000001‘
    3. master transmit ACK clock pulse
    4. No slave sets the ACK to 0(没有任何一个slave响应ACK)
    5. master generate RESTART conditon
      HW receiver不需要respond START BYTE,因为它是保留地址
      在RESTART conditionu之后就被复位
      在这里插入图片描述

timing spec

![[Pasted image 20220913093655.png]]

  • tf tr,分别对应falling edge和rising edge的时间,两个transition之间的时间,30%-70%图中

  • setup time,hold time分别对应采样前/后数据要保持稳定的时间,图中分别对应了SCL 上升沿到数据改变状态的这段时间和SCL下降沿到数据改变状态的这段时间

  • START conditon setup hold time

    • START conditon hold time 表示在SCL下降之前应该保持稳定的时间
    • START conditon setup time只有在RESTART的情况下才有,表示在restart之前SDA应该保持为高的时间
    • 在这里插入图片描述
  • STOP condition setup time

    • 指的是在SCL为高的时候SDA在变高之前应保持稳定的时间 在这里插入图片描述
  • setup time for data

    • 在这里插入图片描述
  • Buffer time

    • buffer time specifies the bus free time between stop and start condition,如果不满足的话,slave device可能就不能把新的START condition看作一次新的传输,从而不会respond在这里插入图片描述

这篇关于DW_apb_i2c学习笔记之I2C协议部分的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/287660

相关文章

一文详解如何在Python中从字符串中提取部分内容

《一文详解如何在Python中从字符串中提取部分内容》:本文主要介绍如何在Python中从字符串中提取部分内容的相关资料,包括使用正则表达式、Pyparsing库、AST(抽象语法树)、字符串操作... 目录前言解决方案方法一:使用正则表达式方法二:使用 Pyparsing方法三:使用 AST方法四:使用字

利用Python快速搭建Markdown笔记发布系统

《利用Python快速搭建Markdown笔记发布系统》这篇文章主要为大家详细介绍了使用Python生态的成熟工具,在30分钟内搭建一个支持Markdown渲染、分类标签、全文搜索的私有化知识发布系统... 目录引言:为什么要自建知识博客一、技术选型:极简主义开发栈二、系统架构设计三、核心代码实现(分步解析

Nginx中配置HTTP/2协议的详细指南

《Nginx中配置HTTP/2协议的详细指南》HTTP/2是HTTP协议的下一代版本,旨在提高性能、减少延迟并优化现代网络环境中的通信效率,本文将为大家介绍Nginx配置HTTP/2协议想详细步骤,需... 目录一、HTTP/2 协议概述1.HTTP/22. HTTP/2 的核心特性3. HTTP/2 的优

关于WebSocket协议状态码解析

《关于WebSocket协议状态码解析》:本文主要介绍关于WebSocket协议状态码的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录WebSocket协议状态码解析1. 引言2. WebSocket协议状态码概述3. WebSocket协议状态码详解3

Mysql删除几亿条数据表中的部分数据的方法实现

《Mysql删除几亿条数据表中的部分数据的方法实现》在MySQL中删除一个大表中的数据时,需要特别注意操作的性能和对系统的影响,本文主要介绍了Mysql删除几亿条数据表中的部分数据的方法实现,具有一定... 目录1、需求2、方案1. 使用 DELETE 语句分批删除2. 使用 INPLACE ALTER T

Java进阶学习之如何开启远程调式

《Java进阶学习之如何开启远程调式》Java开发中的远程调试是一项至关重要的技能,特别是在处理生产环境的问题或者协作开发时,:本文主要介绍Java进阶学习之如何开启远程调式的相关资料,需要的朋友... 目录概述Java远程调试的开启与底层原理开启Java远程调试底层原理JVM参数总结&nbsMbKKXJx

Qt 中集成mqtt协议的使用方法

《Qt中集成mqtt协议的使用方法》文章介绍了如何在工程中引入qmqtt库,并通过声明一个单例类来暴露订阅到的主题数据,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录一,引入qmqtt 库二,使用一,引入qmqtt 库我是将整个头文件/源文件都添加到了工程中进行编译,这样 跨平台

Java深度学习库DJL实现Python的NumPy方式

《Java深度学习库DJL实现Python的NumPy方式》本文介绍了DJL库的背景和基本功能,包括NDArray的创建、数学运算、数据获取和设置等,同时,还展示了如何使用NDArray进行数据预处理... 目录1 NDArray 的背景介绍1.1 架构2 JavaDJL使用2.1 安装DJL2.2 基本操

Java如何接收并解析HL7协议数据

《Java如何接收并解析HL7协议数据》文章主要介绍了HL7协议及其在医疗行业中的应用,详细描述了如何配置环境、接收和解析数据,以及与前端进行交互的实现方法,文章还分享了使用7Edit工具进行调试的经... 目录一、前言二、正文1、环境配置2、数据接收:HL7Monitor3、数据解析:HL7Busines

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert