|
发表于 2012-1-5 18:32:42
|
显示全部楼层
见到过最多的就是 , O) \4 x* n: d
WMI ACPI , & W0 b7 V7 F8 p2 q
1. 一般做法都是 BIOS在CODE中定义一个Device, PNP0C14 ?? 记不太清了 ,/ s% l5 k- \, E8 ?$ Z7 Z4 v
2. 然后 OS会为此device 安装提供Driver, 然后BIOS 在这个Device Scope里 实作一些 访问PC 的接口,
4 o, |( o: Z* @: s; y, J 并把这些接口Expose 出去,
% i3 F5 W+ _, s( ?$ O% d 3. 上层应用程式 即可透过这些 接口 访问底层 (直接调用Windows API 即可)$ c* I7 ]; b1 f4 y+ M+ S1 a3 a
很久以前有实际操作过这个过个东西,
B" B) v" c( E 当时也是看了好多好多资料,问了好多人,然后自己拿了一套BIOS code ,实作了一些Interface ,总算明白了一点点了,但是这个东西太多了啊!!!
4 P; k" `6 y1 j H/ P) ~( L 另外,论坛里也有很多资料哦, 可仿照做做
3 Y( _- f* i5 I" u7 I 当然WMI ,决不限于此,我感觉,它的好处是可以不用自己写Driver,就可以透过API访问底层,同时不用考虑兼容性,
" d G1 k+ O7 y Windows 会为你处理好这个,因为是通过Windows driver 来实现的,当然,要做出特殊的客制化功能,还是得BIOS配合一下哦, o$ h& w1 D1 U8 p- f
WMI 和BIOS之间是透过 WMIACPI.sys 来通信+ O; r V% s3 [
另外,如果你发现调用 WMI接口可以访问 EC控制的device ,那么,应该是BIOS中为你做好了 访问EC的interface % L& G. u2 w- f. w) J) T% U3 q% o( N/ @
也可以看看WMI ACPI的白皮书 ,有详细讲解1 Z$ n- g3 Y) e* e5 a" W( c
以上是个人的一些实践总结, 有误请指正,谢谢, w/ ?! T! L+ ^# Y* t, I5 A
& J; k6 x1 x! G3 I( c' i: _; c9 e[ 本帖最后由 蓝色永恒 于 2012-1-5 18:47 编辑 ] |
|