记录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