|
Reset Control
7 V8 Y6 O- W" N5 M q. {- E! \- d1.Reset Introduction
: b% q/ w. E1 N. m6 ]& R6 w( ^% ^9 _( V3 Z4 Q* U9 \
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的原理以及使用方法。
+ s0 ?2 c: Q% n! H0 g0 I C, J
; \ g N% R( e* j2.Hard Reset
! s! }4 D5 o6 v' S5 {1 o# w+ c6 \( t/ r8 x7 K" z
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,再重新分配和扫描资源。
7 d; J( z& z# }+ D+ v. T1 E7 k3 @8 z5 b: ]- s+ x0 P" Y* C+ D d
3.Soft Reset- @& H5 W9 W9 a
3 k" U6 z* ? T
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等动作。0 X: `! {8 J' N9 o7 v6 t8 z
* ?3 q, j+ ~3 E' U3 M/ m
4.Global Reset+ ~2 o$ A, A, D+ d* K+ a' U# Z
* b0 { Q! S- @1 @+ BGlobal Reset又称为Powerok Reset亦或者是Full Reset,它与Hard Reset非常像也是下06/OE到CF9唯一的差别就是,它需要将LPC那边CF9GR的BIT举起来。Global Reset有一个显著的特点是它会有一个掉电的动作,有些Device如ME or TPM,对它们的初始化或者设置通常都需要做一次Global Reset.5 \# y" L3 w) J! [8 q: ?. ?9 v
+ o1 u# j3 }/ }& Y4 d* `9 o1 ]# @7 l' l! D
5.Special Cycle Reset
3 v7 }' `- a( ^/ h a- {
# i* A6 c9 k- `( c' L9 [Special Cycle Reset按照BWG上的说法,是指当CPU产生一个shutdown special cycle时Chipset将会产生一个soft reset而且该soft reset无法避免,不留痕迹!:)4 h. @: p+ I) h
5 g5 b" `9 I8 ?1 L% N
( {$ t$ j. d7 w1 i& A' F2 Z
Peter: S# m3 H' D+ o! r' v' x5 T
/ `. j9 B3 W* B& {
; f4 D! N2 Z- u/ y7 M4 ^; s2010-07-049 e% t' k5 K, Z
2 N; B# V* _ v+ ]2 j6 Y[ 本帖最后由 peterhu 于 2010-10-29 16:28 编辑 ] |
|