万变不离其宗之I2C总线要点总结

嵌入式ARM 2020-07-05 00:00
[导读] 前文总结了单片机串口个人认为值得注意的一些要点,本文来梳理一下 I2C 总线的一些要点。这个题目有点大,本文对于 I2C 其实很多地方也没整清楚,只为了与前文形成系列,如果大家有补充欢迎留言。说了些闲话,进入正题吧。

I2C 之前世今生

(Inter-Integrated Circuit),是一种同步、多主、多从、分组交换、单端、串行计算机总线,由飞利浦半导体(现在的 NXP 半导体)在 1982 年发明。它广泛用于在短距离、板内通信中将低速外设集成电路附加到处理器和微控制器上。 也可以写成 I2C 或 IIC。

自 2006 年 10 月 10 日起,实施 I2C 协议不需要任何许可费用。但是,获得恩智浦分配的 I2C 从设备地址则需要付费。一些竞争者如西门子(后来的英飞凌技术,现在的英特尔移动通信)、NEC、德州仪器 TI、意法半导体(以前的 SGS-Thomson)、摩托罗拉(后来的飞思卡尔,现在与 NXP 合并)、Nordic 半导体和 Intersil,自 20 世纪 90 年代中期以来已经陆续发布了很多兼容的 I2C 标准的芯片。

说到总线,其种类很多,但其目的基本一致,就是一个用于传递信息的公共干线。如芯片内部地址总线、数据总线其对象可能为CPU核与各外设(RAM/ROM/外设控制器电路等);芯片级总线I2C,SPI等,设备级总线如RS422/RS485/HART/CAN/Ethernet/Fieldbus......

速度模式

自 Version 4 之后 I2C 支持下面几种模式:

  • 双向总线
    • standard-mode(Sm): ≤100 Kbit/S
    • Fast-Mode(Fm):≤400 Kbit/S
    • Fast-mode Plus(Fm+):≤1Mbit/S
    • High-speed mode (Hs-mode): ≤ 3.4 Mbit/s
  • 单向总线:
    • Ultra Fast-mode (UFm): ≤ 5 Mbit/s

I2C优势

I2C 标准能带来些啥好处呢?

  • 简单的 2 线串行 I2C 总线最小化互连,节省 PCB 布板走线空间;
  • 完全集成的 I2C 总线协议消除了地址解码器。
  • I2C 总线的多主控能力允许终端用户设备通过外部连接到装配线进行快速测试和校准。
  • 标准支持广泛,大量无铅封装 I2C 总线兼容集成芯片进一步降低了空间需求。

其他子集

系统管理总线(SMBus),由 Intel 在 1995 年定义,是 I2C 的一个子集,定义了更严格的用法。SMBus 的一个目的是促进健壮性和互操作性。因此,现代 I2C 系统合并了来自 SMBus 的一些策略和规则,有时同时支持 I2C 和 SMBus,只需要通过命令或输出引脚使用最小限度的重新配置。

TWI(双线接口)或 TWSI(双线串行接口),本质上是在 Atmel 和其他供应商的各种系统芯片处理器上实现的同一总线。

I2C 拓扑结构

从概念上,I2C 总线有两根线 SDA/SCL 就可以连一堆芯片,实现很多的应用。连接拓扑极简!

比如这样一个系统:

  • LCD 显示
  • ADC 采样
  • EEPROM/FRAM 非易失存储
  • 温度采集
  • .....

接下来看看各模式下,连接拓扑图:

标准速度/快速模式

高速模式拓扑

混速模式拓扑

工作原理

如果使用 IO 口模拟 I2C 总线,或者使用 FPGA 实现 I2C 接口,深刻理解 I2C 时序波形无疑是重点中的重点!即使使用内置的 I2C 控制器外设实现一个 I2C 总线编程,在调试底层时或者踩坑过程中,深入理解时序波形原理,也是非常必要的!

时序图

I2C 的时序图如下:

  • START 事件:可以联想一下 UART 的起始位,这个用于通知 I2C 通信的发起。用一句话描述就是在 SCL 常高时,采集到 SDA 高到低跳变,这就是启动事件。

  • 数据有效性SDA 线上的数据必须在时钟的高周期保持稳定。数据线的高或低状态只能在 SCL 线上的时钟信号低时改变。每个传输的数据位产生一个时钟脉冲。

  • ACK:确认信号 ACK 的定义如下:发送器在 ACK 时钟脉冲期间释放 SDA 线,因此接收器可以将 SDA 线拉低,并在此时钟脉冲的高电平期间保持稳定的低电平(见上图)。须严格遵循电气的建立保持时间,使用时需要用示波器去严格测试信号是否能满足这些参数。

  • NACK:当在第九个时钟脉冲期间 SDA 保持高电平时,这被定义为“NACK”信号。之后主机可以产生停止条件以中止传输,或产生重复的开始条件以开始新的传输。导致 NACK 产生的条件有五个:

  1. 总线上没有报文中所包含地址的接收器,因此没有设备响应应答。
  2. 接收器无法执行接收或发送操作,比如它正在执行某些实时功能,并且尚未准备好与主机进行通信。
  3. 在传输过程中,接收器收到应用协议不理解的数据或命令。
  4. 在传输期间,接收器无法再接收更多有效数据字节。比如程序或者芯片内置缓冲区已经满了
  5. 主接收器用 NACK 通知从发送器结束传输。这是何意呢?比如主设备已经接受到足够多的数据,不希望从设备发送更多的数据时,就可以 NACK 从设备,这样从设备就会停止发送

时钟同步与仲裁

  • 时钟同步:两个主机可以同时开始在空闲总线上进行传输,并且必须有一种方法来确定控制总线并完成其传输的方法。这是通过时钟同步和仲裁完成的。在单主机系统中,不需要时钟同步和仲裁。

    时钟同步是通过 I2C 接口中 SCL 线的线与实现的。啥意思呢?

    这里的几句话需要划重点去理解,这就是 I2C 总线的核心之核心工作原理:线与

    • 当 SCL 从高到低的过渡时,总线上的主机开始计数其低电平时间,且一旦主机时钟变为低,它就会将 SCL 保持在该状态,直到变为高状态为止。
    • 但是,如果另一个主机时钟仍在其低周期内,则此时钟从低到高的转变不会改变 SCL 线的状态。所以, SCL 线由主机以最长的低电平周期保持为低电平低电平周期较短的主机在此期间进入高电平等待状态
    • 上面的话不好理解?看看 线与的本质是 ,啥叫与呢?比如 C=A&B,只要其中一个变量 A/B 为低,那么 C 就必然为 0,比如下图中,即便 CLK1(为其中一个主机)为高了,但奈何另一主机的 CLK2 任然为低啊?所以 SCL 线上测出来就是低。
    • 当所有相关的主机都计数完低电平周期后,时钟线被释放并变为高电平。这样,主时钟和 SCL 线的状态之间就没有区别,所有主时钟都开始计数其高电平周期。第一个完成其高电平周期的主机将 SCL 线再次拉低。
  • 仲裁:仲裁与同步类似,仅在系统中使用多个主机时才会涉及到,从站不参与仲裁过程。首先要理解一下仲裁是干啥的?所谓仲裁就是在多主机模式下,哪一个主机能获取介质的访问权限,获得权限的主机才可以传输 I2C 通信报文。只有在总线空闲时,主机才可以开始传输。两个主机可以在 START 的最小保持时间内产生 START 条件这种情况会导致总线上出现有效的 START 条件。然后需要仲裁以确定哪个主机将完成其传输。

    仲裁是一位一位地进行。节点发送 1 个位后,回读比较总线上所呈现的数据与自己发送的是否一致。是,继续发送;否则,退出竞争。SDA 线的仲裁可以保证 I2C 总线系统在多个主节点同时企图控制总线时通信正常进行并且数据不丢失。总线系统通过仲裁只允许一个主节点可以继续占据总线

  • 上图显示了两个主机的仲裁程序。实际使用中连接到总线的主机数量可能会更多。当主机产生的 DATA1 的内部数据电平与 SDA 线上的实际电平之间存在差异时,DATA1 输出将关闭。从而主机 1 退出竞争,没有获得总线的控制权。

  • 时钟延长:时钟延长通过将 SCL 线保持为低电平来暂停事务。直到再次释放高电平,事务才能继续。时钟延长是可选的,实际上,大多数从设备不包括 SCL 驱动能力,因此它们无法延长时钟。

    为啥要设计这样一个机制呢?个人理解是为了增强系统的健壮性而设计的:

    • 在字节传输级别,设备可能能够以快速速率接收数据字节,但需要更多时间来存储接收到的字节或准备另一个要发送的字节。此时,从机可以在接收和确认字节后将 SCL 线保持为 LOW,以强制主机进入等待状态,直到从机为握手过程中的下一个字节传输做好准备。

    • 在位级别上,诸如微控制器之类的设备可以通过延长每个时钟的 LOW 周期来减慢总线时钟。任何主机的速度都将根据该设备的内部工作速率进行调整。

地址及 R/W 位:

地址及 R/W:

  • 7 位地址:分读写两种情况

  • 10 位地址:分读写两种情况

  • 保留地址

设备地址 读写位 描述
0000 000 0 广播地址
0000 000 1 启动字节
0000 001 X CBUS 地址
0000 010 X 预留给不同的总线格式
0000 011 X 预留未来扩展使用
0000 1XX 1 Hs-mode 主代码
1111 1XX 1 设备 ID
1111 0XX X 10 位从地址

通用广播地址

通用广播地址用于同时寻址连接到 I2C 总线的所有设备。但是,如果设备不需要处理广播数据,则可以通过不发出 ACK 来忽略该地址。如果某设备需要来自通用广播地址的数据,它将发送 ACK 给该地址并充当从接收器。主机实际上不知道有一个或多个设备响应时确认了广播数据(不确定有多少个 ACK)。每个能够处理此数据的从机接收器都会确认第二个字节和随后的字节。无法处理这些字节的从机将不应答从而忽略。同样,如果一个或多个从机应答,则主机不会看到未确认的消息。通用广播地址的含义总是在第二个字节中指定,如下图:

1.当 B 为 0 时,第 2 字节定义如下:

  • 0000 0110(06h):设备将复位以及设置地址的可编程部分。接收到这个 2 字节命令后,所有支持响应通用广播地址的设备将复位,并将其地址的可编程部分改写保存。 须采取预防措施以确保设备在施加电源电压后不会拉低 SDA 或 SCL 线,因为这些低电平会阻塞总线。
  • 0000 0100 (04h):收到该命令后设备将通过硬件设置地址的可编程部分。(Write programmable part of slave address by hardware).
  • 0000 0000 (00h): 不允许将此代码用作第二个字节.

对于 06h/04h 这两个命令,有些不太好理解。复位比较好理解。对于设置设备地址的可编程部分可能很多没有遇到过的朋友则不太好理解。这里来一个实际芯片的例子,以 Microchip 的 MCP3423/MCP3424 为例进行描述一下,MCP3423/MCP3424 是一颗多通道 ADC 芯片,其芯片引脚如下:

当接收到通用广播访问且第 2 字节为 06h 命令后,芯片做两件事情:

  • 芯片复位如上电复位的行为一样
  • 同时锁住 Adr1/Adr0 的电平作为地址,这两位地址为芯片地址的可编程部分。

当然对于不同的芯片,具体如何实现通用广播地址的处理则各有不同,只需要认真阅读芯片的手册就能获取相应信息。这里仅仅就通用广播地址举个栗子,方便理解。老实说这个功能好像不太常见,具体有什么用?我反正没这么用过,感觉这功能有点蛋疼(直接用电阻配置好不更省事?)。如果有好的应用实例场景,欢迎留言交流。

2.当 B 为“ 1”时,则该 2 字节序列为“硬件通用呼叫”。该报文由 I2C 主设备(例如键盘扫描器)发送,可以对其进行编程以发送所需的从地址。由于 I2C 主设备事先不知道该消息必须传输到哪个从设备,故利用通用广播地址及通用呼叫命令并将自身的地址放在高 7 位,从而标识总线上发送通用硬件呼叫的设备 ID。该地址由连接到总线的智能设备识别(比如该智能设备是一个单片机系统),然后该智能设备从硬件主机接收信息。如果硬件主机也可以充当从机,则从机地址与主机地址相同。

所以标准中定义这个功能,可以做些自适应应用,只需要制定出相应协议就可以完成比较灵活的多主通信应用协议。

软复位

如上面描述,当通用广播地址后面跟 06h 字节,就可以使从设备软复位。但这个功能并非所有芯片都支持,具体使用的时候需要仔细阅读芯片手册是否支持该功能。

须采取预防措施以确保设备在施加电源电压后不会拉低 SDA 或 SCL 线,因为这些低电平会阻塞总线。

起始 START 字节

单片机/DSP 可以用两种方法连接到 I2C 总线:

  • 有的单片机/DSP 具有片上 I2C 硬件外设,这就可以直接使用。
  • 如果没有或者被其他功能占用,则可以使用 GPIO 去模拟 I2C 总线时序。用这个方式去实现,则比较消耗 CPU 时间,

比如在一个多单片机用 I2C 总线连一起的系统,其中一个单片机 I2C 是用 IO 口模拟的,则快速的硬件设备与依赖软件轮询的相对较慢的单片机之间存在速度差异。这个不难想象,因为依靠轮询则不是硬实时,同时单片机肯定还有其他事物需要处理,那么检测 START 条件信号就有可能丢失,导致系统不健壮。那么 I2C 标准已然考虑这种需求了。

这就是起始字节需要解决的需求,前面介绍的就是起始字节设计的背景。那么起始字节究竟是怎样的呢?

  • START 事件(英文叫 condition,我这样叫成一个事件有一点软件原语抽象的意思)
  • START 字节 0000 0001
  • ACK
  • 重复 START 事件

在需要访问总线的主机发送了 START 事件之后,发送 START 字节(0000 0001)。另一个单片机/DSP 可以以低采样率对 SDA 线进行采样,直到检测到 START 字节中的七个零之一为止。在 SDA 线上检测到此 LOW 电平后,微控制器可以切换到更高的采样率,以找到重复的 START 事件,然后将其用于同步。

总线复位

在异常情况下,如果时钟 SCL 被拉为 LOW 了,则有哪些办法可以对总线复位呢?

  • 则优选的做法是如 I2C 设备具有硬件复位输入,则使用硬件复位信号来复位总线。
  • 如果 I2C 设备没有硬件复位输入信号,如果硬件设计可以考虑用 MOSFET 控制设备电源,重新通电以激活强制性的内部上电复位(POR)电路。
  • 还有一种做法是主机 发送 9 个时钟 SCL 脉冲。使总线保持低电平的设备应在这九个时钟内的某个时间释放它。这个具体怎么做呢? 主设备初始化 I2C 总线时,可以冗余加 9 个 SCL 脉冲以复位 I2C 总线,或者检测到 SCL 长时间被拉低后,可以以控制 IO 高低翻转的方式控制 SCL 产生 9 个脉冲
//可能需要先关闭I2C控制器,如果是使用I2C控制器外设实现的//I2C_SCL根据不同硬件进行移植,delay#define I2C_SCL P10void soft_rst_i2c(void){ I2C_SCL = 1; for(int i=0;i<9;i++) { I2C_SCL = 0; delay(xx); I2C_SCL = 1; delay(xx); }}

前面两种方法是更健壮的方案,如果硬件不支持,可以考虑后一种方法,但后一种方法的前提是拉死 SCL 的设备需要支持这种功能,如果两端都是自定义开发的则比较灵活了。

总线锁死,是 I2C 总线系统常踩的坑,有哪些原因会导致锁死呢?程序不健壮,I2C 的波形不满足 I2C 规格书要求,或者在外加干扰情况下导致波形被干扰。有经验的同学可能会遇到设备平时工作的好好的,但是做 EMC 测试,常常设备会莫名死机,如果你的设备有 I2C 总线,请记得检查 I2C 是否被 EMC 干扰干死了!

设备 ID

设备 ID 字段是一个可选的 3 字节只读(24 位)字,提供以下信息:

  • 12 位用于表示制造商名称,每个制造商唯一(例如,NXP)
  • 9 位由制造商分配的芯片标识(例如,PCA9698)
  • 3 位表示芯片版本,由制造商分配(例如 RevX)

这个对于设计软件有什么可以利用的信息呢?比如一个系统可兼容不同厂家的基于 I2C 协议的传感器,利用这个字段就可以做设备信息管理。至于怎么读取,不同芯片或有不同。

接口电路简介

前面拓扑图中采用 open-drain 开漏结构。I2C 有的还用集电极开路输出结构,究其原因是内部是三极管的集电极开路。如下

Ultra Fast-mode

在 Rev 4 中还出现了 Ultra Fast-mode,该模式使用 push–pull 推挽定义 I2C 内部硬件接口电路(我把它叫推拉),这个又长什么样呢?

这种推挽接口是用在 Ultra Fast-mode(UFm)模式,为啥不继续采用集电极开路门/漏极开路门呢?因为这两种硬件已然无法满足如此高速的通讯波形要求了,推挽输出可以实现更为快速波形前沿特性以驱动总线电容负载。

对于 Ultra Fast-mode 模式其他如时序波形,报文定义基本一致,这里不做赘述了。需要提醒的是设备 ID 在该模式下不支持!

容性负载

为什么要特别讨论一下总线的容性负载特征呢?想象中的理想通信波形:



由于容性负载以及充放电常数特性,实际中却可能是这个鸟样:


如果实际总线中电阻选取过大,或者容性负载过大(设备节点过大或者布线不合理),也即RC常数过大,甚至可能是这个德行:

那么参数选取合适时,波形则可能是这样的:



所以就其本质而言,就是由于驱动接口电路的RC参数影响了波形的时序参数:


实际应用中,一方面电阻需要选取足够大以降低不必要的电流消耗,另一方面电阻又需要选择足够小以满足对应传输速度的波形时序要求。故需要在这一对矛盾体中寻求一个折中平衡!实际项目中先用示波器测测I2C波形非常必要,代码对了总线可未必如愿工作。做底层开发,尽量先硬后软~~

I2C 总线标准从电气特性界定了容性负载特征:

  • Fast-mode:连接到总线的外部上拉设备必须经过调整,以适应快速模式 I2C 总线较短的最大允许上升时间。对于 200 pF 以内的等效总线负载,每条总线的上拉设备可以是一个电阻。对于 200 pF 至 400 pF 之间的总线负载,上拉设备可以是电流源(最大 3 mA)或开关电阻电路。

  • Fast-mode Plus (Fm+):该模式下设备中的驱动接口电路驱动能力比较强大,可以满足 Fast-mode Plus 时序规范,并具有与标准模式部件相同的 400 pF 负载。为了与标准模式向后兼容,它们还可以承受标准模式设备的 1μs 上升时间。在仅存在 Fast-mode Plus 部件的应用中,强驱动接口和对缓慢的上升和下降时间的容忍度允许使用较大的总线电容,只要软件设置好或硬件 IC 实现好,Fast-mode Plus 的最小 LOW 时间和最小 HIGH 时间即可满足所有要求,并且下降时间和上升时间不超过标准模式的 300ns 上升沿时间和 1μs 下降沿时间规格。可以将总线速度与负载电容进行折衷,总线电容可增加大约十倍。
  • Hs-mode: 高速模式(Hs-mode)器件在 I2C 总线传输速度方面实现了飞跃。高速模式设备可以实现高达 3.4Mbit/s 的比特率传输速度,但仍然向下兼容,与快速模式增强版、快速模式或标准模式(F/S)设备完全兼容以进行双向通信总线系统。除了在 Hs 模式传输期间不执行仲裁和时钟同步外,与 F/S 模式系统保持相同的串行总线协议和数据格式。那么如此高速是如何做到的呢?这里将个人认为与应用相关的要点翻译总结下:
    • Hs 模式主设备具有用于 SDAH 信号的 漏极开路输出缓冲器,以及 SCLH 输出上的漏极开路下拉电路和电流源上拉电路的组合。该电流源电路缩短了 SCLH 信号的上升时间。任何时候仅在 Hs 模式下,仅启用一个主机的电流源。
    • 在多主机系统的 Hs 模式传输期间,不执行仲裁以及时钟同步以提高位处理能力。仲裁过程始终在先前的 F/S 模式下的主代码传输之后完成。
    • Hs 模式主设备生成串行时钟信号,其 占空比为 50%以减轻建立和保持时间的时序要求。这个项目中可利用示波器检查波形。
  • 具体设计时,可参考规格书电气特性参数规定以及所选芯片的手册。

编程策略

  • 硬件 I2C 控制器:要实现 I2C 总线,如果使用单片机/DSP/SOC 内置了 I2C 控制器,就其本质就是抽象了 I2C 总线的各种事件以寄存器进行控制,最为常见的方式就是将总线事件抽象为异步中断事件。以 STM32 为例:

编程时,比较好的方式就是处理相应的中断事件。利用内置 I2C 控制器是优选方案。

  • IO 模拟,如果系统中不存在 I2C 控制器,可利用 IO 口进行模拟,对于实现多设备以及高速模式系统则不推荐这样做。但在一些 PCB 尺寸受限或者成本受限、单片机引脚很少的系统中还是比较有实用价值的。其编程只需要对照 I2C 时序进行操作即可,难度较小。

在实际项目中,需要特别注意 I2C 的上升沿、下降沿波形时间参数是否满足设计速率要求,可通过配置寄存器以及调整驱动上拉电阻进行调整。对于高速模式则可能需要用电流源进行驱动。另外需要注意的是,I2C 总线锁死情况处理。

总结一下

I2C 总线是一个比较复杂的芯片间总线系统,你或许会用。但是如果不注意标准的很多细节,你可能无法用好!尤其总线上挂很多设备时,系统极可能不健壮!本文主要参考 I2C version 标准,I2C 总线看似简单却极为复杂,本文总结了规格书中一些要点,也并不全面。在复杂应用场景中,还需要多多踩坑、填坑并加以总结。前文谈到了对于技术要点尽量总结、概括以及提炼,这里想提醒的是一些技术要点的标准往往是最为严谨、也最为全面的总结。具体使用时,可多多研读。

I2C VERSION6 规格书可至 www.i2c-bus.org 下载,也可以至公众号后台回复 I2C6,可直接领取。

本文辛苦原创分享,如果觉得有价值也请帮忙点赞/在看/转发支持,不胜感激!


END




推荐阅读



【01】一个C程序的源代码是如何运行在硬件上的?
【02】C语言宏定义的妙用!用完软硬件效率蹭蹭涨!
【03】做硬件,真的没前途吗?看看资深工程师是怎么说的
【04】嵌入式有什么值得学习的软硬件技术?
【05】嵌入式软件和硬件谁更重要?


免责声明:整理文章为传播相关技术,版权归原作者所有,如有侵权,请联系删除


嵌入式ARM 关注这个时代最火的嵌入式ARM,你想知道的都在这里。
评论
  • Ubuntu20.04默认情况下为root账号自动登录,本文介绍如何取消root账号自动登录,改为通过输入账号密码登录,使用触觉智能EVB3568鸿蒙开发板演示,搭载瑞芯微RK3568,四核A55处理器,主频2.0Ghz,1T算力NPU;支持OpenHarmony5.0及Linux、Android等操作系统,接口丰富,开发评估快人一步!添加新账号1、使用adduser命令来添加新用户,用户名以industio为例,系统会提示设置密码以及其他信息,您可以根据需要填写或跳过,命令如下:root@id
    Industio_触觉智能 2025-01-17 14:14 56浏览
  • 随着智慧科技的快速发展,智能显示器的生态圈应用变得越来越丰富多元,智能显示器不仅仅是传统的显示设备,透过结合人工智能(AI)和语音助理,它还可以成为家庭、办公室和商业环境中的核心互动接口。提供多元且个性化的服务,如智能家居控制、影音串流拨放、实时信息显示等,极大提升了使用体验。此外,智能家居系统的整合能力也不容小觑,透过智能装置之间的无缝连接,形成了强大的多元应用生态圈。企业也利用智能显示器进行会议展示和多方远程合作,大大提高效率和互动性。Smart Display Ecosystem示意图,作
    百佳泰测试实验室 2025-01-16 15:37 185浏览
  • 实用性高值得收藏!! (时源芯微)时源专注于EMC整改与服务,配备完整器件 TVS全称Transient Voltage Suppre,亦称TVS管、瞬态抑制二极管等,有单向和双向之分。单向TVS 一般应用于直流供电电路,双向TVS 应用于电压交变的电路。在直流电路的应用中,TVS被并联接入电路中。在电路处于正常运行状态时,TVS会保持截止状态,从而不对电路的正常工作产生任何影响。然而,一旦电路中出现异常的过电压,并且这个电压达到TVS的击穿阈值时,TVS的状态就会
    时源芯微 2025-01-16 14:23 171浏览
  • 百佳泰特为您整理2025年1月各大Logo的最新规格信息,本月有更新信息的logo有HDMI、Wi-Fi、Bluetooth、DisplayHDR、ClearMR、Intel EVO。HDMI®▶ 2025年1月6日,HDMI Forum, Inc. 宣布即将发布HDMI规范2.2版本。新规范将支持更高的分辨率和刷新率,并提供更多高质量选项。更快的96Gbps 带宽可满足数据密集型沉浸式和虚拟应用对传输的要求,如 AR/VR/MR、空间现实和光场显示,以及各种商业应用,如大型数字标牌、医疗成像和
    百佳泰测试实验室 2025-01-16 15:41 175浏览
  • 日前,商务部等部门办公厅印发《手机、平板、智能手表(手环)购新补贴实施方案》明确,个人消费者购买手机、平板、智能手表(手环)3类数码产品(单件销售价格不超过6000元),可享受购新补贴。每人每类可补贴1件,每件补贴比例为减去生产、流通环节及移动运营商所有优惠后最终销售价格的15%,每件最高不超过500元。目前,京东已经做好了承接手机、平板等数码产品国补优惠的落地准备工作,未来随着各省市关于手机、平板等品类的国补开启,京东将第一时间率先上线,满足消费者的换新升级需求。为保障国补的真实有效发放,基于
    华尔街科技眼 2025-01-17 10:44 164浏览
  •  光伏及击穿,都可视之为 复合的逆过程,但是,复合、光伏与击穿,不单是进程的方向相反,偏置状态也不一样,复合的工况,是正偏,光伏是零偏,击穿与漂移则是反偏,光伏的能源是外来的,而击穿消耗的是结区自身和电源的能量,漂移的载流子是 客席载流子,须借外延层才能引入,客席载流子 不受反偏PN结的空乏区阻碍,能漂不能漂,只取决于反偏PN结是否处于外延层的「射程」范围,而穿通的成因,则是因耗尽层的过度扩张,致使跟 端子、外延层或其他空乏区 碰触,当耗尽层融通,耐压 (反向阻断能力) 即告彻底丧失,
    MrCU204 2025-01-17 11:30 127浏览
  • 现在为止,我们已经完成了Purple Pi OH主板的串口调试和部分配件的连接,接下来,让我们趁热打铁,完成剩余配件的连接!注:配件连接前请断开主板所有供电,避免敏感电路损坏!1.1 耳机接口主板有一路OTMP 标准四节耳机座J6,具备进行音频输出及录音功能,接入耳机后声音将优先从耳机输出,如下图所示:1.21.2 相机接口MIPI CSI 接口如上图所示,支持OV5648 和OV8858 摄像头模组。接入摄像头模组后,使用系统相机软件打开相机拍照和录像,如下图所示:1.3 以太网接口主板有一路
    Industio_触觉智能 2025-01-20 11:04 74浏览
  • 晶台光耦KL817和KL3053在小家电产品(如微波炉等)辅助电源中的广泛应用。具备小功率、高性能、高度集成以及低待机功耗的特点,同时支持宽输入电压范围。▲光耦在实物应用中的产品图其一次侧集成了交流电压过零检测与信号输出功能,该功能产生的过零信号可用于精确控制继电器、可控硅等器件的过零开关动作,从而有效减小开关应力,显著提升器件的使用寿命。通过高度的集成化和先进的控制技术,该电源大幅减少了所需的外围器件数量,不仅降低了系统成本和体积,还进一步增强了整体的可靠性。▲电路示意图该电路的过零检测信号由
    晶台光耦 2025-01-16 10:12 102浏览
  • 电竞鼠标应用环境与客户需求电竞行业近年来发展迅速,「鼠标延迟」已成为决定游戏体验与比赛结果的关键因素。从技术角度来看,传统鼠标的延迟大约为20毫秒,入门级电竞鼠标通常为5毫秒,而高阶电竞鼠标的延迟可降低至仅2毫秒。这些差异看似微小,但在竞技激烈的游戏中,尤其在对反应和速度要求极高的场景中,每一毫秒的优化都可能带来致胜的优势。电竞比赛的普及促使玩家更加渴望降低鼠标延迟以提升竞技表现。他们希望通过精确的测试,了解不同操作系统与设定对延迟的具体影响,并寻求最佳配置方案来获得竞技优势。这样的需求推动市场
    百佳泰测试实验室 2025-01-16 15:45 263浏览
  • 一个易用且轻量化的UI可以大大提高用户的使用效率和满意度——通过快速启动、直观操作和及时反馈,帮助用户快速上手并高效完成任务;轻量化设计则可以减少资源占用,提升启动和运行速度,增强产品竞争力。LVGL(Light and Versatile Graphics Library)是一个免费开源的图形库,专为嵌入式系统设计。它以轻量级、高效和易于使用而著称,支持多种屏幕分辨率和硬件配置,并提供了丰富的GUI组件,能够帮助开发者轻松构建出美观且功能强大的用户界面。近期,飞凌嵌入式为基于NXP i.MX9
    飞凌嵌入式 2025-01-16 13:15 211浏览
  • 随着消费者对汽车驾乘体验的要求不断攀升,汽车照明系统作为确保道路安全、提升驾驶体验以及实现车辆与环境交互的重要组成,日益受到业界的高度重视。近日,2024 DVN(上海)国际汽车照明研讨会圆满落幕。作为照明与传感创新的全球领导者,艾迈斯欧司朗受邀参与主题演讲,并现场展示了其多项前沿技术。本届研讨会汇聚来自全球各地400余名汽车、照明、光源及Tier 2供应商的专业人士及专家共聚一堂。在研讨会第一环节中,艾迈斯欧司朗系统解决方案工程副总裁 Joachim Reill以深厚的专业素养,主持该环节多位
    艾迈斯欧司朗 2025-01-16 20:51 123浏览
  • 80,000人到访的国际大展上,艾迈斯欧司朗有哪些亮点?感未来,光无限。近日,在慕尼黑electronica 2024现场,ams OSRAM通过多款创新DEMO展示,以及数场前瞻洞察分享,全面展示自身融合传感器、发射器及集成电路技术,精准捕捉并呈现环境信息的卓越能力。同时,ams OSRAM通过展会期间与客户、用户等行业人士,以及媒体朋友的深度交流,向业界传达其以光电技术为笔、以创新为墨,书写智能未来的深度思考。electronica 2024electronica 2024构建了一个高度国际
    艾迈斯欧司朗 2025-01-16 20:45 160浏览
  • 近期,智能家居领域Matter标准的制定者,全球最具影响力的科技联盟之一,连接标准联盟(Connectivity Standards Alliance,简称CSA)“利好”频出,不仅为智能家居领域的设备制造商们提供了更为快速便捷的Matter认证流程,而且苹果、三星与谷歌等智能家居平台厂商都表示会接纳CSA的Matter认证体系,并计划将其整合至各自的“Works with”项目中。那么,在本轮“利好”背景下,智能家居的设备制造商们该如何捉住机会,“掘金”万亿市场呢?重认证快通道计划,为家居设备
    华普微HOPERF 2025-01-16 10:22 190浏览
  • 本文介绍瑞芯微开发板/主板Android配置APK默认开启性能模式方法,开启性能模式后,APK的CPU使用优先级会有所提高。触觉智能RK3562开发板演示,搭载4核A53处理器,主频高达2.0GHz;内置独立1Tops算力NPU,可应用于物联网网关、平板电脑、智能家居、教育电子、工业显示与控制等行业。源码修改修改源码根目录下文件device/rockchip/rk3562/package_performance.xml并添加以下内容,注意"+"号为添加内容,"com.tencent.mm"为AP
    Industio_触觉智能 2025-01-17 14:09 53浏览
我要评论
0
点击右上角,分享到朋友圈 我知道啦
请使用浏览器分享功能 我知道啦