|
|
|
Reset Control 0 ?1 ^9 Z2 l/ a! _. I* L
1.Reset Introduction" `6 j/ p, v1 y
; U& ^0 J3 i ? U/ k3 f, G# N- Z
Reset机制是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的原理以及使用方法。6 t% N# N5 ^* [# S
1 k2 i0 y, S" q$ x" d1 K2.Hard Reset
; k5 C. Y, D* [ Q
6 x5 b' P% p( \6 CHW 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,再重新分配和扫描资源。$ G1 C8 B2 u; ?2 S& y5 ]% O @6 `7 O
( U0 c7 d9 X0 p% {9 I" B/ c
3.Soft Reset
+ d4 l4 ~. j% C" t# |
7 T# e- A1 [! p0 C ISoft 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等动作。! R$ D# j1 f# e
) R1 ?. p% F* B; \8 g+ @. d4.Global Reset3 |- O( y% d5 ^. L; x
2 q. A! U1 D$ n/ r' i2 tGlobal Reset又称为Powerok Reset亦或者是Full Reset,它与Hard Reset非常像也是下06/OE到CF9唯一的差别就是,它需要将LPC那边CF9GR的BIT举起来。Global Reset有一个显著的特点是它会有一个掉电的动作,有些Device如ME or TPM,对它们的初始化或者设置通常都需要做一次Global Reset.
) a) O- Q3 A( l' ?; `2 k" d, S* y; z- q3 |- j' s
5.Special Cycle Reset% ] {: f2 r- G3 V P7 |0 [
7 B, V" o" ?3 u" w7 R4 L
Special Cycle Reset按照BWG上的说法,是指当CPU产生一个shutdown special cycle时Chipset将会产生一个soft reset而且该soft reset无法避免,不留痕迹!:). ]- Y; F8 ?* b2 T1 A: p5 v
6 w$ W, D" o2 V8 ?4 E, I8 I/ d+ U# d' Y3 I3 v/ f
Peter
: w+ Q# b6 j3 @6 p( o( E n O5 L- Y- [$ o5 S7 b4 q
3 Z& J. g5 W, z$ d( e0 H* W2010-07-04
" ^. i, n2 R0 {" O D* c: g% v8 A2 m/ x7 J- b1 m, o, m2 ^
[ 本帖最后由 peterhu 于 2010-10-29 16:28 编辑 ] |
|