|
|
发表于 2012-1-5 18:32:42
|
显示全部楼层
见到过最多的就是
# z+ v( E" w* W WMI ACPI , ) B0 g& ^- W. H' Q X! _/ c% C
1. 一般做法都是 BIOS在CODE中定义一个Device, PNP0C14 ?? 记不太清了 ,
- v [+ R' g0 W! n5 _ 2. 然后 OS会为此device 安装提供Driver, 然后BIOS 在这个Device Scope里 实作一些 访问PC 的接口,
; ?) c$ X% x2 [* T& _ 并把这些接口Expose 出去, 2 U) }: I9 ]# i; _9 W
3. 上层应用程式 即可透过这些 接口 访问底层 (直接调用Windows API 即可)
8 {& v. @7 p7 \' S1 M9 X2 y4 ^ 很久以前有实际操作过这个过个东西,
( L8 k9 F# R v' X- a3 v 当时也是看了好多好多资料,问了好多人,然后自己拿了一套BIOS code ,实作了一些Interface ,总算明白了一点点了,但是这个东西太多了啊!!! . t3 B( [5 \2 c4 |( d
另外,论坛里也有很多资料哦, 可仿照做做
! G+ o" Q! i2 q) I1 | 当然WMI ,决不限于此,我感觉,它的好处是可以不用自己写Driver,就可以透过API访问底层,同时不用考虑兼容性,
& D0 ] S s$ U, M' O& c Windows 会为你处理好这个,因为是通过Windows driver 来实现的,当然,要做出特殊的客制化功能,还是得BIOS配合一下哦
+ x' @, i) d+ v" H WMI 和BIOS之间是透过 WMIACPI.sys 来通信% \# y; ~# C) O$ z; c- b
另外,如果你发现调用 WMI接口可以访问 EC控制的device ,那么,应该是BIOS中为你做好了 访问EC的interface , K# k9 w( ?* z" s; L5 {
也可以看看WMI ACPI的白皮书 ,有详细讲解# N: @. e0 k! Z, K0 e
以上是个人的一些实践总结, 有误请指正,谢谢. U1 W, o$ e( Y/ L9 G8 T
8 G' A5 H& p7 A+ z, n! K- e[ 本帖最后由 蓝色永恒 于 2012-1-5 18:47 编辑 ] |
|