首页 > 其他分享 >SMBus协议-3

SMBus协议-3

时间:2023-07-16 16:45:28浏览次数:40  
标签:协议 I2C 字节 发出 flag Functionality SMBus

参考资料:

  • Linux内核文档:Documentation\i2c\smbus-protocol.rst

  • SMBus协议:

  • SMBus_3_0_20141220.pdf

  • I2CTools: https://mirrors.edge.kernel.org/pub/software/utils/i2c-tools/

1. SMBus是I2C协议的一个子集

SMBus: System Management Bus,系统管理总线。 SMBus最初的目的是为智能电池、充电电池、其他微控制器之间的通信链路而定义的。 SMBus也被用来连接各种设备,包括电源相关设备,系统传感器,EEPROM通讯设备等等。 SMBus 为系统和电源管理这样的任务提供了一条控制总线,使用 SMBus 的系统,设备之间发送和接收消息都是通过 SMBus,而不是使用单独的控制线,这样可以节省设备的管脚数。 SMBus是基于I2C协议的,SMBus要求更严格,SMBus是I2C协议的子集。

 

SMBus有哪些更严格的要求?跟一般的I2C协议有哪些差别?

  • VDD的极限值不一样

    • I2C协议:范围很广,甚至讨论了高达12V的情况

    • SMBus:1.8V~5V

  • 最小时钟频率、最大的Clock Stretching

    • Clock Stretching含义:某个设备需要更多时间进行内部的处理时,它可以把SCL拉低占住I2C总线

    • I2C协议:时钟频率最小值无限制,Clock Stretching时长也没有限制

    • SMBus:时钟频率最小值是10KHz,Clock Stretching的最大时间值也有限制

  • 地址回应(Address Acknowledge)

    • 一个I2C设备接收到它的设备地址后,是否必须发出回应信号?

    • I2C协议:没有强制要求必须发出回应信号

    • SMBus:强制要求必须发出回应信号,这样对方才知道该设备的状态:busy,failed,或是被移除了

  • SMBus协议明确了数据的传输格式

    • I2C协议:它只定义了怎么传输数据,但是并没有定义数据的格式,这完全由设备来定义

    • SMBus:定义了几种数据格式(后面分析)

  • REPEATED START Condition(重复发出S信号)

    • 比如读EEPROM时,涉及2个操作:

      • 把存储地址发给设备

      • 读数据

    • 在写、读之间,可以不发出P信号,而是直接发出S信号:这个S信号就是REPEATED START

    • 如下图所示 

       

  • SMBus Low Power Version

    • SMBus也有低功耗的版本

 

2. SMBus协议分析

对于I2C协议,它只定义了怎么传输数据,但是并没有定义数据的格式,这完全由设备来定义。 对于SMBus协议,它定义了几种数据格式。

 

注意

  • 下面文档中的Functionality flag是Linux的某个I2C控制器驱动所支持的功能。

  • 比如Functionality flag: I2C_FUNC_SMBUS_QUICK,表示需要I2C控制器支持SMBus Quick Command

2.1 symbols(符号)

S     (1 bit) : Start bit(开始位)
Sr   (1 bit) : 重复的开始位
P     (1 bit) : Stop bit(停止位)
R/W# (1 bit) : Read/Write bit. Rd equals 1, Wr equals 0.(读写位)
A, N (1 bit) : Accept and reverse accept bit.(回应位)
Address(7 bits): I2C 7 bit address. Note that this can be expanded as usual to
               get a 10 bit I2C address.
              (地址位,7位地址)
Command Code (8 bits): Command byte, a data byte which often selects a register on
              the device.
              (命令字节,一般用来选择芯片内部的寄存器)
Data Byte (8 bits): A plain data byte. Sometimes, I write DataLow, DataHigh
               for 16 bit data.
              (数据字节,8位;如果是16位数据的话,用2个字节来表示:DataLow、DataHigh)
Count (8 bits): A data byte containing the length of a block operation.
(在block操作总,表示数据长度)
[..]:           Data sent by I2C device, as opposed to data sent by the host
              adapter.
              (中括号表示I2C设备发送的数据,没有中括号表示host adapter发送的数据)

 

2.2 SMBus Quick Command

 

只是用来发送一位数据:R/W#本意是用来表示读或写,但是在SMBus里可以用来表示其他含义。 比如某些开关设备,可以根据这一位来决定是打开还是关闭。

Functionality flag: I2C_FUNC_SMBUS_QUICK

 

2.3 SMBus Receive Byte

 

 

I2C-tools中的函数:i2c_smbus_read_byte()。 读取一个字节,Host adapter接收到一个字节后不需要发出回应信号(上图中N表示不回应)。

Functionality flag: I2C_FUNC_SMBUS_READ_BYTE

 

2.4 SMBus Send Byte

 

I2C-tools中的函数:i2c_smbus_write_byte()。 发送一个字节。

Functionality flag: I2C_FUNC_SMBUS_WRITE_BYTE

 

2.5 SMBus Read Byte

 

I2C-tools中的函数:i2c_smbus_read_byte_data()。

先发出Command Code(它一般表示芯片内部的寄存器地址),再读取一个字节的数据。 上面介绍的SMBus Receive Byte是不发送Comand,直接读取数据。

Functionality flag: I2C_FUNC_SMBUS_READ_BYTE_DATA

 

2.6 SMBus Read Word

 

I2C-tools中的函数:i2c_smbus_read_word_data()。

先发出Command Code(它一般表示芯片内部的寄存器地址),再读取2个字节的数据。

Functionality flag: I2C_FUNC_SMBUS_READ_WORD_DATA

 

2.7 SMBus Write Byte

 

I2C-tools中的函数:i2c_smbus_write_byte_data()。

先发出Command Code(它一般表示芯片内部的寄存器地址),再发出1个字节的数据。

Functionality flag: I2C_FUNC_SMBUS_WRITE_BYTE_DATA

 

2.8 SMBus Write Word

 

I2C-tools中的函数:i2c_smbus_write_word_data()。

先发出Command Code(它一般表示芯片内部的寄存器地址),再发出1个字节的数据。

Functionality flag: I2C_FUNC_SMBUS_WRITE_WORD_DATA

 

2.9 SMBus Block Read

 

I2C-tools中的函数:i2c_smbus_read_block_data()。

先发出Command Code(它一般表示芯片内部的寄存器地址),再发起度操作:

  • 先读到一个字节(Block Count),表示后续要读的字节数

  • 然后读取全部数据

Functionality flag: I2C_FUNC_SMBUS_READ_BLOCK_DATA

 

2.10 SMBus Block Write

 

I2C-tools中的函数:i2c_smbus_write_block_data()。

先发出Command Code(它一般表示芯片内部的寄存器地址),再发出1个字节的Byte Conut(表示后续要发出的数据字节数),最后发出全部数据。

Functionality flag: I2C_FUNC_SMBUS_WRITE_BLOCK_DATA

 

2.11 I2C Block Read

在一般的I2C协议中,也可以连续读出多个字节。 它跟SMBus Block Read的差别在于设备发出的第1个数据不是长度N,如下图所示:

 

I2C-tools中的函数:i2c_smbus_read_i2c_block_data()。

先发出Command Code(它一般表示芯片内部的寄存器地址),再发出1个字节的Byte Conut(表示后续要发出的数据字节数),最后发出全部数据。

Functionality flag: I2C_FUNC_SMBUS_READ_I2C_BLOCK

 

2.12 I2C Block Write

在一般的I2C协议中,也可以连续发出多个字节。 它跟SMBus Block Write的差别在于发出的第1个数据不是长度N,如下图所示:

 

I2C-tools中的函数:i2c_smbus_write_i2c_block_data()。

先发出Command Code(它一般表示芯片内部的寄存器地址),再发出1个字节的Byte Conut(表示后续要发出的数据字节数),最后发出全部数据。

Functionality flag: I2C_FUNC_SMBUS_WRITE_I2C_BLOCK

 

2.13 SMBus Block Write - Block Read Process Call

 

先写一块数据,再读一块数据。

Functionality flag: I2C_FUNC_SMBUS_BLOCK_PROC_CALL

 

2.14 Packet Error Checking (PEC)

PEC是一种错误校验码,如果使用PEC,那么在P信号之前,数据发送方要发送一个字节的PEC码(它是CRC-8码)。

SMBus Send Byte为例,下图中,一个未使用PEC,另一个使用PEC:

 

 

3. SMBus和I2C的建议

因为很多设备都实现了SMBus,而不是更宽泛的I2C协议,所以优先使用SMBus。 即使I2C控制器没有实现SMBus,软件方面也是可以使用I2C协议来模拟SMBus。 所以:Linux建议优先使用SMBus。

参考资料:

  • Linux内核文档:Documentation\i2c\smbus-protocol.rst

  • SMBus协议:

  • SMBus_3_0_20141220.pdf

  • I2CTools: https://mirrors.edge.kernel.org/pub/software/utils/i2c-tools/

1. SMBus是I2C协议的一个子集

SMBus: System Management Bus,系统管理总线。SMBus最初的目的是为智能电池、充电电池、其他微控制器之间的通信链路而定义的。SMBus也被用来连接各种设备,包括电源相关设备,系统传感器,EEPROM通讯设备等等。SMBus 为系统和电源管理这样的任务提供了一条控制总线,使用 SMBus 的系统,设备之间发送和接收消息都是通过 SMBus,而不是使用单独的控制线,这样可以节省设备的管脚数。SMBus是基于I2C协议的,SMBus要求更严格,SMBus是I2C协议的子集。

image-20210224093827621

SMBus有哪些更严格的要求?跟一般的I2C协议有哪些差别?

  • VDD的极限值不一样

    • I2C协议:范围很广,甚至讨论了高达12V的情况

    • SMBus:1.8V~5V

  • 最小时钟频率、最大的Clock Stretching

    • Clock Stretching含义:某个设备需要更多时间进行内部的处理时,它可以把SCL拉低占住I2C总线

    • I2C协议:时钟频率最小值无限制,Clock Stretching时长也没有限制

    • SMBus:时钟频率最小值是10KHz,Clock Stretching的最大时间值也有限制

  • 地址回应(Address Acknowledge)

    • 一个I2C设备接收到它的设备地址后,是否必须发出回应信号?

    • I2C协议:没有强制要求必须发出回应信号

    • SMBus:强制要求必须发出回应信号,这样对方才知道该设备的状态:busy,failed,或是被移除了

  • SMBus协议明确了数据的传输格式

    • I2C协议:它只定义了怎么传输数据,但是并没有定义数据的格式,这完全由设备来定义

    • SMBus:定义了几种数据格式(后面分析)

  • REPEATED START Condition(重复发出S信号)

    • 比如读EEPROM时,涉及2个操作:

      • 把存储地址发给设备

      • 读数据

    • 在写、读之间,可以不发出P信号,而是直接发出S信号:这个S信号就是REPEATED START

    • 如下图所示image-20210224100056055

  • SMBus Low Power Version

    • SMBus也有低功耗的版本

 

2. SMBus协议分析

对于I2C协议,它只定义了怎么传输数据,但是并没有定义数据的格式,这完全由设备来定义。对于SMBus协议,它定义了几种数据格式。

 

注意

  • 下面文档中的Functionality flag是Linux的某个I2C控制器驱动所支持的功能。

  • 比如Functionality flag: I2C_FUNC_SMBUS_QUICK,表示需要I2C控制器支持SMBus Quick Command

2.1 symbols(符号)

S     (1 bit) : Start bit(开始位)
Sr   (1 bit) : 重复的开始位
P     (1 bit) : Stop bit(停止位)
R/W# (1 bit) : Read/Write bit. Rd equals 1, Wr equals 0.(读写位)
A, N (1 bit) : Accept and reverse accept bit.(回应位)
Address(7 bits): I2C 7 bit address. Note that this can be expanded as usual to
               get a 10 bit I2C address.
              (地址位,7位地址)
Command Code (8 bits): Command byte, a data byte which often selects a register on
              the device.
              (命令字节,一般用来选择芯片内部的寄存器)
Data Byte (8 bits): A plain data byte. Sometimes, I write DataLow, DataHigh
               for 16 bit data.
              (数据字节,8位;如果是16位数据的话,用2个字节来表示:DataLow、DataHigh)
Count (8 bits): A data byte containing the length of a block operation.
(在block操作总,表示数据长度)
[..]:           Data sent by I2C device, as opposed to data sent by the host
              adapter.
              (中括号表示I2C设备发送的数据,没有中括号表示host adapter发送的数据)

 

2.2 SMBus Quick Command

image-20210224105224903

只是用来发送一位数据:R/W#本意是用来表示读或写,但是在SMBus里可以用来表示其他含义。比如某些开关设备,可以根据这一位来决定是打开还是关闭。

Functionality flag: I2C_FUNC_SMBUS_QUICK

 

2.3 SMBus Receive Byte

image-20210224113511225

I2C-tools中的函数:i2c_smbus_read_byte()。读取一个字节,Host adapter接收到一个字节后不需要发出回应信号(上图中N表示不回应)。

Functionality flag: I2C_FUNC_SMBUS_READ_BYTE

 

2.4 SMBus Send Byte

image-20210224110638143

I2C-tools中的函数:i2c_smbus_write_byte()。发送一个字节。

Functionality flag: I2C_FUNC_SMBUS_WRITE_BYTE

 

2.5 SMBus Read Byte

image-20210224110812872

I2C-tools中的函数:i2c_smbus_read_byte_data()。

先发出Command Code(它一般表示芯片内部的寄存器地址),再读取一个字节的数据。上面介绍的SMBus Receive Byte是不发送Comand,直接读取数据。

Functionality flag: I2C_FUNC_SMBUS_READ_BYTE_DATA

 

2.6 SMBus Read Word

image-20210224111404096

I2C-tools中的函数:i2c_smbus_read_word_data()。

先发出Command Code(它一般表示芯片内部的寄存器地址),再读取2个字节的数据。

Functionality flag: I2C_FUNC_SMBUS_READ_WORD_DATA

 

2.7 SMBus Write Byte

image-20210224111542576

I2C-tools中的函数:i2c_smbus_write_byte_data()。

先发出Command Code(它一般表示芯片内部的寄存器地址),再发出1个字节的数据。

Functionality flag: I2C_FUNC_SMBUS_WRITE_BYTE_DATA

 

2.8 SMBus Write Word

image-20210224111840257

I2C-tools中的函数:i2c_smbus_write_word_data()。

先发出Command Code(它一般表示芯片内部的寄存器地址),再发出1个字节的数据。

Functionality flag: I2C_FUNC_SMBUS_WRITE_WORD_DATA

 

2.9 SMBus Block Read

image-20210224112524185

I2C-tools中的函数:i2c_smbus_read_block_data()。

先发出Command Code(它一般表示芯片内部的寄存器地址),再发起度操作:

  • 先读到一个字节(Block Count),表示后续要读的字节数

  • 然后读取全部数据

Functionality flag: I2C_FUNC_SMBUS_READ_BLOCK_DATA

 

2.10 SMBus Block Write

image-20210224112629201

I2C-tools中的函数:i2c_smbus_write_block_data()。

先发出Command Code(它一般表示芯片内部的寄存器地址),再发出1个字节的Byte Conut(表示后续要发出的数据字节数),最后发出全部数据。

Functionality flag: I2C_FUNC_SMBUS_WRITE_BLOCK_DATA

 

2.11 I2C Block Read

在一般的I2C协议中,也可以连续读出多个字节。它跟SMBus Block Read的差别在于设备发出的第1个数据不是长度N,如下图所示:

image-20210225094024082

I2C-tools中的函数:i2c_smbus_read_i2c_block_data()。

先发出Command Code(它一般表示芯片内部的寄存器地址),再发出1个字节的Byte Conut(表示后续要发出的数据字节数),最后发出全部数据。

Functionality flag: I2C_FUNC_SMBUS_READ_I2C_BLOCK

 

2.12 I2C Block Write

在一般的I2C协议中,也可以连续发出多个字节。它跟SMBus Block Write的差别在于发出的第1个数据不是长度N,如下图所示:

image-20210225094359443

I2C-tools中的函数:i2c_smbus_write_i2c_block_data()。

先发出Command Code(它一般表示芯片内部的寄存器地址),再发出1个字节的Byte Conut(表示后续要发出的数据字节数),最后发出全部数据。

Functionality flag: I2C_FUNC_SMBUS_WRITE_I2C_BLOCK

 

2.13 SMBus Block Write - Block Read Process Call

image-20210224112940865先写一块数据,再读一块数据。

Functionality flag: I2C_FUNC_SMBUS_BLOCK_PROC_CALL

 

2.14 Packet Error Checking (PEC)

PEC是一种错误校验码,如果使用PEC,那么在P信号之前,数据发送方要发送一个字节的PEC码(它是CRC-8码)。

SMBus Send Byte为例,下图中,一个未使用PEC,另一个使用PEC:

image-20210224113416249

 

3. SMBus和I2C的建议

因为很多设备都实现了SMBus,而不是更宽泛的I2C协议,所以优先使用SMBus。即使I2C控制器没有实现SMBus,软件方面也是可以使用I2C协议来模拟SMBus。所以:Linux建议优先使用SMBus。

标签:协议,I2C,字节,发出,flag,Functionality,SMBus
From: https://www.cnblogs.com/liusiluandzhangkun/p/17558066.html

相关文章

  • 传输层协议
    传输层协议1,什么是传输层传输层是整个网络体系结构中的关键层次之一,主要负责向两个主机中进程之间的通信提供服务。由于一个主机同时运行多个进程,因此运输层具有复用和分用功能。传输层在终端用户之间提供透明的数据传输,向上层提供可靠的数据传输服务。传输层在给定的链路上通过......
  • IIC协议 -2
    1.硬件连接I2C在硬件上的接法如下所示,主控芯片引出两条线SCL,SDA线,在一条I2C总线上可以接很多I2C设备,我们还会放一个上拉电阻,用来提高驱动能力,如果没有上拉电阻,可能会造成输出电压不够 2.传输数据类比怎么通过I2C传输数据,我们需要把数据从主设备发送到从设备上去,也需要把......
  • 【网络】【TCP】TCP 协议有什么缺陷?
    1  前言这节我们来看个问题,就是 TCP协议有什么缺陷?TCP通过序列号、确认应答、超时重传、流量控制、拥塞控制等方式实现了可靠传输,看起来它很完美,事实真的是这样吗?TCP就没什么缺陷吗?所以,今天就跟大家聊聊,TCP协议有哪些缺陷?主要有四个方面:升级TCP的工作很困难;TCP建......
  • 【网络】【TCP】如何基于 UDP 协议实现可靠传输?
    1  前言这节我们来看个问题,就是 TCP协议有什么缺陷?很多同学第一反应就会说把TCP可靠传输的特性(序列号、确认应答、超时重传、流量控制、拥塞控制)在应用层实现一遍。实现的思路确实这样没错,但是有没有想过,既然TCP天然支持可靠传输,为什么还需要基于UDP实现可靠传输呢?这......
  • 智能门锁的无线通讯协议有哪些?它的主要特点和工作原理是什么?
    智能门锁的无线通讯协议主要有蓝牙、ZigBee和Wi-Fi等。主要特点如下:蓝牙:是一种支持短距离无线通信的协议,具有低功耗、低成本的特点,适用于移动设备之间的数据传输和连接。Wi-Fi:是一种基于无线局域网的无线通信协议,可以快速传输数据,并支持互联网连接。ZigBee:是一种低功耗、低成本的无......
  • docker 检查SQL Server实例的TCP/IP协议是否已启用
    检查SQLServer实例的TCP/IP协议是否已启用作为一名经验丰富的开发者,我将帮助你学习如何检查SQLServer实例的TCP/IP协议是否已启用。以下是整个流程以及每一步需要做的事情。流程步骤描述1连接到SQLServer实例2查询是否已启用TCP/IP协议3根据查询结果判断TC......
  • 【HarmonyOS】元服务隐私协议开发指导样例
    【关键字】隐私、弹窗、元服务、协议 【介绍】每个元服务必须提供隐私声明,否则将导致提交元服务发布上架时,审核无法通过。隐私声明的具体要求请参见隐私声明规范。用户使用元服务前,必须引导其了解隐私声明信息,获取用户授权后,才能继续使用元服务。废话不多说,上代码!! 【方式......
  • HTTP协议违背
    HTTP协议违背2.1请求URI过长告警信息:therequestedURL'slengthexceedsthecapacitylimit描述:HTTP请求URI长度超过默认缓冲区大小,认为其不合规2.2 请求头部过长告警信息:requestexceedssystem'slimit描述:HTTP请求头部长度超过默认的缓冲区大小,认为其不合规2.3 ......
  • 从需求去理解 Linux dbus与基于dbus协议的无agent软件管理
    从需求去理解Linuxdbus与基于dbus协议的无agent软件管理 转载 WhatisIPCIPC[Inter-ProcessCommunication] 进程间通信,指至少两个进程或线程间传送数据或信号的一些技术或方法。在Linux/Unix中,提供了许多IPC。Unix七大IPC:Pipe:无名管道,最基本的IPC,单向通信,仅在......
  • TCP协议的首部结构?
     源端口:占2字节。目的端口:占2字节。序号:占4字节。序号范围是[0,2^23-1],共2^23个序号。当序号达到2^23-1时候,下一个序号就回到0。TCP是面向字节流的,在一个TCP连接中传送的字节流的每一个字节都按顺序编号。整个TCP的起始序号必须在建立时确认,首部中的序号字段指的是这个报文段所......