LPC(Low Pin Count) 与SIO(Super IO)
记录bios学习的点点滴滴,虽然已经学了很长时间才发出来,但就当是温故而知新吧,由于水平有限,难免存在错误,望指正,同时感谢CSDN提供的平台。
1、LPC
定义: Intel所定义的PC接口,将以往ISA BUS的地址/数据分离译码,改成类似PCI的地址/数据信号线共享的译码方式,信号线数量大幅降低,工作速率由PCI总线速率同步驱动,虽然改良过的LPC接口一样维持最大传输值16MB/s,不过所需要的信号脚位数大幅降低25~30个,以LPC接口设计的Super I/O芯片、Flash芯片都能享有脚位数减少、体积微缩的好处,主板的设计也可以简化,这也就是取名LPC——Low Pin Count的原因。
应用:
LPC总线上一般都是低速设备,比如说鼠标,键盘,EC,SIO以及一些FLASH。
2、SIO
超级输入输出芯片(SIO)一般位于主板左下方或者左上方。主要使用的芯片有Winbond、ITE,Fintek,它为主板上的标准I/O接口提供控制处理功能。这里所说的“超级”是指它集成了PS/2键盘、PS/2鼠标、串口COM、并口LPT接口等处理功能,而这些接口都是计算机中的慢速I/O设备。它们全部位于主板后部右边。它的主要功能包括负责处理从键盘、鼠标、串行接口等设备传输来的串行数据,将它们转换成为并行数据,同时也负责并行接口、软驱接口数据的传输与处理。
SIO通过LPC总线与南桥通信,进行数据传输,而且SIO本身也是一块MCU,可以独立的控制输入输出设备。
目前主要使用的SIO芯片的品牌有winbond华邦电子,ITE联阳半导体,以及Fintek精拓科技三个。本次介绍的为精拓科技的F81866芯片。
F81866的介绍:
F81866主要由H/W Monitor,FDC,Parallel Port,KBC,UART,GPIO,ACPI等构成,EDS中给出的介绍如下:
在访问SIO时,需要输入“KEY”,KEY的值可以通过硬件的设计来获知:如下
通过下面的硬件图对照上面的表格来确定key值
在使用SIO之前需要完成对0X2E中输入两次0X87操作,下面介绍使用SIO的H/W monitor的功能。
H/W monitor的使用需要在index 07H中输入04,在上面有提到过。
在ru下对sio的H/W monitor进行操作:
在index 07H中写04选择H/W monitor
其中60h,61h是H/W monitor的基地址。
RU界面下的H/W monitor:
编程实现对SIO的访问:
对SIO进行访问需要知道访问的是哪一个设备以及该设备的哪一个寄存器,设备选择是将该设备对应的值写入Index 04H当中,如何对该设备的某一个寄存器进行读写操作。其程序设计如下(对一个字节):
我们都知道电脑的CPU都有风扇,他可以实现智能对CPU进行降温,这是怎么实现的呢?
对sio的了解会知道这一点:
Smart Fan的相关寄存器设置
Index 94H
选择风扇工作类型的寄存器,共三种工作类型。
Index 96H
选择风扇的工作模式,一共4种,分别为auto模式下的
RPM/duty cycle 控制,以及manual模式下的RPM/duty cycle
auto 模式下设置温度的寄存器(A6H,A7H,A8H,A9H)
auto 模式下设置RPM/duty cycle的寄存器(AAH,ABH,ACH,ADH,AEH)
温度,转速寄存器的使用说:
manual 模式下的寄存器设置
转速的设置,选择manual模式之后,可以在A3寄存器当中设置所需要的风扇的转速,其寄存器如下,并且给出了转速的计算方式(duty cycle),若设置的值为X,则为:
X*100/255
Smart Fan转速的计算
设置风扇的转速也需要将风扇实际的转速读出来,风扇实际的转速会保留在A0,A1寄存器当中:
在F81866当中也给出了转速的计算公式,如下:
编程实现对smart fan 的控制:
将每一个我们需要看到的数值,以及状态通过scan()函数读出来,然后打印在屏幕上,主要的值有当前状态是auto还是manual,设定的温度界限值,5个区间所对应的转速值,以及当前cpu温度以及当前风扇的转速。
总结
LPC总线继承了ISA总线的优点之余,也大大减少了电路针脚的设计,降低了硬件设计的难度,也实现了体积微缩,而SIO芯片则是将外部的低速的输入输出设备的控制以及信息交流全部集中在了一块芯片上,使信息的交流更加方便,同时整合多个功能在一块芯片上,使用的时候也更加方便。F81866芯片上集成了有:
一个FDC,9组GPIO,一个KBC,一组Parallel Port,一个WDT,一个H/W monitor,以及PME,
ACPI,ERP。
对于各个device来说,一般0x30寄存器为其的enable,0x60,0x61作为基地址的寄存器,0x70是中断寄存器,但不同设备有所区别,如kbc的中断寄存器除了0x70之外,还有0x72,分别对于的是键盘,鼠标的中断寄存器。
今天状态不好,脑袋有点疼,写的东西基本是以前学习的时候整理的PPT上再整理下来的,有点乱,见谅,SIO里有的会设置DIO,通过继电器来实现用主板对外部强电设备进行直接控制,下一章节会提到。
Thanks for your reading.
转载:http://blog.csdn.net/vito_bin/article/details/52973056
LPC(Low Pin Count) 与SIO(Super IO)的更多相关文章
- SDRAM interface slashes pin count
Many designs need deep buffering but don't require ultrahigh-memory bandwidth. Examples include imag ...
- X86架构
在接触BIOS的时候,都需要对PC架构有一定的认知.目前的PC架构绝大多数都是Intel的X86架构,貌似也是因为INTEL的这个X86架构早就了目前INTEL如日中天的地位. 废话不多说,X86架构 ...
- Linux内核配置选项
http://blog.csdn.net/wdsfup/article/details/52302142 http://www.manew.com/blog-166674-12962.html Gen ...
- 深入linux kernel内核配置选项
============================================================================== 深入linux kernel内核配置选项 ...
- Trusted Execution Technology (TXT) --- 基本原理篇
版权声明:本文为博主原创文章,未经博主允许不得转载. http://www.cnblogs.com/tsec/p/8409600.html 1. Intel TXT 介绍 TXT是Trusted Ex ...
- 2.2 HOST主桥
本节以MPC8548处理器为例说明HOST主桥在PowerPC处理器中的实现机制,并简要介绍x86处理器系统使用的HOST主桥. MPC8548处理器是Freescale基于E500 V2内核的一个P ...
- 006 PCI总线的桥与配置(一)
在PCI体系结构中,含有两类桥片,一个是HOST主桥,另一个是PCI桥.在每一个PCI设备中(包括PCI桥)都含有一个配置空间.这个配置空间由HOST主桥管理,而PCI桥可以转发来自HOST主桥的配置 ...
- System Address Map Initialization in x86/x64 Architecture Part 2: PCI Express-Based Systems
原文 http://resources.infosecinstitute.com/system-address-map-initialization-x86x64-architecture-pa ...
- Development of Intel chipsets interconnection
http://en.wikipedia.org/wiki/Chipset Chipset From Wikipedia, the free encyclopedia A chipset is ...
随机推荐
- Code First 数据库的表中属性的配置
数据类型的约定配置 默认规则 列的数据类型是由数据库决定的,SqlServer的默认规则如下 String: nvarchar(MAX) Int:int Bool:bit Decimal:deci ...
- 斯坦福大学卷积神经网络教程UFLDL Tutorial - Convolutional Neural Network
Convolutional Neural Network Overview A Convolutional Neural Network (CNN) is comprised of one or mo ...
- Python学习(六)模块 —— 标准模块
Python 标准模块 Python 带有一个标准模块库,并发布有独立的文档(库参考手册).对于程序员而言,标准库与语言本身同样重要,它好比一个百宝箱,能为各种常见的任务提供完美的解决方案. 这边简单 ...
- ExtJS ComboBox 录入智能提示
ExtJS ComboBox非常复杂,有很多的属性:其中有的属性是针对某一种特定的方案而设计的,不是所有情况下都有效.我想下拉选择能支持录入,并且录入时能智能提示,弄了半天可以了,但是只能是mode= ...
- Android -- ContentProvider与联系人
数据库 读联系人 raw ...
- (剑指Offer)面试题51:数组中重复的数字
题目: 在一个长度为n的数组里的所有数字都在0到n-1的范围内. 数组中某些数字是重复的,但不知道有几个数字是重复的.也不知道每个数字重复几次.请找出数组中任意一个重复的数字. 例如,如果输入长度为7 ...
- 网络电台-SHOUTcast
网络电台种类 目前的网络电台网站一般是基于以下三种协议的: mms.rtsp.http 其中mms是微软公司提出的网络流媒体协议,通常采用wma格式的文件,Android现在还不支持这种协议,也不支持 ...
- Mysql创建、删除用户、查询所有用户等教程,提升您的MYSQL安全度!
建议您不要使用mysql的root账号来为您的web页面连接数据库,这可能会导致用户通过网页获取到您的数据库账号密码,存在严重的安全隐患. 建议新建一账号,权限设置基本够用,然后使用那新建的账号来连接 ...
- tableview的两个重用cell方法
今天在学习IAP的时候无意间看到原来 tableView: cellForRowAtIndexPath:方法中有两个获得重用cell的方法,一直以来都是用 UITableViewCell *cel ...
- PHP 杂项函数
PHP 杂项 函数 PHP 杂项函数简介 我们把不属于其他类别的函数归纳到杂项函数类别. 安装 杂项函数是 PHP 核心的组成部分.无需安装即可使用这些函数. Runtime 配置 杂项函数的行为受 ...