找回密码
 加入计匠网
搜索
热搜: BIOS ACPI CPU Windows
查看: 59500|回复: 16

[原创]BIOS知识点滴Follow Bini系列之--ACPI _GPE & _Q方法

[复制链接]
发表于 2007-12-7 12:11:21 | 显示全部楼层 |阅读模式
--易祝兵 2007-12-7
1 m8 U( R$ ?/ H
在BIOS初始化platform PM寄存器后,支持ACPI的操作系统会开启ACPI模式,一般同时开启SCI事件的响应。
1 i- }) [' P8 t+ \; I) a% m1 Z  w* k% f  n
什么是SCI?什么是SMI?+ z3 W& q! h7 l; R: \& R! s
这里如您不知道,我只大致解释一下:  T  ~; k$ u# o/ @4 j6 L2 i
SCI:系统控制中断,会由产生一个IRQ x(此x号码,一般可由平台的寄存器设定)中断请求,操作系统的ACPI驱动会响应此中断。
& j& `- H& F/ [- o& G1 @4 USMI:系统管理中断,由各设备或软件需要SMM服务时,下拉CPU的SMI Pin所产生,系统不论在做什么,都会挂起现执行的操作,跳至一个特殊的模式,叫系统管理模式(SMM)(当然是比操作系统有更高的优先权啦,才不管你0/3 level什么的。)3 e: x! r4 }% @' F
7 b5 s, T! o7 h# t' F, k8 K9 `( N
当你配置了一个GPIO产生events后,又打开了ACPI和SCI。那么系统在此GPIO Status发生变化的时候,ACPI驱动就会捕捉到。即:一般就执行一个ACPI里_GPE()内的一个方法。这是普通的。
8 R/ {5 [6 S" Z5 Z# W, y$ T
# ?$ {  T8 E0 M4 ?+ g- q+ |ICH7 GPIO Status的寄存器如下:
. G1 V2 ~; G  v4 f. Q 1.JPG 4 U/ F% L/ B% s$ _

' Q3 ]% [2 n5 ]0 T让GPIO产生SCI或SMI的Switch寄存器:, A# L: B! J2 ], z# L& M3 N; g
3.JPG
* J4 i; V2 P, G/ W/ U. d/ o9 _+ A: R& h/ k9 L" X
一种机器所用到的的GPIO:
: g5 a8 u$ {& e) ]# i, O/ R 2.JPG 9 |! r8 O. K5 Z
( v% H  Y8 \. f  L
处理这些事件的方法如下:7 M. {! \9 f& M3 [5 U
4.JPG 1 K. [, w. }& w' @3 |
注意上面,的_L04是指你GPEx_STS的PM寄存器的第4个bit位发生变化时,所执行的ACPI事件方法,并不一定是指第4个GPIO所生产的方法,各平台有各平台的Chipset手册,注意看好。( U7 k0 U2 [% V$ D
: |7 {4 K8 E% p- q3 m8 Q; {( o  \
那什么是Q方法?* Y0 F- f: M5 H* f
当你的平台定义了ACPI嵌入式控制器(EC,PNPID:PNP0C09[PNPID的文档,见本站内的贴子:http://www.ufoit.com/bbs/thread-97-1-1.html]),并指定了EC所使用的GPIO,那么,此GPIO的事件(状态发生变化)产生时,就会产生一个Q事件,处理此事件的,就叫Q方法,可以有从0到FF个,即: _Q00() ~ Q255()。7 j' u- o& X$ `% g

' C6 s+ J! H6 w既然有256个,哪如何区分Q事件呢?0 D3 [5 q2 W: g
当Q事件产生时,OSPM会向ACPI EC发出一个命令去查询此Q事件的号码。EC会响应并回复一个号码给OSPM,然后OSPM就会执行ACPI里的某个Q方法。6 H+ q) t: q% w* K

$ j- b6 A, V8 o# g* \如EC发现温度发生变化,就会向ACPI Thermal驱动发出通知,更新ACPI Thermal,以便系统按要求处理散热方案,如下图:
5 G5 t3 X' P7 l$ G9 P1 I$ C9 rMethod(_Q34) { // embedded controller event for thermal Notify
1 ^: d* K. a: O6 N: O# Z$ S$ _    (\_SB.TZ0.THM1, 0x80) ' T' w9 w$ {4 G; ~7 V- Y% D
}) L' r0 e2 R/ X4 g7 A  Z
( ]; k/ g9 |$ Z, E1 x( O' J
详见文档: ACPI 3.0b -> 5.6.2.2.3 Queuing the Matching Control Method for Execution.. q- @; L; V; s% Z& c
如找不到ACPI 3.0b请到:http://www.ufoit.com/bbs/thread-7-1-1.html 处或 http://www.acpi.info 下载。
发表于 2007-12-8 09:17:47 | 显示全部楼层
嗯,多谢分享
回复

使用道具 举报

发表于 2007-12-24 11:22:01 | 显示全部楼层

wake event

看spec,GPE 事件产生后除了会发 SCI/SMI#,有时候还会发 wake event.2 B" k7 U4 j" Q( a. ]
SCI --> IRQ --> ACPI driver。 , B0 `7 g/ _4 ~8 F
SMI# --> SMM。' j8 @6 m* s$ X* j9 N( [
那 wake event 的工作机制又是怎样的呢?
回复

使用道具 举报

发表于 2007-12-24 12:09:51 | 显示全部楼层
Wake Event, 就是可以把系统唤醒的事件, 例如网络的唤醒方式, 是通过 PME# 产生 Wake 事件, 把机器从S1/S3/S4/S5唤醒, 返回到S0.
回复

使用道具 举报

 楼主| 发表于 2007-12-26 14:31:54 | 显示全部楼层
你看Host的Datasheet,看平台支持哪些唤醒,如你平台支持GPI[0..n]的 wake up,那就应该有个开关,让某个GPI[0..n]产生Wake event(注意是在S1~S5,看你的平台说明),如果在S0,那么就可能只产生SCI/SMI。所以,当此GPI产生Wake event时,HOST就会启用wake up上电时序进行平台上电。
: C' F( ]) X) W: v
8 h( U9 N& b3 b+ `8 n; u多翻平台的Datasheet,查找wake event,应该一目了然。
回复

使用道具 举报

发表于 2008-1-2 14:58:31 | 显示全部楼层
看了快一个月的ACPI了,总算知道大家的讨论什么了。( P; q2 k' a- A+ J; y( p+ v" ~
: w' F" M' F! i" J1 r0 q% j
   ^    ^
6 w, f  @% L$ z (   。 。  ), `2 K" h9 I% \$ `; A) e
     (  )
回复

使用道具 举报

发表于 2008-1-14 16:04:06 | 显示全部楼层
讲得不错。9 ^3 m7 T5 C/ J, }/ S  n
其实一切均按apci规范进行,考验大家英语阅读和领会能力啊
回复

使用道具 举报

发表于 2008-5-19 20:16:16 | 显示全部楼层
"让GPIO产生SCI或SMI的Switch寄存器" 0 E: s% U. r* }" n% d

% ?* |4 @% d9 |- i7 y( ], {" T/ P: Q谢谢!
回复

使用道具 举报

发表于 2008-5-19 20:31:28 | 显示全部楼层
请教一个问题 ) o, B1 ]/ X& s7 |

' l- P2 u; i! U9 QSMM里面还可以在发SMI吗?
回复

使用道具 举报

 楼主| 发表于 2008-5-20 00:54:48 | 显示全部楼层
SMI是不可重入的.具体见IA64 & IA32 AS, Volume 3B 第24章.
回复

使用道具 举报

发表于 2008-7-8 17:54:14 | 显示全部楼层
请楼主解释一下,
1 ]8 g! ?- K! kRST_CNT—Reset Control Register $ ?, J3 s4 ~- H% T6 K
I/O Address: CF9h Attribute: R/W
8 L' Q- G' q+ ^
  Y  k; R* P& q+ c1 r. MICH9在这之后都使用offset表示 Register Address(PMBASE + OFFSET, 这里的PMBASE是指 CF9吗??)$ r) K6 @; u+ a: A  {% B- X( \
比如:& p- V: a1 [( d
GEN_PMCON_1—General PM Configuration 1 Register ) u9 o* Z6 y# K, Y+ i( Y
Offset Address: A0h; O- ]' o( ^' m. c3 u! V9 h
& n" Z9 C2 Z9 A* ?5 |/ T
如果我要对该register操作,该怎么做呢? I/O Address = 0x0CF9* 16 + 0xA0 = 0xd030 ??????
+ A3 n8 ?! n1 H- v- e$ b5 B2 d5 B/ f/ k8 S3 p
还有,您上面所写的8 |% ?) \1 T  j5 q+ \% k# G. p
mov al, 0Eh2 s7 c2 u1 s* E6 s  ]% K$ L' i% C
mov dx, 0CF9h+ C4 G; g/ ]+ m- b& T
out dx, al8 `$ G! r& P5 q/ P# R. [
jmp $" X+ |: |. Z7 W& W1 r, L: x& e% h

5 M# Q* i0 ]' Q/ k最后的jmp $ 是跳到哪了?
回复

使用道具 举报

 楼主| 发表于 2008-7-9 09:44:43 | 显示全部楼层
PMBASE,请查找ICH的spec,即可找到答案。
% O) f0 F4 ?9 V! p* |' r% T; b6 o; }; P6 j& O9 x/ b+ p8 r5 N
Jmp $,就是Jmp到自己,也就相当于一个死循环。
回复

使用道具 举报

发表于 2009-12-4 17:25:54 | 显示全部楼层
哥哥,有些复杂
回复

使用道具 举报

发表于 2010-7-19 19:53:15 | 显示全部楼层
mark,等我先看看spec,再来领会先,多谢
回复

使用道具 举报

发表于 2011-1-4 14:26:46 | 显示全部楼层
mark,等我先看看spec,再来领会先,多谢
回复

使用道具 举报

发表于 2012-7-20 10:53:39 | 显示全部楼层
Bini,怎麼看不到你最近的動態了呢?什麽時候再出江湖,為我們指點迷津呀?
回复

使用道具 举报

发表于 2013-9-4 00:25:20 | 显示全部楼层
暂时还在学习中,很多看不懂
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 加入计匠网

本版积分规则

Archiver|手机版|小黑屋|计匠网

GMT+8, 2026-3-5 14:24 , Processed in 0.067726 second(s), 20 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

快速回复 返回顶部 返回列表