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

[原创]WMIACPI.SYS

[复制链接]
发表于 2009-5-22 17:14:23 | 显示全部楼层 |阅读模式
WMIACPI.SYS

( V9 i$ O3 Z, d3 ]7 ]1. WMI Concept: ^1 e1 d# B6 W; ?# r
* h, e, g6 C' b5 ~3 p( m- m
WMI全称Windows Management Instrumentation是一种管理计算机系统的方式。它是微软基于WBEM的实现,WMI希望为系统管理以及分布式数据描述提供一种模型,并且允许使用基于COMuser mode API对系统部件进行访问、管理、控制。
# H& T- Q7 }1 n

/ u* c+ C- D* M/ Z
; z0 H" Y% j& e% `- a& A2. WMIACPI.SYS1 r9 c# i* ?- ]5 ^" ~1 t% ]
8 h1 @4 I- L0 L2 c: G. h9 o
Wmiacpi.sys 是微软提供的一只generic mapping driver它的Plug and Play ID PNP0c14.ACPI包含丰富的系统信息,OEM厂商可以利用这支mapping driver定制平台相关的功能而且允许使用WMI获取,如此便可以在单机或者在网络环境中获得平台的特定信息。关于如何在BIOSOS中定制wmiacpibini已经给出了非常详细的讲解,有兴趣可以参考
bini的文章。在这里我会讲解一下原理部分。ACPI-to-WMI mapping function是通过下述两只driver达成的:
' ?7 J0 ^1 o: M- rA.Acpi.sys
" L+ O% d" t5 A$ T# V( }B.Wmiacpi.sys
; m0 C, h. b! zA).Acpi.sys的一个主要功能是解释和执行aml,aml就是asl code的机器码,所以ACPI asl code真正的执行是由acpi.sys触发的,而不是BIOS主动执行的。它的另一个功能就是查找ACPI spec定义的device Plug and Play ID,并据此创建相应的software device后续OS会为这些device加载对应driver。如power button driverbattery driverlid driverfan driver等等。Device 对应的Plug and Play ID可以查阅ACPI spec获得。
6 y" D/ P) T; g  u5 AB).Wmiacpi.sys它的Plug and Play IDPNP0c14,一旦BIOS asl code给出定义,acpi.sys就会创建这个pseudo deviceOS就会load wmiacpi.sys作为该devicedriver。当然仅仅加载这支driver还是不够的,为了能够使用WMI访问该software device包含的具体信息我们还需要一个供BIOS使用的asl文件以及与asl code对应的MOF文件而微软并没有提供Wmiacpi.sys相关的MOF文件。那么MOF文件到底有什么作用呢?要搞明白这一点我们来研究一下WMI的工作原理了,下图1展示了WMI Architecture8 V0 r& _  S- v4 L3 Y/ A
( x( W+ O; d1 I, E
6 ^2 \& r* N, c2 h& E
wmiacpi1.JPG
: s8 a. @5 R, P; f0 luser使用API访问WMI信息时,WMI CORE会查看repository中已知的scheme定义,然后将希望获得的信息通过IRP的形式送给Providers这些Providers通常都是WMI Driver,它们处理IRP并将所需信息送给上层。那么也就是说必须要将MOF scheme加到WMI repository之中,consumer 才可能透过WMI COM API访问到。完整的过程是这样的OS在加载WMI驱动程序的时候会查看驱动程序的MOF scheme,如果驱动程序MOF scheme 部分正确无误,那么OS会将MOF scheme提取出来并自动加入到repository之中。所以OS仅仅加载wmiacpi.sys并不行,我们还需要给出与ACPI asl code对应的MOF scheme,并且通过在WMIACPI service key 下面建立一个key MofImagePath它的value指向MOF档的路径。如此在OS加载wmiacpi.sys时就会将对应的MOF scheme加入到repository之中,后续consumer访问时WMI CORE就会检索到scheme信息,然后下IRPwmiacpi.sys。讲到这里原理应该差不多了但还要注意的是wmiacpi.sys并不会去执行asl code,最终执行动作还是会由acpi.sys发动。driver是层次结构的,acpi.syswmiacpi.syslower driverwmiacpi.sys会将上层对asl的访问转化为low level IRP 送给acpi.sysacpi.sys再返回具体信息然后逐级回送。9 q4 r8 G  {1 S" O+ N1 P" \4 h
! C- Q  ~! W3 G' R( ]/ V# r+ Q3 @
3. Under the hood6 @" B7 U- f$ X; J$ D0 m

# `; l/ m. W3 k; a% W$ t前面都是原理的介绍,讲的我都快吐血了J,实践是检验理论的唯一标准。说不如做,随我揭开内幕一探究竟。WDK ver6000 src带了一个wmiacpisamplecodebuild之后会生成一只acpimof.dll,在BIOS里面将device.asl
包进去然后再注册表中加入acpimof.dll的信息然后重启。讲到这里还要提到一个验证wmi的好工具叫做WMICodeCreator.exe微软的网站上有下载,下面我们就使用该tool验证前面的说法,下图2演示了我们定制wmiacpi之后的状况:6 X7 J$ x* \; @% s) Z

/ z" x# z# n3 ~- o- u. W
, j# ?. ?% l% Y6 }) Y, n
wmiacpi2.JPG
; h6 Y" d5 U  \) {; r
2
7 @: X, q- e; O# |+ f9 l  i* z
2红色方框标注的AcpiTest_**就是我们定制的WMI class。也就是OS Load wmiacpi.sys之后将其MOF档案解析出来并加入到WMI repository于是我们就看到了上图的信息。下面我们来跟踪一下访问具体的class的情况吧,祭出WinDbglet’s go!首先查看一下wmiacpi.sys这支driver有没有被加载下图3表明该driver被正常加载了。
5 L; Y" z" @) R* N8 X- K& K4 _( o1 x% I  [  x% m: i$ F! y
wmiacpi3.JPG

1 g: y% |- v) \1 D6 K, y$ A
3
# t1 l$ K# H9 O  L  Z6 `/ k
由图3显示与wmi相关的有两个driver:wmilib.syswmiacpi.sys,wmilib.sys是干嘛的呢?别急后续讲述wmi driver的文章会详细介绍它。既然被加载了那我们就要dump wmiacpi.syssymbol看看有哪些有用的信息,这样我们才比较容易下手J。下图4显示了wmiacpi.sys的所有symbol5 g, Y3 h1 K, p) d' h& g

/ H0 N% H$ l% }3 Z
wmiacpi4.JPG

9 V; C1 @: W0 T- |, h4 r1 B1 Y
4
) p6 J2 O3 k4 D( _6 P* i$ V
前面我们还讲到wmiacpi.sys最终会调用到acpi.sys访问asl code那我们再看一看acpi.sys有哪些symbol,下图5显示了acpi.sys的所有symbol: \. X/ E! w% U' A* q0 R
/ D6 R/ a/ ?/ e" @
wmiacpi5.JPG
+ }4 V' j% z6 F" H/ a0 X7 S6 W
5

* ~, n1 ?* H: ^0 Z! z经过分析上述symbol我觉得下述函数很有作案嫌疑,所以将它们秘密监控J都给设上断点,被怀疑的对象如下图6所示:8 L+ |, L) [4 |  o

* n& l2 ?! A$ V) f: }
wmiacpi6.JPG

- L8 v6 r; l6 @: b6 X
6

  K7 @4 `0 \6 i- R1 X如图所示:% e; z: p3 v! n2 }" q- v, k7 Z
! W: `7 x' M0 X
wmiacpi!WmiAcpiSetWmiDataItem

8 `$ T5 N, X  ^4 {2 x/ x
. \3 T" R7 `# C% F/ ywmiacpi!WmiAcpiSetWmiDataBlock
( {8 b& V5 z$ b- J
& x( k" }/ T1 E5 [2 [
wmiacpi!WmiFireEvent
; r! i- r1 R( C$ ^5 Z/ ]/ o) ~4 K- \* [
- h$ @6 B" ~' m# ]9 h9 N2 }8 o
wmiacpi!WmiAcpiQueryWmiDataBlock

$ @" `4 a  {  s5 k& P, @) W% l$ q$ {. W. m
wmiacpi!WmiAcpiSendAsyncDownStreamIrp

; R; o2 N0 I/ T5 N' ?7 g( L6 z
' B  M' g* ]5 P7 F# Cwmiacpi!WmiSystemControl
; A0 |2 }1 c/ c& Q) Q; @0 F
% [# T$ J4 k8 m2 [& \
wmiacpi!WmiAcpiSystemControlDispatch
! [! j- ?" @9 n" A: V9 r

  w6 r: T$ E  U) a8 \+ a2 v' C' Jacpi!ACPIIoctlEvalControlMethod

8 W. w$ N) b! h0 q3 i( r& U% X4 f4 |  @4 T/ P9 F# `+ B( }& v, u
acpi!ACPIIoctlAsyncEvalControlMethod

6 E# y+ l( d6 H' M4 ^, D1 \* }- R  V
acpi!ACPIIoctlAsyncEvalControlMethodEx

2 K" F: U. Z7 i  n/ q0 a/ u! `- _
acpi!ACPIIoctlEvalControlMethodEx

0 r' F4 u/ `; h9 }% p3 K. X5 L. @* p4 v/ s5 y4 x6 F0 G6 s1 O+ L( |3 O
acpi!ACPIButtonDeviceControl

/ q* x+ R3 w! G4 m" P/ p/ T' s7 H* E  e
acpi!ACPIEcInternalControl

  |+ L$ ?* I) o1 m% B: T5 a9 H; K2 @( G  i5 |
acpi!AcpiEmbeddedControllerIrpDispatch

# Q& [2 T. a! k8 Z! S1 j$ \" h. \3 J# Y! ~. X, A) W7 E
acpi!ACPIIrpDispatchDeviceControl
' ~+ U7 y9 |9 _- f- j/ E
) F* v$ M. t. T: M
acpi!WmiSystemControl

9 u0 n# U+ M( Y+ d. [. B7 t8 a8 a3 @. V: {9 ]5 q
这些函数都被设置的断点,下面就我们读写一个class试试看了,图7证实了我之前的所说绝非空口无凭,我们读AcpiTest_MPackage class时发现先会call wmiacpi!WmiAcpiQueryWmiDataBlock,然后acpi!ACPIIrpDispatch DeviceControl会接手,当然后续还会有别的一些动作,但是上述行为就足以支撑我的论点了J) f& z. [2 B. o# A. \; ~
; s$ f) \' p: c6 B( N

1 G, s2 }' }; O( D" h
0 D: A3 @9 u5 t8 z& h
wmiacpi7.JPG
7 B) Z( N4 w' b$ Y" i" J) |- E
7
/ d" d- x( i% w% U+ B' L& D0 j
8演示了我们发一个event的状况,图中显示acpi.sys会接到该event然后透过wmiacpi!WmiFireEvent送给上层AP,上层AP再透过IRP下来qurey其它相关的具体信息。
! v( \7 U% a2 {  m8 U" Y( o$ k9 e

+ F& F0 q+ a; r  s8 v/ k% T. g
8 X" d% s5 K2 _9 u
wmiacpi8.JPG

* [0 b( {6 G  m' k, Y
8

- L/ H# A8 V- a$ T  J( n以上就是我费尽九牛二虎之力挖掘的wmiacpi.sys的秘密了,再附上一幅我的debug环境J
- C( ]4 O% P$ m
# f- [. Y5 _  X5 }
; i. s2 s; H7 u) P. l
wmiacpiA.JPG

, r3 f1 p& e' Q+ Q
9

( s2 y$ [% E; `! }That’s all!
3 P4 t. p5 `; ^# c. x7 i; vPeter 5 ^: R, b. N$ i1 j" R

5 L* \0 s) t3 I' z, y  p3 |[ 本帖最后由 peterhu 于 2009-5-25 09:31 编辑 ]
发表于 2009-5-22 20:27:37 | 显示全部楼层
兄弟说的很详细。) ^* s: o0 Z# I7 i) p  A
但最终的实现是不是采用MS的那个AP/ a3 ^$ C# v9 T$ v2 ~& a8 y( ?! l
动态生成VBS脚本,然后执行
3 m8 K) _% I# v! R! B上面Debug中那些内核函数,兄弟你不会是自己做申明吧?
$ W6 a' V- l2 s7 w4 W# X刚才骑车时仔细想了一下,觉得用那动态生成脚本是最方便的。
9 G( q* @! _. E4 R9 B7 F如果用COM来访问,我试了去调用,结果总是不能执行。
回复

使用道具 举报

 楼主| 发表于 2009-5-23 11:13:23 | 显示全部楼层
那些内核函数是微软的symbol,怎么可能是我声明的呢?
: R" T' Z7 j, j' ^0 H使用COM API访问绝对可以,请看这里http://blog.csdn.net/hgf1011/archive/2009/04/14/4073457.aspx
& U: s1 \4 Y* I7 u这是我写的一个tool,使用COM访问.
回复

使用道具 举报

发表于 2009-5-24 10:39:03 | 显示全部楼层
可以了,附件为C++写的一个执行WMI的程序,可以执行ASL代码了。- [  n' ?/ W+ k5 C4 a) t
以前不能执行是我把namespace给弄错了。- K- i- i" s7 |7 r, \9 z$ Z
谢谢各位。

Using WMI.rar

1.08 KB, 下载次数: 1378

回复

使用道具 举报

发表于 2009-7-30 16:05:21 | 显示全部楼层
刚开始学习acpi,收藏了,谢谢!
回复

使用道具 举报

发表于 2009-8-11 11:25:53 | 显示全部楼层
看了楼主的文章,有两点实在不是很清楚,望楼主指教:# o' \/ a7 K8 u5 Q/ K
1  该怎么把asl文件刷到BIOS中,是否需要BIOS的源代码,还需要其他的工具么?如果没有BIOS的源代码,我是否可以用ACPISCOPE刷到BIOS里面?但是这又引出一个问题,我不知道该把这段ASL放在DSDT表格的什么地方?1 K$ ~6 t, C, E; f4 C
2  我在其他的地方找到一般都是把acpimof.dll注册在HKLM\System\CurrentControlSet\Services\WmiAcpi里面,
  e: G% a7 A& W; ^+ V6 A我在xp上试验的,我的机器里面没有WmiAcpi这一项,是否我需要自己新创建这一项,然后把它加入?2 n/ C- u/ f& J4 o: N( i
不好意思,我刚接触这个,很多都不是很清楚,自己在网上找了好长时间都没有搞清楚,所以只有麻烦楼主了。
* {- R( P% ^. {2 u先谢了!
回复

使用道具 举报

发表于 2009-8-11 14:10:43 | 显示全部楼层
关于第一个问题,我用iasl  device.asl编译没有通过,出现了一个错误:, Q  c/ k  q! b$ F4 `+ i
Error    4095 -                    ^ parse error, expecting `error' or `PARSEOP_DEFINITIONBLOCK'2 b" R3 S2 X; d4 a! Y8 A  j3 u$ t* ]
但是这个device.asl就是DDK自带的。
; p6 j/ m$ G( }6 H& B: R: b第二个问题我直接在cmd里面执行的时候也出现了一个错误:“已加载 acpimof.dll,但没有找到DllRegisterServer输入点,无法注册这个文件。”$ g9 c. ]3 o. P1 W
我在网上下载了一个wmiacpi.sys,请问我可以自己修改注册表,然后将这个驱动加载到系统中么?* y# ]9 M) Y1 U% N& [( h
好迷糊。。。3 q) R9 Z2 N; E% q2 n

+ c, T& J+ W: ^0 J[ 本帖最后由 go_ahead 于 2009-8-11 16:48 编辑 ]
回复

使用道具 举报

 楼主| 发表于 2009-8-11 22:03:52 | 显示全部楼层
to go_ahead:5 B. \- l4 F' y
使用DDK build wmiacpi code.
% r9 m: ~5 ^$ n/ w" N4 ~asl code要包在BIOS code中,所以需要BIOS的源代碼。
7 m' n  e1 B) }9 i0 P0 b( S沒有Wmiacpi選項就自己創建一個。
回复

使用道具 举报

发表于 2009-8-12 09:31:51 | 显示全部楼层
原帖由 peterhu 于 2009-8-11 22:03 发表
2 r8 w1 [' d/ Eto go_ahead:
3 o" Z, T9 d! ~5 u+ J使用DDK build wmiacpi code.6 ?( q$ N; \8 h/ i: H8 H" s
asl code要包在BIOS code中,所以需要BIOS的源代碼。' W' M& I* e. J! j0 o) n
沒有Wmiacpi選項就自己創建一個。
: e6 X) G, P8 B3 w
. }6 k5 o8 |- N5 ^  `: E$ D
谢谢peterhu,今天看到了注册表出现了wmiacpi项了,而且查看acpiscope看到了添加进去的内容了。, ]2 o, T/ a: G% w! V4 M+ ]
但是还是不知道该怎么把dll加入注册表, 今天我再试试也许就出来了
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-6-8 08:32 , Processed in 0.090419 second(s), 19 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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