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

相关文章

HTTP 与 SpringBoot 参数提交与接收协议方式

《HTTP与SpringBoot参数提交与接收协议方式》HTTP参数提交方式包括URL查询、表单、JSON/XML、路径变量、头部、Cookie、GraphQL、WebSocket和SSE,依据... 目录HTTP 协议支持多种参数提交方式,主要取决于请求方法(Method)和内容类型(Content-Ty

Unity新手入门学习殿堂级知识详细讲解(图文)

《Unity新手入门学习殿堂级知识详细讲解(图文)》Unity是一款跨平台游戏引擎,支持2D/3D及VR/AR开发,核心功能模块包括图形、音频、物理等,通过可视化编辑器与脚本扩展实现开发,项目结构含A... 目录入门概述什么是 UnityUnity引擎基础认知编辑器核心操作Unity 编辑器项目模式分类工程

Python学习笔记之getattr和hasattr用法示例详解

《Python学习笔记之getattr和hasattr用法示例详解》在Python中,hasattr()、getattr()和setattr()是一组内置函数,用于对对象的属性进行操作和查询,这篇文章... 目录1.getattr用法详解1.1 基本作用1.2 示例1.3 原理2.hasattr用法详解2.

Java对接MQTT协议的完整实现示例代码

《Java对接MQTT协议的完整实现示例代码》MQTT是一个基于客户端-服务器的消息发布/订阅传输协议,MQTT协议是轻量、简单、开放和易于实现的,这些特点使它适用范围非常广泛,:本文主要介绍Ja... 目录前言前置依赖1. MQTT配置类代码解析1.1 MQTT客户端工厂1.2 MQTT消息订阅适配器1.

Linux中的自定义协议+序列反序列化用法

《Linux中的自定义协议+序列反序列化用法》文章探讨网络程序在应用层的实现,涉及TCP协议的数据传输机制、结构化数据的序列化与反序列化方法,以及通过JSON和自定义协议构建网络计算器的思路,强调分层... 目录一,再次理解协议二,序列化和反序列化三,实现网络计算器3.1 日志文件3.2Socket.hpp

Linux中的HTTPS协议原理分析

《Linux中的HTTPS协议原理分析》文章解释了HTTPS的必要性:HTTP明文传输易被篡改和劫持,HTTPS通过非对称加密协商对称密钥、CA证书认证和混合加密机制,有效防范中间人攻击,保障通信安全... 目录一、什么是加密和解密?二、为什么需要加密?三、常见的加密方式3.1 对称加密3.2非对称加密四、

如何在Spring Boot项目中集成MQTT协议

《如何在SpringBoot项目中集成MQTT协议》本文介绍在SpringBoot中集成MQTT的步骤,包括安装Broker、添加EclipsePaho依赖、配置连接参数、实现消息发布订阅、测试接口... 目录1. 准备工作2. 引入依赖3. 配置MQTT连接4. 创建MQTT配置类5. 实现消息发布与订阅

使用Python进行GRPC和Dubbo协议的高级测试

《使用Python进行GRPC和Dubbo协议的高级测试》GRPC(GoogleRemoteProcedureCall)是一种高性能、开源的远程过程调用(RPC)框架,Dubbo是一种高性能的分布式服... 目录01 GRPC测试安装gRPC编写.proto文件实现服务02 Dubbo测试1. 安装Dubb

Go学习记录之runtime包深入解析

《Go学习记录之runtime包深入解析》Go语言runtime包管理运行时环境,涵盖goroutine调度、内存分配、垃圾回收、类型信息等核心功能,:本文主要介绍Go学习记录之runtime包的... 目录前言:一、runtime包内容学习1、作用:① Goroutine和并发控制:② 垃圾回收:③ 栈和

Android学习总结之Java和kotlin区别超详细分析

《Android学习总结之Java和kotlin区别超详细分析》Java和Kotlin都是用于Android开发的编程语言,它们各自具有独特的特点和优势,:本文主要介绍Android学习总结之Ja... 目录一、空安全机制真题 1:Kotlin 如何解决 Java 的 NullPointerExceptio