|
|
发表于 2012-1-5 18:32:42
|
显示全部楼层
见到过最多的就是
8 D2 o! B& B. q3 n# ^3 b* a' R5 F2 \ WMI ACPI , ( j+ h, m, N" }) j* o/ {" o
1. 一般做法都是 BIOS在CODE中定义一个Device, PNP0C14 ?? 记不太清了 ,
( w2 p- L! Q/ F' ` 2. 然后 OS会为此device 安装提供Driver, 然后BIOS 在这个Device Scope里 实作一些 访问PC 的接口,
1 L$ I, l9 v: R" B- }: e" ? 并把这些接口Expose 出去,
* A$ G& X* P; j+ d& W 3. 上层应用程式 即可透过这些 接口 访问底层 (直接调用Windows API 即可)
6 h/ b2 H& W w, j 很久以前有实际操作过这个过个东西,7 P+ j- G# F7 |. m" C
当时也是看了好多好多资料,问了好多人,然后自己拿了一套BIOS code ,实作了一些Interface ,总算明白了一点点了,但是这个东西太多了啊!!!
% l7 V" [# v/ K4 M 另外,论坛里也有很多资料哦, 可仿照做做7 }! k8 E: |, ^
当然WMI ,决不限于此,我感觉,它的好处是可以不用自己写Driver,就可以透过API访问底层,同时不用考虑兼容性, & K c7 y, \& H' H% W
Windows 会为你处理好这个,因为是通过Windows driver 来实现的,当然,要做出特殊的客制化功能,还是得BIOS配合一下哦+ m7 J" { z4 _; ]8 i* d, k0 d1 f
WMI 和BIOS之间是透过 WMIACPI.sys 来通信
Y: A1 f4 c2 i3 {0 m' ~ 另外,如果你发现调用 WMI接口可以访问 EC控制的device ,那么,应该是BIOS中为你做好了 访问EC的interface
6 N: S2 s/ v* E5 \1 _) w! { 也可以看看WMI ACPI的白皮书 ,有详细讲解2 ~. _4 ]2 S& d' }- E ` [! T: X
以上是个人的一些实践总结, 有误请指正,谢谢
5 y; R6 U+ ^4 z3 k2 e& h3 B* ]2 J8 {# n0 P! q
[ 本帖最后由 蓝色永恒 于 2012-1-5 18:47 编辑 ] |
|