|
|
|
Reset Control ( e2 v8 i P% L, Q) x* F3 e
1.Reset Introduction
$ W/ S" y$ H, t5 X3 Y1 j# r0 T
; A' A1 y5 |& S" M# YReset机制是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的原理以及使用方法。; |! n) v* t9 K5 j# k1 v- [/ i
4 w9 Q" d3 f1 |2 [" ^2 j
2.Hard Reset
q5 H5 ~" p' ]: Y! c2 l' S9 a- R+ _$ r6 i
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,再重新分配和扫描资源。6 q6 K: x1 {: [4 T* A6 y0 [! t
! O! k- P D# _* G+ g3.Soft Reset5 S4 w& Y6 f, C3 Q( i
; e4 Q0 ^, Y8 Z4 Q1 v ]3 i: N. N
Soft 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等动作。/ |! z# g3 o/ a4 U+ }
9 L' Z: T/ n$ [; i. a7 ]& c1 f4 }+ H. Q
4.Global Reset
9 S+ U! l) h3 f- Z7 V4 T, S3 r z0 n3 L& Q
Global Reset又称为Powerok Reset亦或者是Full Reset,它与Hard Reset非常像也是下06/OE到CF9唯一的差别就是,它需要将LPC那边CF9GR的BIT举起来。Global Reset有一个显著的特点是它会有一个掉电的动作,有些Device如ME or TPM,对它们的初始化或者设置通常都需要做一次Global Reset.
/ E# z' o0 e: o& O: w6 v" V. y8 f/ x5 r: D! F# v
5.Special Cycle Reset
% s3 s1 j) A* u p3 ?
; f# {, a6 T8 F5 A; D( ~ mSpecial Cycle Reset按照BWG上的说法,是指当CPU产生一个shutdown special cycle时Chipset将会产生一个soft reset而且该soft reset无法避免,不留痕迹!:)
- Q. l+ \9 c0 ^4 |( `6 u7 V, r! T% e" h
X% n# n$ k! E$ C
Peter4 x: |/ V' \, f- }* W6 J5 G9 n
5 `$ \4 C* g3 G8 E' C7 B5 M/ N. S8 e
1 w+ E2 _! |: L: L. {) h
2010-07-04
7 z1 [: U$ W/ S6 d' ~' w7 p8 B) O! L& n
[ 本帖最后由 peterhu 于 2010-10-29 16:28 编辑 ] |
|