|
|
发表于 2012-1-5 18:32:42
|
显示全部楼层
见到过最多的就是
5 \3 x5 h7 p& G4 G& F8 C( W) T WMI ACPI , 4 Y$ f3 G& e6 ^7 S4 i4 N7 z
1. 一般做法都是 BIOS在CODE中定义一个Device, PNP0C14 ?? 记不太清了 ,
' I O2 N" u0 Q5 t# R 2. 然后 OS会为此device 安装提供Driver, 然后BIOS 在这个Device Scope里 实作一些 访问PC 的接口," J' V2 V3 ?* n* Y
并把这些接口Expose 出去, , q# }- h, D2 f) K4 W+ C
3. 上层应用程式 即可透过这些 接口 访问底层 (直接调用Windows API 即可)" n$ C. I* i* I+ Q
很久以前有实际操作过这个过个东西,2 z+ p% [6 S6 E0 i. w! w( n
当时也是看了好多好多资料,问了好多人,然后自己拿了一套BIOS code ,实作了一些Interface ,总算明白了一点点了,但是这个东西太多了啊!!! ; x; J W9 `! m* X t
另外,论坛里也有很多资料哦, 可仿照做做
+ F. x: l2 u9 G 当然WMI ,决不限于此,我感觉,它的好处是可以不用自己写Driver,就可以透过API访问底层,同时不用考虑兼容性,
% x0 n* v7 N0 q- _; a8 Z1 R/ G Windows 会为你处理好这个,因为是通过Windows driver 来实现的,当然,要做出特殊的客制化功能,还是得BIOS配合一下哦
% }3 v7 U1 A' B+ O WMI 和BIOS之间是透过 WMIACPI.sys 来通信
& Y% B A* l' {( n9 w3 ]* d* K 另外,如果你发现调用 WMI接口可以访问 EC控制的device ,那么,应该是BIOS中为你做好了 访问EC的interface
8 `' B$ f, d5 Y! ]( U+ A6 m 也可以看看WMI ACPI的白皮书 ,有详细讲解0 ^/ s# n$ u7 e, E b- X/ Z
以上是个人的一些实践总结, 有误请指正,谢谢
( V; g0 {9 \1 S5 ^* \6 m( u0 n& j& K" d& b6 @$ n M- j/ J7 A% g
[ 本帖最后由 蓝色永恒 于 2012-1-5 18:47 编辑 ] |
|