博文是为了总结自己在bios学习上面的点点滴滴,并且加深印象,由于本人水平有限,难免存在不足之处,望指正,同时感谢CSDN提供的平台。本文主要介绍的是SMBUS。

1  SMBUS的简介

特点:

SMBUS,System Management BUS,即系统管理总线,1995年,由Intel公司提出,应用于移动PC和桌面PC系统的低速率通讯。通过一条廉价而又功能强大的总线

(由两条线组成),来控制主板上的设备以及收集相应的信息。
                       SMBUS有两条信号线,分别为SMBCLK与SMBDAT,即一条时钟线一条数据线,并且这两条信号线都是双向的,当总线空闲时,这两条信号线都是高电平。

SMBUS总线规范是基于I2C的总线规范。但与I2C总线规范也有一定的区别。
                       SMBUS与I2C总线之间在时序特性上存在一些差别。首先,SMBUS需要一定数据保持时间,而 I2C总线则是从内部延长数据保持时间。SMBUS具有超时功能,

因此当SCL太低而超过35 ms时,从器件将复位正在进行的通信。相反,I2C采用硬件复位。SMBUS具有一种警报响应地址(ARA),因此当从器件产生一个中断时,它不会

马上清除中断,而是一直保持到其收到一个由主器件发送的含有其地址的ARA为止。SMBUS工作频率从10kHz到最高100kHz。最低工作频率10kHz是由SMBUS超时功能

决定的。

应用:

SMBUS最初的目的是为智能电池,充电电池和其他与系统进行通信的微控制器之间的通信链路而定义的。SMBUS也被用来连接各种设备,包括电源相关设备,系统传感器

,EEPROM通讯设备等等。
       SMBUS最适用于笔记本电脑上,检测各元件状态并更新硬件设置引脚 (pull-high 或 pull-low)。例如,将不存在的 DIMM 时钟关闭,或检测电池低电压状态。 SMBUS 的

数据传输率只有 100Kbit/s;这允许单一主机与 CPU 和多个主从硬盘通讯并收发数据。SMBUS 也可用于免跳线设计的主板上。

下图为SMBUS的拓扑结构,其总线上所挂的设备都是通过线与逻辑连接到SMBUS上面。

时序分析:

SMBUS的起始和停止条件:

如时序图所示,当CLK为高电平时,DAT从高电平转换为低电平,表示数据传输信号的开始;当CLK为高电平,DAT从低电平转换为高电平则表示数据传输的结束。

SMBUS的数据传输条件

当数据传输时,CLK信号线表示高电平时,DAT必须保持稳定,不可以进行高低电平切换,只有当CLK信号处于低电平的时候,才可以进行高低电平的转换。

SMBUS的数据传输每一个字节为8位,传输结束之后需要跟一个相应信号为:ACK。即每次传输的数据为九位,第一个发送的数据位为最高位。SMBUS每次传输的字节数量不受限制。

2 :SMBUS的访问过程

在DATASHEET中,给出的SMBUS的byte的读方式如下:

但一般,在BIOS当中,一般会配置部分参数,也就是说,并不是所有的在函数中都需要配置,根据不同的bios可能会有所不同,在我所试验的bios版本中,已经配置了很多参数,所以只需要配置必须的参数即可,总结如下:

read byte:

1:写入slave+1,写入地址为base address+0x04 ,bit 0 置一表示读操作

2:选择需要的寄存器,设置其偏移量,地址为base address+0x03

3:写入操作方式0x48,写入地址为base address+0x02

4:读出数据,读数据的地址为base address +0x05

read Word:

1:写入slave+1,写入地址为base address+0x04,bit 0 置一表示读操作

2:选择需要的寄存器,设置其偏移量,地址为base address+0x03

3:写入操作方式0x4C,写入地址为base address+0x02

4:读出数据,读数据的地址为base address +0x05,base address +0x06

write byte:

1:写入slave,写入地址为base address+0x04,bit 0 置零表示写操作

2:选择需要的寄存器,设置其偏移量,地址为base address+0x03

3:写入需要的数据:一个byte,写数据的地址为base address +0x05

4:设置byte的工作方式0x48,写入地址为base address +0x02

write Word:

1:写入slave,写入地址为base address+0x04,bit 0 置零表示写操作

2:选择需要的寄存器,设置其偏移量,地址为base address+0x03

3:写入需要的数据:一个word,写数据的地址为base address +0x05,base address +0x06

4:设置word的工作方式0x4C,写入地址为base address +0x02

下面show一下intel给出的Datasheet中关于block的读写方式的说明:

同样的,对一些必须的步骤进行总结:

read  block:

1:写入slave+1,写入地址为base address+0x04,bit 0 置一表示读操作

2:选择需要的寄存器,设置其偏移量,地址为base address+0x03

3:写入block的工作方式0x54,写入地址为base address + 0x02

4:读出count地址为 base address + 0x05,读出数据,地址为 base address + 0x07

5:清标志位,写0x80到base address + 0x00,执行前一步,如此反复,直到读出count个byte

Datasheet中也给出了写block的内容:

总结如下:

write block:

1:写入slave+1,写入地址为base address+0x04,bit 0 置一表示写操作

2:选择需要的寄存器,设置其偏移量,地址为base address+0x03

3:写入count地址为 base address + 0x05,写入数据,地址为 base address + 0x07

4:设置block工作方式0x54,地址为base address + 0x02

5:清标志位,写0x80到base address + 0x00,执行第三步,再跳到此步,直到写入count个byte。

上面说了很多,其实主要的设置就是两点,一个是command,一个数据寄存器,其他都是大同小异,通过这些配置,实现不同的读写方式:

而我们在这些东西里面修改的主要还是寄存器,寄存器是如何工作的?在Datasheet中也有说明,下面介绍部分常用的寄存器:

1:基址寄存器

对SMBUS进行访问需要知道他的基地址,其基地址可以通过PCI的访问方式,访问位置为bus=0,device=31,function=3,offset:20-23H的[15:5]。

bit 0,表示smbus是否空闲,bit 1,表示操作是否终止,bit 6:当前smbus是否可用,往这个位写1表示清除该位。bit 7:表示已经执行结束一个byte的读写.

bit 6:用来控制操作开始,[4:2]:表示对读写方式的选择:此次会用到的三种方式分别为:010=byte,011=word,101=block

对需要操作的寄存器进行操作,在这个寄存器内设置所操作寄存器的偏移量。

[7:1]选择slave,bit 0去决定读写操作,0表示写,1表示读。

这个寄存器有两种功能,一个是在byte/word的方式下,作为需要写/读的数据寄存器,另一种则是在block的方式下,用来存放需要读写的数据个数,其范围为不能为0,也不能超过32,否则会产生不可预知的动作。

这个寄存器是在word的方式下用来存放数据,(DATA 0存放高八位),用来存放低八位的数据。

这个寄存器是在block方式用来存放数据的

在RU下读一个byte示例:

程序示例,读一个byte:

这篇博文对smbus的访问介绍的十分详细,在这个博文里,使用的是smbus对spd信息进行访问的,需要注意的是,spd信息的写需要注意,因为信息很重要,数据写错易导致内存烧掉,需要谨慎。

Thanks for your reading.

SMBUS的介绍与访问相关推荐

  1. ATTCK v10版本战术介绍-初始访问

    一.引言 在前几期文章中我们介绍了ATT&CK中侦察及资源开发战术理论知识及实战研究,通过实战场景验证行之有效的检测规则.防御措施,本期我们为大家介绍ATT&CK 14项战术中初始访问 ...

  2. 系统管理总线(SMBus)介绍

    SMBus介绍 系统管理总线协议概要 系统管理总线 关键标记表 SMBus接口函数 1. SMBus Quick Command 2. SMBus接收字节函数:i2c_smbus_read_byte( ...

  3. kubesphere devops介绍、访问账密及nfs数据备份同步

    nfs多节点数据备份:将nfs server节点的数据mount到nfs客户端

  4. 10.20-smbus

    10.20 任务目标 // 进度: SMBus/I2C:编写dos下小工具,读取256字节SPD信息 汇编语言 工作结果: 学习笔记: SMBus(System Management Bus) SMB ...

  5. Docker 外部访问容器Pp、数据管理volume、网络network 介绍

    Docker 外部访问容器Pp.数据管理volume.网络network 介绍 外部访问容器 容器中可以运行一些网络应用,要让外部也可以访问这些应用,可以通过 -P 或 -p 参数来 指定端口映射. ...

  6. 数据库访问抽象层系列-1(介绍数据库编程接口及数据库访问抽象层概念)

    摘要 本人最近完成了一个封装数据库访问抽象层的项目.我们开发的数据库访问抽象层作为分布式集群基础平台的一个组件.可以支持不同数据库编程接口(OCI.mysql.ODBC.pgsql)等.本系列博客主要 ...

  7. 基于mdm9206 threadx_os的I2c操作相关API介绍

    大家好,今天小白给大家介绍一下,关于mdm9206 threadx_os的I2c操作相关的API,希望能和大家一起交流学习. 一:I2C简介 I2C是一种2线总线,用于将低速外设连接到处理器或微控制器 ...

  8. VC访问数据库学习总结

    VC连接数据库方式 目前Windows系统上常见的数据库接口包括: ODBC(开放数据库互连):访问数据库得先配置数据源 MFC(Microsoft基础类)ODBC类 DAO(数据访问对象) RDO( ...

  9. java 修饰符 访问控制符_Java访问修饰符(访问控制符)

    Java 通过修饰符来控制类.属性和方法的访问权限和其他功能,通常放在语句的最前端.例如: public classclassName { // body of class } private boo ...

最新文章

  1. 项目经理修炼手册 2.1.2 项目经理的基本功
  2. appium python框架结构,GitHub - wyybingo/python-appium: 基于PageObject UI自动化测试框架,支持Android/iOS...
  3. 关于数据库隔离问题说明及解决
  4. [置顶]IFTTT与Google+是什么?ifttt怎么玩?
  5. leetcode 373. Find K Pairs with Smallest Sums | 373. 查找和最小的K对数字(小根堆)
  6. 1847 奇怪的数学题(杜教筛 + Min_25 + 第二类斯特林数)
  7. tesseract 使用说明
  8. gis导出栅格数据为什么不能tif_GIS基础操作教程(3)--点数据操作【附带练习数据】...
  9. Spring Boot系列(一)——初识Spring Boot
  10. 个人常用观影网址记录
  11. 历时一个月整理2021金三银四Java面试题汇总,足足127页!
  12. 椭圆形印章核心算法浅析及使用GDI+绘制椭圆印章的方法
  13. 腾讯云直播是什么?操作文档
  14. 【题解】2020年蓝桥杯C/C++程序设计B组·试题 D: REPEAT 程序
  15. 记一次kali搭建vulfocus环境
  16. 《Cisco防火墙》一6.5 虚拟防火墙的管理访问
  17. 抖音小店如何上传商品?提升精选联盟排名的4大秘籍丨国仁网络
  18. select二级联动价格策略+js的eval()
  19. 区块链性能提升:链上设计之道
  20. 水果分选机设计(论文+CAD图纸+开题报告+任务书+文献综述+外文翻译) 水果果径大小分选机的设计

热门文章

  1. 拆装微型计算机的心得体会,微机课程设计心得
  2. 【C语言】刷题计划第一期——洛谷编程题目集
  3. VBS基础篇 - 循环语句(2) - While...Wend
  4. 1131 神犇的悲惨一生
  5. java做windows屏保_java编程加载窗口,制作动画(屏保泡泡)
  6. T80 Google云端AI实验室
  7. 资料分析的统计术语、速算技巧、重点题型
  8. 安装Broadcom无线网卡驱动
  9. re管理器修改音量_安卓教程:使用RE管理器去除系统拍照声音
  10. 在线软件-管理软件 收银管理软件 连锁管理软件 餐饮管理软件 足浴管理软件 会员管理软件...