I2C驱动(二) -- SMBus协议

相关文章

I2C驱动(一) – I2C协议
I2C驱动(二) – SMBus协议
I2C驱动(三) – 驱动中的几个重要结构
I2C驱动(四) – I2C-Tools介绍
I2C驱动(五) – 通用驱动i2c-dev.c分析
I2C驱动(六) – I2C驱动程序模型
I2C驱动(七) – 编写I2C设备驱动之i2c_driver
I2C驱动(八) – 编写I2C设备驱动之i2c_client
I2C驱动(九) – i2c_adapter控制器驱动框架编写
I2C驱动(十) – i2c_adapter控制器驱动完善与上机实验
I2C驱动(十一) – gpio模拟的i2c总线驱动i2c-gpio.c分析
I2C驱动(十二) – 主控芯片的i2c_adapter驱动分析

参考资料

一. SMBus协议和I2C协议区别

1.1 SMBus协议简介

SMBus:System Management Bus, 系统管理总线。SMBus最初的目的是用来管理智能电池、充电电池、以及其它微控制器之间的通信。SMBus也被用来连接各种设备,如电源相关设备,系统传感器等。SMBus 为系统和电源管理这样的任务提供了一条控制总线,使用 SMBus 的系统,设备之间发送和接收消息都是通过 SMBus,而不是使用单独的控制线,这样可以节省设备的管脚数。

1.2 SMBus协议和I2C协议的区别

SMBus是基于I2C协议的,SMBus要求更严格,SMBus是I2C协议的子集。
在这里插入图片描述
SMBus协议和I2C协议的区别:
(1)VDD的极限值不一样

  • I2C协议:范围很广,甚至讨论了高达12V的情况。
  • SMBus: 范围在1.8V- 5V。

(2)最小时钟频率和最大Clock Stretching不一样

  • Clock Stretching含义:某个设备需要更多时间进行内部的处理时,它可以把SCL拉低占住I2C总线。
  • I2C协议:时钟频率最小值无限制,Clock Stretching时长也没有限制。
  • SMBus:时钟频率最小值是10KHz,Clock Stretching的最大时间值也有限制。

(3)地址回应区别

  • 一个I2C设备接收到它的设备地址后,是否必须发出回应信号?
  • I2C协议:没有强制要求必须发出回应信号。
  • SMBus:强制要求必须发出回应信号,这样对方才知道该设备的状态:busy,failed,或是被移除了。

(4)SMBus协议明确规定数据传输格式

  • I2C协议:它只定义了怎么传输数据,但是并没有定义数据的格式,这完全由设备来定义。
  • SMBus:定义了几种数据格式(后面分析)。

(5)SMBus协议可重复发出S信号(REPEATED START Condition)

  • 比如读EEPROM时,涉及2个操作:
    • 把存储地址发给设备
    • 读数据
  • 在写、读之间,可以不发出P信号,而是直接发出S信号:这个S信号就是
    REPEATED START
    在这里插入图片描述

二、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 Code,直接读取数据。

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-tools中的函数:i2c_smbus_read_i2c_block_data()
在一般的I2C协议中,也可以连续读出多个字节。
它跟SMBus Block Read的差别在于设备发出的第1个数据不是长度N,先发出Command Code(它一般表示芯片内部的寄存器地址),再发出1个字节的Byte Conut(表示后续要发出的数据字节数),最后发出全部数据。

Functionality flag: I2C_FUNC_SMBUS_READ_I2C_BLOCK

2.12 I2C Block Write

在这里插入图片描述
I2C-tools中的函数:i2c_smbus_write_i2c_block_data()
在一般的I2C协议中,也可以连续发出多个字节。
它跟SMBus Block Write的差别在于发出的第1个数据不是长度N,先发出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,而不是更宽泛的I2C协议,所以优先使用SMBus。即使I2C控制器没有实现SMBus,软件方面也是可以使用I2C协议来模拟SMBus。所以:Linux建议优先使用SMBus

03-11
<think>嗯,用户想了解SMBus协议的介绍和应用。首先我需要回顾一下自己知道的关于SMBus的知识,然后结合提供的引用资料来组织回答。根据用户给的三个引用,里面提到了SMBusI2C的区别、应用场景、协议内容、接口信号等。 首先,我应该先介绍SMBus是什么,可能从基本定义开始。然后比较SMBusI2C的不同之处,因为引用1和3都提到了这点。比如,SMBusI2C的子集,但可能有更严格的电压和时序要求,还有特定的功能如超时和警报机制。接着要讲应用场景,引用1提到系统管理任务,比如温度监控、电池管理等,这部分需要具体例子。 然后,协议内容部分,引用2和3提到了帧格式、信号映射。需要详细说明SMBus的物理层和协议层,比如数据帧结构,包括起始条件、地址、读写位、命令码、数据等。还要提到可选信号如SMBSUS#和SMBALERT#,以及它们的用途。 应用实例部分,可以举电池管理、温度传感器、电源控制等,说明SMBus在这些设备中的具体作用。最后,对比I2CSMBus的异同,帮助用户理解选择哪种协议。 同时,用户要求生成相关问题,可能需要包括协议细节、应用案例、与I2C的对比、开发中的注意事项等。确保问题覆盖用户可能感兴趣的方面,比如协议优化、常见问题处理等。 需要注意的是,回答要符合用户给定的格式,行内公式用$...$,独立公式用$$...$$,但在这个问题中可能数学公式不多,但如果有涉及频率或时序的计算,可能需要用到。例如,时钟频率是固定的,比如SMBus的时钟频率范围,可以用行内公式表示。 还要检查引用是否正确,每个引用标记对应到用户提供的三个引用资料。例如,提到SMBusI2C的区别时引用[^1][^3],应用场景引用[^1][^2]等。 最后,确保回答结构清晰,分点说明,使用中文,避免使用Markdown格式,代码块用指定的方式呈现。如果有Python代码示例的话需要添加,但用户的问题是关于协议介绍,可能代码示例较少,但如果有相关命令或寄存器配置的例子,可以适当加入。</think>### SMBus协议介绍及应用 #### 1. 基本定义 SMBus(System Management Bus)是专为系统管理任务设计的同步串行通信协议,主要用于低带宽设备(如传感器、电池、电源控制器)之间的通信。其物理层基于I2C协议,但增加了更严格的时序规范和功能扩展[^3]。 #### 2. 协议特性 - **帧格式**: 典型数据帧包含以下字段: $$ \text{起始位} + \text{7位设备地址} + \text{读写位} + \text{8位命令码} + \text{数据域} + \text{停止位} $$ - **信号映射**: 接口信号包括`SMBDAT`(数据线)、`SMBCLK`(时钟线),可选信号`SMBSUS#`(挂起)和`SMBALERT#`(警报)。 - **超时机制**: 强制要求时钟频率范围$10\,\text{kHz} \leq f_{\text{CLK}} \leq 100\,\text{kHz}$,且单次传输最长持续时间为$35\,\text{ms}$。 #### 3. 核心应用场景 1. **电池管理**:读取电池电量、温度及状态(如充放电模式)。 2. **传感器监控**:采集温度传感器(如LM75)、风扇转速等数据。 3. **电源控制**:配置电压调节模块(VRM)的输出参数。 #### 4. 与I2C协议对比 | 特性 | SMBus | I2C | |-----------------|-----------------------|------------------| | 时钟频率 | 固定范围 | 更宽泛 | | 超时检测 | 强制要求 | 无 | | 数据包校验 | 必须使用PEC(可选) | 无 | | 电气特性 | 严格电压阈值 | 相对宽松 | #### 5. 典型开发流程 ```python # 示例:使用Linux SMBus库读取温度传感器数据 import smbus bus = smbus.SMBus(1) # 选择I2C总线1 address = 0x48 # 传感器设备地址 data = bus.read_byte_data(address, 0) # 读取寄存器0的值 print(f"当前温度: {data}°C") ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值