|
|
|
Reset Control
! G: l6 ~. s2 b/ {3 x2 H# ^' V: a0 t1.Reset Introduction
0 B- _# Q- c7 _& K
; \3 h3 w4 P1 a$ F8 D5 EReset机制是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的原理以及使用方法。1 l3 B) y H! I( ^9 U
0 u$ L9 n2 |) f9 j) s/ H2.Hard Reset" P5 ]8 ?6 k# K4 a
+ B* h1 o; M" c$ l- L+ n! 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,再重新分配和扫描资源。+ _& {# K+ J/ ]3 h* o
4 p9 W' I: x% t# J3.Soft Reset
0 o1 U9 P4 n0 a7 e" Z b4 i) D3 [% x: ?
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等动作。1 h3 E" C i3 b' ]. k% Y/ V
8 l7 y }; |0 r, N% K7 }9 Z
4.Global Reset3 D' R' i6 h+ m4 o5 k* W: d
' y& M4 A* \3 U+ R5 a/ G' M. KGlobal Reset又称为Powerok Reset亦或者是Full Reset,它与Hard Reset非常像也是下06/OE到CF9唯一的差别就是,它需要将LPC那边CF9GR的BIT举起来。Global Reset有一个显著的特点是它会有一个掉电的动作,有些Device如ME or TPM,对它们的初始化或者设置通常都需要做一次Global Reset.
9 a; G5 E" {7 N+ }" Z4 g3 J+ F, J8 O7 h, [, Y$ @7 M0 m6 r5 \. N
5.Special Cycle Reset9 ^9 T' Z9 @' \7 q; K
! f& g5 T, _ m4 I7 ]5 zSpecial Cycle Reset按照BWG上的说法,是指当CPU产生一个shutdown special cycle时Chipset将会产生一个soft reset而且该soft reset无法避免,不留痕迹!:)
! |* {& t3 _! {. c1 _. x5 t" ~/ l
( M4 |! X, A1 `, ^. C& D& b( o, X! e7 ?9 ^5 q! W- L1 m
Peter
" l# w! e0 R3 B8 @
+ ~. X+ H/ j( Z: w4 l. _+ q2 O$ O8 T, v2 q* P
2010-07-04
/ l4 J* N- Q# l
5 P/ e; c# D9 B- d[ 本帖最后由 peterhu 于 2010-10-29 16:28 编辑 ] |
|