|
Reset Control $ Z' s. k* e! M
1.Reset Introduction* O V3 a0 B. T5 z9 W
7 _3 _6 i$ p( e: Y' rReset机制是BIOS中一个很基本的动作,很多部分的操作往往需要做一下Reset然后才能正常工作。Reset如影随形无处不在,哪个功能不正常就Reset一下呗(玩笑而已:)),Reset在BIOS code中还真是挺多的,翻翻code就会找到像MRC初始化、ME设置、Setup的调整 、三键重启、BIOS Flash之后的Reset等等。虽说Reset是一个很简单的操作,但是我一直搞不清楚Reset有哪些种类,这些Reset分类的区别以及使用时机,所以就打算总结一下。翻翻spec发现其实Reset大致上就分为1. HW Reset 2.Soft Reset 3.Special Cycle Reset 4.Global Reset这么几类,每一个类别下又可能有几种不同的实现方法,后续就分别介绍一下各个Reset的原理以及使用方法。
0 x2 w% x: L0 d8 ?
, \# Q; q* D, n1 D% V' I2.Hard Reset
4 F. R5 o3 A# M) j, O- P" o$ J' p# M# N& V1 @* J; D/ |- H4 L
HW Reset通常是将整个Chipset以及连接在Chipset上的所有的bus device都会被Reset,它的信号上的表现就是Chipset将会给出PLTRST# signal(Platform Reset),BIOS可以通过向RST_CTL Register (CF9h)下06或者0E的cmd来产生一个HW Reset,06和0E的区别是0E会产生一个Power Cycle,也就是S3# S4# S5#的信号会依次下达。因为这和S5的power sequence是一样的,所以0E的HW Reset也通常被称之为S5RESET。Hard Reset常见开启或者关掉某些device,或者一些port的时候可能就需要做一次Hard Reset将bus reset,再重新分配和扫描资源。
# o2 p* E% f2 q
n: A2 K2 Q5 c9 h4 o0 R5 X5 u- A3.Soft Reset
6 y2 F: f2 j+ S) Y2 Y
5 U. Q, C, k* t3 N0 i: R3 D# kSoft Reset指的是只Reset CPU其他部分不受影响。Soft Reset有很多种方法,比较常见的是透过IO Port 92 or CF9还有就是64port 下FE CMD,虽然操作方法不一样,但是最终都是透过拉CPUINIT# 16个PCI clock实现Reset CPU的目的。Soft Reset通常对应的就是BIOS 的warm boot,比如常见的三键重启,或者windows下的reboot等动作。
3 y& e: k# n- G6 @# U8 u7 A% P) M% w9 V1 S9 k
4.Global Reset
! p; p2 i5 i2 ]7 I& p4 `
9 R) ^( s* z1 TGlobal Reset又称为Powerok Reset亦或者是Full Reset,它与Hard Reset非常像也是下06/OE到CF9唯一的差别就是,它需要将LPC那边CF9GR的BIT举起来。Global Reset有一个显著的特点是它会有一个掉电的动作,有些Device如ME or TPM,对它们的初始化或者设置通常都需要做一次Global Reset.' F) B+ m8 F- M' I
0 t5 k( p' O9 x+ [1 O8 f5.Special Cycle Reset( L Y: u* I/ l
2 e/ n% A8 S- q* }1 e5 Y' vSpecial Cycle Reset按照BWG上的说法,是指当CPU产生一个shutdown special cycle时Chipset将会产生一个soft reset而且该soft reset无法避免,不留痕迹!:)
( Z! r$ d5 {+ U- {7 V0 p0 X( @
( F* N2 q% d/ C+ d# V/ U; g( Q
& C( ~- n$ g1 Z+ lPeter0 a+ E" A; O8 j8 M# @( b t
# {2 M' q$ V( S, ~0 o
2 K. c9 l4 B$ u3 P2010-07-04
/ i" o, i$ R4 G8 H2 P5 H0 C& E- y3 p* y: F/ e. e. l
[ 本帖最后由 peterhu 于 2010-10-29 16:28 编辑 ] |
|