|
发表于 2012-1-5 18:32:42
|
显示全部楼层
见到过最多的就是 Z1 n* B' A* U
WMI ACPI ,
Q" b+ B/ u! M4 J3 W- { 1. 一般做法都是 BIOS在CODE中定义一个Device, PNP0C14 ?? 记不太清了 ,
3 G. ]4 r1 p9 |+ G 2. 然后 OS会为此device 安装提供Driver, 然后BIOS 在这个Device Scope里 实作一些 访问PC 的接口,
+ d$ ]! w( H6 f# ? 并把这些接口Expose 出去, 1 G5 G+ z3 R" M) [+ X
3. 上层应用程式 即可透过这些 接口 访问底层 (直接调用Windows API 即可)# W! _6 m$ l" q' L2 H
很久以前有实际操作过这个过个东西,# N; W4 [# G" a1 a
当时也是看了好多好多资料,问了好多人,然后自己拿了一套BIOS code ,实作了一些Interface ,总算明白了一点点了,但是这个东西太多了啊!!! + m0 s2 f0 r$ i" v/ H
另外,论坛里也有很多资料哦, 可仿照做做1 p& J" w/ e) g: B" k. y
当然WMI ,决不限于此,我感觉,它的好处是可以不用自己写Driver,就可以透过API访问底层,同时不用考虑兼容性, : B/ }" Z$ U# W
Windows 会为你处理好这个,因为是通过Windows driver 来实现的,当然,要做出特殊的客制化功能,还是得BIOS配合一下哦
5 Z/ k* {$ [2 B, X WMI 和BIOS之间是透过 WMIACPI.sys 来通信0 H; Z: f& d- N* h T
另外,如果你发现调用 WMI接口可以访问 EC控制的device ,那么,应该是BIOS中为你做好了 访问EC的interface
6 }, L8 n: c( Q( D- _( R% h1 N 也可以看看WMI ACPI的白皮书 ,有详细讲解
' u9 B* U' O! x9 W( b8 g以上是个人的一些实践总结, 有误请指正,谢谢
7 i! w( j9 K7 d; {+ V$ r
" i6 L' W% q; j$ I- K: a# {. R[ 本帖最后由 蓝色永恒 于 2012-1-5 18:47 编辑 ] |
|