|
发表于 2012-1-5 18:32:42
|
显示全部楼层
见到过最多的就是
# c* f) }! o* f7 l: l# [8 o WMI ACPI ,
, R' c( L( }* h* k 1. 一般做法都是 BIOS在CODE中定义一个Device, PNP0C14 ?? 记不太清了 ,
9 J. p. o* s7 n 2. 然后 OS会为此device 安装提供Driver, 然后BIOS 在这个Device Scope里 实作一些 访问PC 的接口,$ Y! t# U$ w, v; O. A1 d- J& [( c
并把这些接口Expose 出去, ! |% D4 g% Z2 Q1 o
3. 上层应用程式 即可透过这些 接口 访问底层 (直接调用Windows API 即可)4 b0 ?: y" A. P' e( @3 T7 T, j
很久以前有实际操作过这个过个东西,
9 J6 z6 W4 }1 g$ G+ n 当时也是看了好多好多资料,问了好多人,然后自己拿了一套BIOS code ,实作了一些Interface ,总算明白了一点点了,但是这个东西太多了啊!!! - u9 T; i+ w# C! w/ A( K
另外,论坛里也有很多资料哦, 可仿照做做
/ Y0 {, Z7 w d2 M1 C5 m w! S$ j' q 当然WMI ,决不限于此,我感觉,它的好处是可以不用自己写Driver,就可以透过API访问底层,同时不用考虑兼容性,
4 ~2 ^6 L7 A1 z# `8 _ Windows 会为你处理好这个,因为是通过Windows driver 来实现的,当然,要做出特殊的客制化功能,还是得BIOS配合一下哦
# v% D7 ]/ @( B WMI 和BIOS之间是透过 WMIACPI.sys 来通信' T( H& |: K6 e$ _; \
另外,如果你发现调用 WMI接口可以访问 EC控制的device ,那么,应该是BIOS中为你做好了 访问EC的interface
7 s" R" t; t* h8 L! K4 H 也可以看看WMI ACPI的白皮书 ,有详细讲解) ]3 o$ I( b" ^9 O" w
以上是个人的一些实践总结, 有误请指正,谢谢6 W8 P2 ?0 \' i2 h, Y
" X4 Q D1 a* G5 h* K3 y[ 本帖最后由 蓝色永恒 于 2012-1-5 18:47 编辑 ] |
|