|
|
发表于 2012-1-5 18:32:42
|
显示全部楼层
见到过最多的就是
8 e- S# s1 W" s% I4 C! T S% T WMI ACPI , " C( Y- [; K. L$ I; F7 `* }! C9 s" ~
1. 一般做法都是 BIOS在CODE中定义一个Device, PNP0C14 ?? 记不太清了 ," F& M: y6 q6 l! b9 H1 l( y
2. 然后 OS会为此device 安装提供Driver, 然后BIOS 在这个Device Scope里 实作一些 访问PC 的接口,% n+ p& b* p) {7 a/ x5 U/ [
并把这些接口Expose 出去,
7 m/ O# H1 h' M 3. 上层应用程式 即可透过这些 接口 访问底层 (直接调用Windows API 即可)1 E) d' f- k% i
很久以前有实际操作过这个过个东西,
4 s( y# w8 A4 M0 \/ v/ G5 N, K! d 当时也是看了好多好多资料,问了好多人,然后自己拿了一套BIOS code ,实作了一些Interface ,总算明白了一点点了,但是这个东西太多了啊!!! % l: \) |7 ?8 k" d) D
另外,论坛里也有很多资料哦, 可仿照做做$ ~; l$ ^% ^( X
当然WMI ,决不限于此,我感觉,它的好处是可以不用自己写Driver,就可以透过API访问底层,同时不用考虑兼容性, ( Y! ~( T9 c. j2 ^3 ]* k
Windows 会为你处理好这个,因为是通过Windows driver 来实现的,当然,要做出特殊的客制化功能,还是得BIOS配合一下哦
5 X$ s5 U5 Y; d+ \ WMI 和BIOS之间是透过 WMIACPI.sys 来通信
3 x0 K% Z b! |$ y/ o 另外,如果你发现调用 WMI接口可以访问 EC控制的device ,那么,应该是BIOS中为你做好了 访问EC的interface
, v. [- c/ E* S& ?' c; T1 V 也可以看看WMI ACPI的白皮书 ,有详细讲解8 A1 j7 R7 o, f' N3 j# u) w
以上是个人的一些实践总结, 有误请指正,谢谢& p" P) f- F1 i0 D
* L( Y, t- T1 h! ^0 t* q
[ 本帖最后由 蓝色永恒 于 2012-1-5 18:47 编辑 ] |
|