|
|
|
Reset Control 8 C2 y8 o& r2 W- ], N0 y
1.Reset Introduction
# d Q( ^/ p7 p7 W
' D$ c7 L. N0 \% T% C( M* B! }5 z1 Y. xReset机制是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的原理以及使用方法。
5 j2 E2 a! S' l5 ]# {
( o8 q. [: Z$ G2 P8 k9 K0 g: j- c2 x2.Hard Reset
6 N6 j. l& U( I4 p4 _% |% U
7 @ T) W3 P' J" S7 JHW 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 Z8 u8 @/ i z) V) V
# N& e, ]4 Y; _+ ?- o8 q
3.Soft Reset7 I1 T% d# v0 D$ D, h. {8 D3 B
+ P% F6 w9 _2 E: g5 k9 q/ R0 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等动作。5 u' j, p7 b0 O+ S
9 s& t/ d7 u& |* H" [. D, B/ \' [
4.Global Reset+ ?1 T# z; i0 B: i$ c9 Y! w5 a
5 z q7 E! H% F! w7 \Global Reset又称为Powerok Reset亦或者是Full Reset,它与Hard Reset非常像也是下06/OE到CF9唯一的差别就是,它需要将LPC那边CF9GR的BIT举起来。Global Reset有一个显著的特点是它会有一个掉电的动作,有些Device如ME or TPM,对它们的初始化或者设置通常都需要做一次Global Reset.
" x7 @! D$ M3 \6 W( ]2 J0 l; s& k' p
) E, i* l$ u. A5.Special Cycle Reset
- F$ C, a* w; |9 S& `* B) @8 S' T. ?( V7 ~9 s
Special Cycle Reset按照BWG上的说法,是指当CPU产生一个shutdown special cycle时Chipset将会产生一个soft reset而且该soft reset无法避免,不留痕迹!:)
# T" P* _5 S1 z# V2 ?. F5 Z4 x4 l+ l* w7 f1 b
& i& z& J- a0 `) Z; NPeter
0 @, i1 t1 n9 @( M; I1 W9 v3 f6 U) `
8 ?, ]( W1 p! N
2010-07-04
: I2 d0 T8 _, b8 O
$ U5 }# R9 x/ I2 ^& s[ 本帖最后由 peterhu 于 2010-10-29 16:28 编辑 ] |
|