|
发表于 2012-1-5 18:32:42
|
显示全部楼层
见到过最多的就是
1 a; O" T4 \, p$ M) h WMI ACPI , $ v; }! ]1 K+ A6 t
1. 一般做法都是 BIOS在CODE中定义一个Device, PNP0C14 ?? 记不太清了 ,
7 E- f: _/ ]/ m 2. 然后 OS会为此device 安装提供Driver, 然后BIOS 在这个Device Scope里 实作一些 访问PC 的接口,& \9 t) T/ R: m+ h& f1 F
并把这些接口Expose 出去, , C% w1 ~0 p/ [; S$ g1 f
3. 上层应用程式 即可透过这些 接口 访问底层 (直接调用Windows API 即可)
) T' o" F U5 p7 Y 很久以前有实际操作过这个过个东西,1 ~" M" u% M) g+ {' u- A4 O
当时也是看了好多好多资料,问了好多人,然后自己拿了一套BIOS code ,实作了一些Interface ,总算明白了一点点了,但是这个东西太多了啊!!!
( v5 G2 X; V& p4 g/ u 另外,论坛里也有很多资料哦, 可仿照做做
, G& ~! J" {: `& S) o 当然WMI ,决不限于此,我感觉,它的好处是可以不用自己写Driver,就可以透过API访问底层,同时不用考虑兼容性, , ?4 \; d6 h9 G; b
Windows 会为你处理好这个,因为是通过Windows driver 来实现的,当然,要做出特殊的客制化功能,还是得BIOS配合一下哦% b- }0 G t1 Q
WMI 和BIOS之间是透过 WMIACPI.sys 来通信+ c$ _7 z! h9 z c+ [
另外,如果你发现调用 WMI接口可以访问 EC控制的device ,那么,应该是BIOS中为你做好了 访问EC的interface
6 U( K) o/ W" x9 K3 D& b 也可以看看WMI ACPI的白皮书 ,有详细讲解
. S/ f' e0 Z: d5 s+ M p/ x; D& j# \" N以上是个人的一些实践总结, 有误请指正,谢谢
' v7 z2 R2 L4 x1 o% i% |( a6 }! F* |0 k ?! ^
[ 本帖最后由 蓝色永恒 于 2012-1-5 18:47 编辑 ] |
|