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

[原创]WMIACPI.SYS

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

5 V9 H( D) ~9 h' t4 u1. WMI Concept8 H, Q7 |3 u3 R. W1 ^

: j' b+ R6 j/ J% i3 E6 m$ `WMI全称Windows Management Instrumentation是一种管理计算机系统的方式。它是微软基于WBEM的实现,WMI希望为系统管理以及分布式数据描述提供一种模型,并且允许使用基于COMuser mode API对系统部件进行访问、管理、控制。
5 f+ J: l5 _1 q! P5 D  q
# D( v" z7 U5 B4 S3 B, R! ]

$ Y/ U# d6 A8 B/ y( U) j2. WMIACPI.SYS
8 [/ Z4 `4 b" t- q2 T% m, ]1 H2 L: P6 i+ i* L
Wmiacpi.sys 是微软提供的一只generic mapping driver它的Plug and Play ID PNP0c14.ACPI包含丰富的系统信息,OEM厂商可以利用这支mapping driver定制平台相关的功能而且允许使用WMI获取,如此便可以在单机或者在网络环境中获得平台的特定信息。关于如何在BIOSOS中定制wmiacpibini已经给出了非常详细的讲解,有兴趣可以参考
bini的文章。在这里我会讲解一下原理部分。ACPI-to-WMI mapping function是通过下述两只driver达成的:
) e3 p2 {" v7 H  U5 VA.Acpi.sys
! t" t8 I$ W! S2 Y% ~! jB.Wmiacpi.sys
3 L- [9 X+ p. @4 R" [7 Z' RA).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获得。) b0 r$ V; D' K9 W8 j- d
B).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 Architecture, \) L/ O% H0 }6 X* e

  w1 e' E( F% |; e0 V& Q
( k( }4 b+ _! p. b1 L% c1 | wmiacpi1.JPG
, t& B% z9 M5 ^9 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再返回具体信息然后逐级回送。/ V: v/ l$ G! ?  y, G

& d- i# M% l! T/ v6 V4 ?- \) Z: L3. Under the hood1 s2 T8 S* e9 `4 A

# N8 L1 l% D4 p9 C前面都是原理的介绍,讲的我都快吐血了J,实践是检验理论的唯一标准。说不如做,随我揭开内幕一探究竟。WDK ver6000 src带了一个wmiacpisamplecodebuild之后会生成一只acpimof.dll,在BIOS里面将device.asl
包进去然后再注册表中加入acpimof.dll的信息然后重启。讲到这里还要提到一个验证wmi的好工具叫做WMICodeCreator.exe微软的网站上有下载,下面我们就使用该tool验证前面的说法,下图2演示了我们定制wmiacpi之后的状况:
: H* H# Y0 y- v# R1 U- _
( c6 e; b0 ^* }" A) m5 A0 E$ V) r! C1 o1 X
wmiacpi2.JPG

. ]9 B. o5 X  \6 z5 ]: ^" y# h* Q" e/ z+ ~
2

; @0 A- E, n1 h) T2红色方框标注的AcpiTest_**就是我们定制的WMI class。也就是OS Load wmiacpi.sys之后将其MOF档案解析出来并加入到WMI repository于是我们就看到了上图的信息。下面我们来跟踪一下访问具体的class的情况吧,祭出WinDbglet’s go!首先查看一下wmiacpi.sys这支driver有没有被加载下图3表明该driver被正常加载了。
; s0 L, G3 A2 P5 @1 v1 c! O  t- O! g
wmiacpi3.JPG
- x* D5 W( Y, N! Q5 Y; e1 o
3

, y/ R- ?  M( A( }( r' n由图3显示与wmi相关的有两个driver:wmilib.syswmiacpi.sys,wmilib.sys是干嘛的呢?别急后续讲述wmi driver的文章会详细介绍它。既然被加载了那我们就要dump wmiacpi.syssymbol看看有哪些有用的信息,这样我们才比较容易下手J。下图4显示了wmiacpi.sys的所有symbol4 w1 Q0 P' L: _. K
- J5 p8 Z; [, p2 D7 A) c$ k# p
wmiacpi4.JPG
9 c8 U. |! f0 D8 l8 S
4
7 @  i; u; _# [) L. [3 Q2 ?: ~
前面我们还讲到wmiacpi.sys最终会调用到acpi.sys访问asl code那我们再看一看acpi.sys有哪些symbol,下图5显示了acpi.sys的所有symbol% [( A$ ^, y6 m9 B1 e
1 D- j. E+ F+ K2 `# q# Z% i
wmiacpi5.JPG
0 E  N# g2 L4 D9 t/ B; `
5

4 ]/ M' z/ q/ ~. O经过分析上述symbol我觉得下述函数很有作案嫌疑,所以将它们秘密监控J都给设上断点,被怀疑的对象如下图6所示:
# A" n' M6 {% @8 W  o1 I  R9 U# a- k
wmiacpi6.JPG
9 n% K# z' l6 J, g7 h" \
6
3 ?  X9 n6 d# C3 T
如图所示:0 [0 k0 f1 g# I) q
9 L0 A* l0 g4 |: E3 _6 T/ ]
wmiacpi!WmiAcpiSetWmiDataItem

: k4 V5 k6 B- s. o1 b  \$ S/ `9 V* g! w2 ?6 W. b
wmiacpi!WmiAcpiSetWmiDataBlock
& t( T& K  q% K5 R$ m9 r2 Y6 l3 C
3 ^, @% h' k; C$ ~0 O$ b
wmiacpi!WmiFireEvent
8 B- @! W' k; b8 z2 ]* a; C

  R8 U& U& y+ J; y3 Hwmiacpi!WmiAcpiQueryWmiDataBlock
. C% m0 e% X0 j/ a7 E' p/ {+ [- W

  I$ `0 ^0 f5 Swmiacpi!WmiAcpiSendAsyncDownStreamIrp

% ~' b/ F+ z; P: t0 o  U
. Z+ X' I8 G: N, H- L, ?wmiacpi!WmiSystemControl

2 i/ S% ]: s1 R4 |% x* y, q- |1 B4 y+ N( C2 o6 c
wmiacpi!WmiAcpiSystemControlDispatch

# X; g. w; ~8 a9 d2 v: f( l( u/ X8 E7 T7 l2 s- Z* Q) `
acpi!ACPIIoctlEvalControlMethod

  U6 O& T: [% j7 W$ {0 z
6 ~% v, L/ B' m: v  Zacpi!ACPIIoctlAsyncEvalControlMethod
2 y- W# N" U; o. B4 b( G3 _2 B
- t" A- r+ o$ K9 ~
acpi!ACPIIoctlAsyncEvalControlMethodEx

" h! n; U8 h4 [4 w( |
( R. V  Y: |! S. e; yacpi!ACPIIoctlEvalControlMethodEx
0 @( L* f+ t0 ~( F; |9 W. e
7 i; T4 g& b6 y  Y6 _5 [
acpi!ACPIButtonDeviceControl
1 T$ H$ X- @( Q, j* k+ }$ h1 j% v+ p
( c* A( V0 }3 r, s! J' t
acpi!ACPIEcInternalControl
6 F) d" h7 S5 S

1 f3 D+ v& l' j, `3 Nacpi!AcpiEmbeddedControllerIrpDispatch

! z) z5 |+ k+ f) ~
% G- g" h! K6 W, h, }* ]7 d+ z' ^acpi!ACPIIrpDispatchDeviceControl

; [" @* l" W1 P& p- F/ q, U/ a+ D5 a7 z, u9 n3 M" B: @
acpi!WmiSystemControl
7 N) ~$ t5 K6 F

' I/ d# X6 H, F这些函数都被设置的断点,下面就我们读写一个class试试看了,图7证实了我之前的所说绝非空口无凭,我们读AcpiTest_MPackage class时发现先会call wmiacpi!WmiAcpiQueryWmiDataBlock,然后acpi!ACPIIrpDispatch DeviceControl会接手,当然后续还会有别的一些动作,但是上述行为就足以支撑我的论点了J
6 b7 g$ d/ I' r; o+ W9 l& O
9 B' v( O1 N' l, B
  @1 P, h" A. V1 l4 L5 n0 F, `8 ~# A- Y0 l. Y" L
wmiacpi7.JPG

. g( v7 E- p( F2 k. B. h
72 D% B$ g' X9 L/ d7 P8 g" c3 q
8演示了我们发一个event的状况,图中显示acpi.sys会接到该event然后透过wmiacpi!WmiFireEvent送给上层AP,上层AP再透过IRP下来qurey其它相关的具体信息。
3 v- g4 F% ^: F9 c4 s" g2 O( ?

) n* v5 m4 |, k1 T' O- |  U4 d# A  {% R2 g5 U- O
wmiacpi8.JPG

9 i2 s* J2 t& j+ M% [
8
% X5 N; B+ f6 [9 A5 ]
以上就是我费尽九牛二虎之力挖掘的wmiacpi.sys的秘密了,再附上一幅我的debug环境J! g- u& k; h7 Y6 j" h

$ J: A& P- x! y% h
3 s3 ~2 e) K; D9 X
wmiacpiA.JPG
4 I; k4 Q5 V% e- G: H) D, ?, S
9
$ X( F; U7 h* c1 f
That’s all!0 ~$ y1 T+ n* B9 ~
Peter 4 n! d' R+ [. m" I
2 s% j! D6 o/ n3 o( [+ `6 ?2 A
[ 本帖最后由 peterhu 于 2009-5-25 09:31 编辑 ]
发表于 2009-5-22 20:27:37 | 显示全部楼层
兄弟说的很详细。, Y1 v2 U+ u3 K1 u3 \( V2 Y
但最终的实现是不是采用MS的那个AP& l5 a8 o, y3 o2 W! y! O  b! J% m
动态生成VBS脚本,然后执行
- ^  f1 C% H9 Z4 {上面Debug中那些内核函数,兄弟你不会是自己做申明吧?
& `9 {" S( V7 |- ]# I刚才骑车时仔细想了一下,觉得用那动态生成脚本是最方便的。
& a+ a1 z. j* p1 D, p如果用COM来访问,我试了去调用,结果总是不能执行。
回复

使用道具 举报

 楼主| 发表于 2009-5-23 11:13:23 | 显示全部楼层
那些内核函数是微软的symbol,怎么可能是我声明的呢?
1 S2 S9 n/ Z# E% y- ]( H使用COM API访问绝对可以,请看这里http://blog.csdn.net/hgf1011/archive/2009/04/14/4073457.aspx+ G# J. t$ B. ?+ C' t4 ?9 f
这是我写的一个tool,使用COM访问.
回复

使用道具 举报

发表于 2009-5-24 10:39:03 | 显示全部楼层
可以了,附件为C++写的一个执行WMI的程序,可以执行ASL代码了。1 R: ^% U  L8 C( G
以前不能执行是我把namespace给弄错了。1 A5 a' d1 V5 y& k9 r0 K0 f4 Q9 }  R( V
谢谢各位。

Using WMI.rar

1.08 KB, 下载次数: 1150

回复

使用道具 举报

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

使用道具 举报

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

使用道具 举报

发表于 2009-8-11 14:10:43 | 显示全部楼层
关于第一个问题,我用iasl  device.asl编译没有通过,出现了一个错误:& `+ s5 C$ ~7 ~: I9 G+ s( N* M. y
Error    4095 -                    ^ parse error, expecting `error' or `PARSEOP_DEFINITIONBLOCK'
! p: o8 S" i: l% V2 {但是这个device.asl就是DDK自带的。
, M4 }( C! R- ]第二个问题我直接在cmd里面执行的时候也出现了一个错误:“已加载 acpimof.dll,但没有找到DllRegisterServer输入点,无法注册这个文件。”* Z" I% `" t" G
我在网上下载了一个wmiacpi.sys,请问我可以自己修改注册表,然后将这个驱动加载到系统中么?
6 r1 }( S# w* i- n+ G; O+ f好迷糊。。。
8 P& v$ L9 T3 n: `. p3 u0 X4 M2 R" `7 ?
[ 本帖最后由 go_ahead 于 2009-8-11 16:48 编辑 ]
回复

使用道具 举报

 楼主| 发表于 2009-8-11 22:03:52 | 显示全部楼层
to go_ahead:0 s# n2 U+ ^: Z! E; ?
使用DDK build wmiacpi code.  j' f& y* T0 O* J
asl code要包在BIOS code中,所以需要BIOS的源代碼。
/ I1 E7 J+ [* [- B3 K沒有Wmiacpi選項就自己創建一個。
回复

使用道具 举报

发表于 2009-8-12 09:31:51 | 显示全部楼层
原帖由 peterhu 于 2009-8-11 22:03 发表
( Y+ e& u3 A* ]5 K4 O0 z  Cto go_ahead:, d( v- b1 ]* v% O; W& {$ h& ?
使用DDK build wmiacpi code.
: f- [( ?  B' p6 Vasl code要包在BIOS code中,所以需要BIOS的源代碼。
! c, B  n* w+ F9 s沒有Wmiacpi選項就自己創建一個。

6 v" y4 G2 @. k, l8 o# h( x
9 C& \# ]9 o7 A: P* x, K! l谢谢peterhu,今天看到了注册表出现了wmiacpi项了,而且查看acpiscope看到了添加进去的内容了。" i. S4 F  i* ?, J% Q( }  a
但是还是不知道该怎么把dll加入注册表, 今天我再试试也许就出来了
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-2-21 09:45 , Processed in 0.078190 second(s), 20 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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