一、物理层与电气特性

  1. 双线结构

    • SCL(串行时钟线):主设备控制,支持 推挽(Push-Pull)输出(高速模式)和 开漏(Open-Drain)(兼容I2C模式)。
    • SDA(串行数据线):双向数据线,推挽模式提升速度,开漏模式兼容I2C。
    • 上拉电阻:典型值 1–4.7 kΩ,比I2C更大(因推挽驱动降低电流需求)。
  2. 工作模式

    模式速率特性
    SDR(单倍速率)12.5 MHz基础模式,兼容I2C时序,但SCL高电平时SDA推挽输出加速上升沿。
    HDR-DDR25 Mbps双倍数据率(每时钟周期传输2比特),使用三线编码(Ternary Symbol)
    HDR-TSP33 Mbps分时传输协议,突发传输+时分复用,需专用时序。
    HDR-TSL-保留模式,未来扩展使用。

二、协议层核心机制

1. 动态地址分配(DAA)
  • 流程
    主设备发送RSTDAA CCC
    清除所有从设备动态地址
    主设备发送ENTDAA CCC
    从设备回复48-bit PID Provisional ID
    主设备分配唯一7-bit地址
  • PID结构
    • Part Number(16位) + 厂商ID(12位) + BCR/DCR(8位) + 随机数(12位)
2. 通用命令码(CCC)
  • 广播CCC(0x7E地址):所有设备同时响应(如 ENTHDR 进入高速模式)。
  • 直接CCC:针对特定设备(如 SETMWL 设置最大写长度)。
  • 关键CCC示例
    命令编码功能
    RSTDAA0x06复位动态地址
    ENTDAA0x07启动DAA过程
    ENTHDR0x20+进入HDR模式(子模式依赖参数)
    SETMWL0x22设置从设备最大写长度
3. 带内中断(IBI)
  • 触发条件:从设备在SCL高电平时拉低SDA。
  • 处理流程
    1. 主设备检测SDA低电平(SCL高)。
    2. 主设备发起IBI请求事务:发送[Start] + IBI地址(0-7位) + Read。
    3. 从设备返回 MDB(Mandatory Data Byte)
      • Bit 7:中断挂起状态(1=有中断)。
      • Bit 6:0:数据长度(可选附加数据)。

三、总线事务详解

1. SDR模式帧结构
┌───┬─────┬─────┬───┬─────┬───┬───┐
│ S │ Addr│ R/W │ACK│ Data│ACK│ P │
└───┴─────┴─────┴───┴─────┴───┴───┘
  • 地址帧
    • 7-bit I3C地址7’h7E(广播地址)
    • R/W位:0=写,1=读。
  • 数据帧:每字节后跟ACK/NACK。
2. HDR-DDR模式时序
  • 每时钟传输2比特
    • SCL上升沿:发送第一位(MSB)。
    • SCL下降沿:发送第二位(LSB)。
  • 起始条件:SDA=0 + SCL=0 → SCL=1(推挽驱动)。

四、混合总线操作(I2C与I3C共存)

  1. I2C设备识别
    • 主设备发送 I2C广播地址(0x7E + R/W=0),仅I2C设备响应ACK。
  2. 协议切换规则
    • I3C主设备需在 I2C模式(开漏)I3C模式(推挽) 间动态切换。
    • 关键限制:HDR模式期间禁止I2C设备通信。

五、错误处理与仲裁

  1. 冲突检测
    • 多主竞争:主设备在SDA推挽输出时检测电平冲突(输出高却读到低)。
    • 仲裁失败:立即释放总线,等待重试。
  2. 超时机制
    • SCL超时:从设备检测SCL低电平 > 最大时钟延展时间(典型值25ms) 时复位。

六、典型应用场景

  1. 传感器集线器
    多个低功耗传感器通过I3C接入主处理器。
  2. 移动设备
    摄像头、触摸屏等外设的高效通信。
  3. 汽车电子
    满足低延迟、高可靠性的车载传感器网络需求。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/pingmian/88974.shtml
繁体地址,请注明出处:http://hk.pswp.cn/pingmian/88974.shtml
英文地址,请注明出处:http://en.pswp.cn/pingmian/88974.shtml

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Docker搭建Redis哨兵集群

Redis提供了哨兵机制实现主从集群下的故障转移,其中包含了对主从服务的检测、自动故障恢复和通知。 1.环境 centos7、redis6.2.4、MobaXterm 目的: 搭建redis的主从同步哨兵集群(一主一从三哨兵) 2.步骤 1.主从集群的搭建 主从…

暑假Python基础整理 --异常处理及程序调试

异常概念 在程序运行过程中,经常会遇到各种各样的错误,这些错误统称为“异常”。如下表是Python常见的异常与描述: 异常描述NameError尝试访问一个未声明的变量引发错误IndexError索引超出序列范围引发错误IndentationError缩进错误ValueErr…

k8s-高级调度(二)

目录 Taint(污点)与Toleration(容忍) Taint(污点):节点的排斥标记 Toleration(容忍):Pod的适配声明 与节点亲和性的对比 警戒(cordon)和转移(drain) Cordon:节点隔离(阻止新 Po…

基于OpenCV的深度学习人脸识别系统开发全攻略(DNN+FaceNet核心技术选型)

核心技术选型表 技术组件版本/型号用途OpenCV DNN4.5.5人脸检测FaceNet (facenet-pytorch)0.5.0人脸特征提取MiniConda最新版Python环境管理PyTorch1.8.0FaceNet运行基础OpenVINO2021.4模型加速(可选)SSD Caffe模型res10_300x300高精度人脸检测 一、环境准备与项目搭建 1.1 M…

【AI News | 20250714】每日AI进展

AI Repos 1、All-Model-Chat All Model Chat 是一款为Google Gemini API家族设计的网页聊天应用,支持多模态输入(图片、音频、PDF等)和多种模型(如Gemini Flash、Imagen)。它提供了丰富的自定义功能,包括高…

C 语言(二)

主要包括变量与常量、数据类型、存储方式、数制转换以及字符处理等内容一、变量与常量在 C 语言中,变量是用来存储数据的命名空间,它会在内存中分配地址。例如:int i; i 12345; 其中 i 是变量,12345 是常量。常量表示在程序运行过…

原型继承(prototypal inheritance)的工作原理

这是一个非常常见的 JavaScript 问题。所有 JS 对象都有一个__proto__属性,指向它的原型对象。当试图访问一个对象的属性时,如果没有在该对象上找到,它还会搜寻该对象的原型,以及该对象的原型的原型,依次层层向上搜索&…

OpenCV 视频处理与摄像头操作详解

1. 引言大家都来写OpenCV😊,学的好开心!2. 视频基础与OpenCV简介2.1 视频的定义视频(Video)是由一系列静态图像(帧)以一定速率连续播放形成的动态影像。其本质是利用人眼的视觉暂留效应&#xf…

Agentic AI 的威胁与缓解措施

原文:https://www.aigl.blog/content/files/2025/04/Agentic-AI—Threats-and-Mitigations.pdf AI Agent 的定义 1. 定义与基础 智能代理(Agent)的定义: 智能代理是一种能够感知环境、进行推理、做出决策并自主采取行动以实现特定…

ArrayList列表解析

ArrayList集合 ArrayList 的底层是数组队列,相当于动态数组。与 Java 中的数组相比,它的容量能动态增长。在添加大量元素前,应用程序可以使用ensureCapacity操作来增加 ArrayList 实例的容量。这可以减少递增式再分配的数量。 ArrayList 继承…

《恋与深空》中龙和蛇分别是谁的代表

在《恋与深空》宏大而神秘的世界观中,每一个符号都蕴含着深意。当玩家们热议“龙”和“蛇”这两种强大而古老的生物究竟代表着谁时,所有的线索都默契地指向了同一个名字——秦彻。 他不仅是力量与权威的象征“恶龙”,也是背负着宿命与纠葛的“…

gitignore添加后如何生效?

清除 Git 缓存: git rm -r --cached .添加文件到 Git:git add .使用 git commit 命令提交这些更改git commit -m "Update .gitignore"

多尺度频率辅助类 Mamba 线性注意力模块(MFM),融合频域和空域特征,提升多尺度、复杂场景下的目标检测能力

在伪装物体检测领域,现有方法大多依赖空间局部特征,难以有效捕捉全局信息,而 Transformer 类方法虽能建模长距离依赖关系,却存在计算成本高、网络结构复杂的问题。同时,频域特征虽具备全局建模能力,可频繁的…

Dify的默认端口怎么修改

1.定位配置文件 在 Dify 的安装目录中找到 .env 文件(通常位于 docker/ 子目录下)。此文件定义了 Docker 容器的环境变量,包括端口配置。 2.调整端口参数 修改以下两个关键配置项: # Docker 容器内部 Nginx 监听的端口&#xf…

Go内存分配

图解Go语言内存分配 - 知乎 go内置运行时,采用了自主管理,实现更好的内存使用模式,不需要每次内存分配都进行系统调用 采用TCMalloc算法:把内存分为多级管理,从而降低锁的粒度 将可用的堆内存采用二级分配的方式进行…

cursor使用mcp连接mysql数据库,url方式

背景。 用cursor生成后端代码。让cursor可以创建响应的表结构以及插入数据。使用的cursor版本是1.2.1 cursor 官网 mcp 说明smithery 中mysql mcp这个mcp具有建表的本领。 在cursor中是这样配置的。 以上这种配置方式是是通过在smithery 网站中配置好自己的mysql数据库连接后才…

Twisted study notes[1]

文章目录serverreferencesserver Twisted usually using subclass twisted.internet.protocol.Protocol to treat protocols .Protocol is a fundamental class in Twisted for implementing network protocols.protocol class instant don’t exists forever because of it w…

Python 数据建模与分析项目实战预备 Day 6 - 多模型对比与交叉验证验证策略

✅ 今日目标 引入多种常见分类模型(随机森林、支持向量机、K近邻等)比较不同模型的训练效果使用交叉验证提升评估稳定性🧾 一、对比模型列表模型类名(sklearn)适用说明逻辑回归LogisticRegression基础线、易于解释KNNK…

xss-labs 1-8关

level1打开检查&#xff0c;发现test直接放入h2标签中此时通过script绕过h2标签构造payload127.0.0.1/xss-labs/lvel1.php?name<script>alert(111)</script>直接使用script标签绕过h2,并执行alert,通过level2打开检查&#xff0c;输入的123被放在input标签里面的v…

Conda 核心命令快速查阅表

本表旨在提供一个简洁、高效的 Conda 命令参考&#xff0c;专注于最常用功能的快速查找。 1. 环境管理 (Environment Management)功能 (Function)命令 (Command)示例 (Example)创建新环境conda create -n <env_name> [packages...]conda create -n myenv python3.9 panda…