|
--易祝兵 2007-12-7
6 u: E0 \9 |3 f# |1 u在BIOS初始化platform PM寄存器后,支持ACPI的操作系统会开启ACPI模式,一般同时开启SCI事件的响应。. n- j+ u- v9 p0 P4 p- [0 U
8 |+ E) l- \2 U; _什么是SCI?什么是SMI?( h5 u& i2 n! L% d$ A" o
这里如您不知道,我只大致解释一下:, h+ O; Q/ p* m6 q
SCI:系统控制中断,会由产生一个IRQ x(此x号码,一般可由平台的寄存器设定)中断请求,操作系统的ACPI驱动会响应此中断。
. w1 ~7 q0 S6 PSMI:系统管理中断,由各设备或软件需要SMM服务时,下拉CPU的SMI Pin所产生,系统不论在做什么,都会挂起现执行的操作,跳至一个特殊的模式,叫系统管理模式(SMM)(当然是比操作系统有更高的优先权啦,才不管你0/3 level什么的。)
! ^/ q7 d9 n6 C
/ M5 K+ H$ i9 C当你配置了一个GPIO产生events后,又打开了ACPI和SCI。那么系统在此GPIO Status发生变化的时候,ACPI驱动就会捕捉到。即:一般就执行一个ACPI里_GPE()内的一个方法。这是普通的。8 ?5 b5 V6 Z3 P$ L
/ d' Z! \, Q% c- |1 {8 D& cICH7 GPIO Status的寄存器如下:, ?% C4 x: S. B7 b& l5 L7 c# t/ ?
$ Y3 L9 L* A7 U. p" `( R; d, [! ~2 }& }0 ]
让GPIO产生SCI或SMI的Switch寄存器:
3 k' ]- m, }2 ]6 v" m0 b& s# p
% o8 R% S2 r# U' z- b; |- J
' A) T& e P) a+ B一种机器所用到的的GPIO:$ V9 f& ~1 s" X2 s
$ D. v( R0 s) J7 \9 \- m9 H
( |- s' U9 Y6 E m处理这些事件的方法如下:; ?$ M# J8 z. @) Y
9 y8 u7 p6 S. f1 B注意上面,的_L04是指你GPEx_STS的PM寄存器的第4个bit位发生变化时,所执行的ACPI事件方法,并不一定是指第4个GPIO所生产的方法,各平台有各平台的Chipset手册,注意看好。8 i' G# Y- [, x2 O, G/ Y
/ a6 \3 A: u! A! m" e那什么是Q方法?
4 I6 e; L! Y8 w: k D" q$ t0 G. z当你的平台定义了ACPI嵌入式控制器(EC,PNPID:PNP0C09[PNPID的文档,见本站内的贴子:http://www.ufoit.com/bbs/thread-97-1-1.html]),并指定了EC所使用的GPIO,那么,此GPIO的事件(状态发生变化)产生时,就会产生一个Q事件,处理此事件的,就叫Q方法,可以有从0到FF个,即: _Q00() ~ Q255()。
2 P3 j6 ~ Y% g& F0 L) s$ n& J
( d6 ^ N7 V0 K; j% T: _& t既然有256个,哪如何区分Q事件呢?
8 V- i( t0 y4 {! f8 ?当Q事件产生时,OSPM会向ACPI EC发出一个命令去查询此Q事件的号码。EC会响应并回复一个号码给OSPM,然后OSPM就会执行ACPI里的某个Q方法。; C- I( U) i- E% H* P
9 N8 G2 C; ^4 a) g. j4 c# T* ~9 `
如EC发现温度发生变化,就会向ACPI Thermal驱动发出通知,更新ACPI Thermal,以便系统按要求处理散热方案,如下图:2 V6 e$ n% e. s% ~2 d) h+ x8 K
Method(_Q34) { // embedded controller event for thermal Notify7 j5 S, q! g9 K# T+ |4 c
(\_SB.TZ0.THM1, 0x80) 6 p0 z! y, @- j, z$ [4 S
}+ Y; N1 b1 a' I( P" [6 O* F
% T! ~- r7 t. C$ p; S详见文档: ACPI 3.0b -> 5.6.2.2.3 Queuing the Matching Control Method for Execution.
7 s; c* D$ t7 D2 U9 f: a如找不到ACPI 3.0b请到:http://www.ufoit.com/bbs/thread-7-1-1.html 处或 http://www.acpi.info 下载。 |
|