现在的位置: 首页 > 综合 > 正文

我所知道的EC====>SMBUS

2014年02月27日 ⁄ 综合 ⁄ 共 2390字 ⁄ 字号 评论关闭

 

我所知道的EC====>SMBUS

 

1. Introduction

        

      Smubs 全称为System management bus即系统管理总线,由Intel1995年制定,是基于Philips I2C发展而来。它通过两线式接口将各种芯片连接在一起并能够互相通信,传递各种信息。Smbus不仅节省了设备的pin脚,而且更重要的是它为系统提供了更大的扩展性和更加详细的芯片知识,为系统实现更加精细的控制提供了可能。它的时钟频率在10k~100kHz

 

2. Where to use?

       

       Smbus的初衷主要是应用于PC系统中的低速率信息通讯,当然现在在embed system中也有使用。PC系统中memory spd信息,clockgen的配置等等都需要使用smbus完成。在MB中它主要用于采集电源管理相关的信息,不过相对于MB,它更加适合NB,因为NB上面有非常多的chip都是基于smbus的,而且NB的电源管理较MB也更为复杂,特别是在引入了ACPI以后,定制BatteryThermal等的policy都需要用到smbus。在EC端,smbus主要用于这样几个地方:1.battery info 2.cpu/vga thermal info3.使用smbus debug card调试BIOSEC 4.touch sensor触控按键等。

 

3. How to use?

Ø      slave address

smbus device作为一个slave device挂在smubs总线上,为了能够识别该device,它必须有一个唯一的标识7 bit slave address。设备生产商必须向SMBus Working Group申请专用的地址。下表1中的地址是保留的地址不能分配给设备。

 

1

 

为防止系统中多个设备使用同一个地址造成地址冲突,smbus device必须提供某种机制解决地址冲突(如使用片选等)。目前我们家EC使用到的设备地址有battery0x98thermal0x16debug Card0x80touch sensor0x58(上述地址bit008bits)。

Ø      using smbus device

我们使用从slave device获取信息的方法是通过按照protocol发命令给slave device。一个slave device通常会有一堆命令,这些命令都是一个字节,对应slave device register,命令的参数和返回值长度并不固定,然后slave device收到命令后会将信息通过smbus出来。Smbus是两线式的总线,clock & dataclock是同步信号。一切行动都要听clock的指挥否则就天下大乱了。开始通信和结束通信的时序如下1所示:

                  

1

Clock 保持high datahighlow的跳变表示开始,clock保持High datalowhigh的跳变表示结束。一旦通信开始Data只有在clock保持high时才会有效,如果data想要变化也必须在clock low的时候进行,一招一式都得按规矩来。如下图2所示:

                  

 

2

 

 

Ø      bus protocols

要想使用slave device 要按照protocolcommandsmbus spec制定了11protocolslave device可以使用其中的任意的一条或多条。这11条分别为Quick Command, Send Byte, Receive Byte, Write Byte, Write Word, Read Byte, Read Word, Process Call,Block Read, Block Write and Block Write-Block Read Process CallSmbus spec给出了全部protocol的详细时序,我将结合用示波器抓到的波形讲述其中的几条protocol

·        Read Byte

下图3描述的是smbus spec中关于Read Byte Protocol说明,我用示波器抓了cpu thermal sensor一次读取过程读到的温度为0x64,如图4所示:

 

 

3

 

4

我们对着protocol数数看,图4先是一个start信号然后发了一个0x98slave address,然后回了一个slave device 回了0,接着master发了个0x01commandslave回了0,然后又是一个start信号然后master送了一个0x99bit0Rd,接着就是cpu的温度0x64,最后master回了个1,通信结束。注意看上图红色圈圈部分,那里datahigh可是clocklow,所以是一个无效数据。

·        Write Byte

下图5描述的是smbus spec中关于Write Byte Protocol说明,下图6是我用示波器抓的向smbus debug card写一个0x02的过程,slave device address0x80command0x55data0x02。试着分析结果是不是这样?J

 

 

5

 

                                              

6

·        Write Word

下图7描述的是smbus spec中关于Write Word Protocol明,下图8是我用示波器抓的读取battery temp的过程。slave device address0x16command0x08data=0xc90b。试着分析结果是不是这样?J

 

7

 

       图  8

 Reff:

          smbus 2.0 spec

 

That’s all!

 

Peter

 

抱歉!评论已关闭.