找回密码
 加入计匠网
搜索
热搜: BIOS ACPI CPU Windows
查看: 42619|回复: 19

请教如何实现在VC里读取ACPI table数据

[复制链接]
发表于 2008-6-16 16:18:26 | 显示全部楼层 |阅读模式
小弟想用VC开发一个工具,能读到ACPI 区域里的数据,比如系统温度(如intel TAT 工具),电池信息等数据。请教各位知道用什么接口函数能实现,小弟对ACPI不是很清楚,不知道上述描述是否准确?谢谢!
发表于 2008-6-16 17:20:50 | 显示全部楼层
我先跟你讲讲温度,知道这些温度从何而来,见Intel TAT温度里show的。! ]; o# h8 K. G: E" I( r7 ^$ V
1、ACPI 温度
1 f/ U# f, y/ }0 h4 \( s, G    这个温度是ACPI spec温度(请看ACPI SPEC),操作系统跟据此温度来选择不同的散热方案,也就是ACPI ThermalZone 提供给OS的温度有:throttling temp,Critical temp,currect temp,TAT所显示的就是currect temp。此温度的由来,一般是由EC提供,EC通过SMBUS读取CPU/System thermal sensor的温度,CPU/System thermal sensor 会通过AD转换,去读取CPU&System的温度感应器。(CPU为一个温敏二极管,Intel 一个物理CPU,就会有一个)。此部分温度从何读?自己决定,ACPI?可以,自己写驱动或用WMI,EC?看你平台是不是这样设置的,CPU&SYSTEM的Thermal Sensor,也可的,看你的平台。
" \; }9 m/ v/ p) d: M2、DTS温度(Digital Thermal Sensor)
2 b3 Y8 e- a, a( S$ o  w    这个温度是CPU自己提供的温度,直接去MSR里去读取即可,一般(只能说一般,好象看到有双CPU只有一个Digital Thermal Sensor的)一个核就有一个Thermal,所以双核基本上是有TM1,TM2。当然,在读之前要把CPU的Thermal打开,把系数设好,具体见CPU的Spec。当然也有把DST温度直接返回给ACPI ThermalZone的情况。
3 F1 k. ]! x$ S1 [8 G( L+ ^* r- ~2 \& j. C
SO,你要读取什么?如是温度,那么就搞清楚温度的来源,如果是电池数据,有Windows的API可以获取,如是ACPI Table数据,那么就在内存中,可以通过Windows API & Driver & WMI各种方式去获取,因为ACPI里的东西是for系统不同的Device或不同的用途的,关键是搞清楚自己要什么。
回复

使用道具 举报

 楼主| 发表于 2008-6-17 08:47:24 | 显示全部楼层
感谢bini大侠非常详细的解答!我的程序想实现的功能是这样的:在xp或者vista下运行的程序能读到EC里特定的数据,如LCD屏的背光值,EC读到的温度等。不知道bini说的Windows API & Driver & WM各种获取方法是如何实现的,可否提供一些详细的资料给小弟参考。
回复

使用道具 举报

发表于 2008-6-17 09:07:59 | 显示全部楼层
那你的问题,说起来,跟ACPI是没多少关系,但用ACPI的方法,也是会让系统最稳定,也是最适合用acpi windows程序开发,如低难度的就是WMI ACPI,见DDK中带的WMI-ACPI白皮书。API可以获取电池,CPU,等相关信息的。驱动,你可以建立自己的pnp device驱动来获取,如仅仅是EC里的数据,何必呢,用IO读写就可以,只要你知道如何读EC的space。予人鱼,不好呀,渔才好。
5 ?+ ], c8 S& y/ R1、其中WMI-ACPI最简单,但是BIOS得配合,推荐。
- R& e* R8 R& Q! a; e2、Driver最复杂,也需要BIOS配合,推荐。
, P5 G# `3 _" r4 v$ W8 Z6 i; M6 \. y9 `3、Windows API只能获取到特定信息,不需要特定的BIOS配合。
* _' }2 V7 t0 p6 W: n+ A* s4、IO的方法,能获取到全部的EC状态信息,需要EC的文档,如果是给for end user,要出货的程序,这种方式不推荐。; [) X$ t& S! i0 l7 |% ?" m$ s, X4 I
你可以混合使用。
回复

使用道具 举报

 楼主| 发表于 2008-6-17 11:07:12 | 显示全部楼层
IO方法读EC当然是最简单的,但是好像在windows下也不能直接这么用IO读写,还是要写driver的吧?
! N, W2 w3 Y; [+ b1 U! U( }! r; F; X, w. E/ M+ a
另:如果要想做调节音量和背光的OSD,是不是可以用WMI-ACPI方法来实现?
回复

使用道具 举报

发表于 2008-6-17 11:11:54 | 显示全部楼层
windows下IO读写可以使用WINIO组件,兼容XP/VISTA,很方便,不过LZ还要准备EC的相关SPEC哦
回复

使用道具 举报

发表于 2008-6-17 11:27:57 | 显示全部楼层
Dear Frank,估计你在做NB的APP,WMI-ACPI方法当然可以实现。但是WMI的Event产生的方式是基于Pooling的,也就是主动check,会占用一小小点的CPU时间,同时事件的捕获也不是太及时(WMI中可调Pooling的频率),没有pnp device的那种在ACPI里notify driver的方式好,也就是BIOS去产生PM事件,OS的程序与Driver处于被动,这样就不会占用CPU一些时间,同事实时性也更好。但WMI-ACPI对于NB的小APP程序是够用的。
回复

使用道具 举报

 楼主| 发表于 2008-6-17 11:30:13 | 显示全部楼层
多谢amty,WINIO我之前只知道有xp下的,现在有兼容vista的出来吗?
( Y; l( v& k: _1 D/ Z0 A# n1 {关于EC的SPEC我有的,俺是做EC的。
回复

使用道具 举报

发表于 2008-6-17 11:33:32 | 显示全部楼层
是为了debug EC的话,就用WINIO吧,WINIO在VISTA下可用。记得好象需要重新用DDK(for 2003 server?)编译一下。还有一个地方是在64位CPU上需要修改一个地方...嘿嘿...这是Owen的密秘。
回复

使用道具 举报

 楼主| 发表于 2008-6-17 11:41:03 | 显示全部楼层
Dear bini,你说的没错,俺是在写NB的APP,你说用pnp device的那种在ACPI里notify driver的方法,那我不是还要写个driver?如果用SCI的方式做notice,你看怎么样?
回复

使用道具 举报

发表于 2008-6-17 11:44:10 | 显示全部楼层
这个随你呀。具体怎么设计,就是你的工作啦。不过,你要搞清楚,SCI是一个中断,我指的Notify是ACPI中的Notify driver的function。见acpi spec中的notify function.
回复

使用道具 举报

发表于 2008-6-17 13:08:44 | 显示全部楼层
原帖由 bini 于 2008-6-17 09:07 发表
9 A& Z2 I- N0 m& \那你的问题,说起来,跟ACPI是没多少关系,但用ACPI的方法,也是会让系统最稳定,也是最适合用acpi windows程序开发,如低难度的就是WMI ACPI,见DDK中带的WMI-ACPI白皮书。API可以获取电池,CPU,等相关信息的。驱动,你可以建立自己的p ...
8 O2 C7 ]2 x; P$ o/ t2 A' b& E
很全面,学习...
回复

使用道具 举报

发表于 2008-6-17 13:16:14 | 显示全部楼层
WINIO在VISTA下可以直接用的,不需要去重新编译, m; p/ F9 c' C  X/ }
        [DllImport("winio.dll")]
  I$ [5 Y! {! t        public static extern bool InitializeWinIo();* {. n" a' ^" ]# p4 j
        [DllImport("winio.dll")]1 C2 t" u1 l( s
        public static extern bool GetPortVal(IntPtr wPortAddr, out int pdwPortVal, byte bSize);* C) w/ r) s! }7 o3 p3 d
        [DllImport("winio.dll")]6 e1 Z7 _  _) O5 I, b5 D
        public static extern bool SetPortVal(uint wPortAddr, IntPtr dwPortVal, byte bSize);4 W0 K, C& n& G3 L3 |
        [DllImport("winio.dll")]
2 Z9 w" `' n: w0 W: K  c        public static extern byte MapPhysToLin(byte pbPhysAddr, uint dwPhysSize, IntPtr PhysicalMemoryHandle);: W8 n( `/ a) U3 f1 T$ m5 ]$ C. }  M
        [DllImport("winio.dll")]& A$ O  V- g9 @$ X% N& _. O
        public static extern bool UnmapPhysicalMemory(IntPtr PhysicalMemoryHandle, byte pbLinAddr);
% c( m4 U1 |# @        [DllImport("winio.dll")]3 n# }9 g7 L1 n  I
        public static extern bool GetPhysLong(IntPtr pbPhysAddr, byte pdwPhysVal);! B: J+ ^5 u) E& k$ s6 f
        [DllImport("winio.dll")]
* W) `/ \0 P% M+ o% s/ y" ^: Y        public static extern bool SetPhysLong(IntPtr pbPhysAddr, byte dwPhysVal);
# X/ w( Q. o* s3 \* e        [DllImport("winio.dll")]
* u0 p  g5 P  a  Y        public static extern void ShutdownWinIo();
回复

使用道具 举报

发表于 2008-9-24 14:05:23 | 显示全部楼层
原帖由 bini 于 2008-6-17 09:07 发表 ; d6 U+ D  p/ a3 j- ~" t; ]6 S$ Y
那你的问题,说起来,跟ACPI是没多少关系,但用ACPI的方法,也是会让系统最稳定,也是最适合用acpi windows程序开发,如低难度的就是WMI ACPI,见DDK中带的WMI-ACPI白皮书。API可以获取电池,CPU,等相关信息的。驱动,你可以建立自己的p ...
# f. ]# o2 ^. h
2 ^( Q1 U' {, m" g6 ~, t
- b- U! @  W% j
为什么bini不推荐使用 I/O 读EC的方式?
回复

使用道具 举报

发表于 2008-10-18 15:49:09 | 显示全部楼层
原帖由 bini 于 2008-6-17 11:33 发表 5 ^4 O( ]# e# e/ y8 b' ?' f0 \
是为了debug EC的话,就用WINIO吧,WINIO在VISTA下可用。记得好象需要重新用DDK(for 2003 server?)编译一下。还有一个地方是在64位CPU上需要修改一个地方...嘿嘿...这是Owen的密秘。 ...

6 x$ S) A* }! e6 g% K* P; z. s' O8 m" i  V
64位需要改什么啊,可否赐教一下? 不想公开的话,可不可以用短信....
回复

使用道具 举报

发表于 2008-10-22 09:21:05 | 显示全部楼层
原帖由 bini 于 2008-6-17 11:33 发表
- p& `0 H1 t( W5 U) E是为了debug EC的话,就用WINIO吧,WINIO在VISTA下可用。记得好象需要重新用DDK(for 2003 server?)编译一下。还有一个地方是在64位CPU上需要修改一个地方...嘿嘿...这是Owen的密秘。 ...
2 d3 d! c& t( c- E5 R

" H8 C  ?6 f! T# PWINIO读 IO port使用了几个Undocument的API,只能在i386下使用,X64不再支持这些API了,要在64位上用,恐怕不是修改一个地方的问题吧。我是自己写了一个驱动,不但读取IO,memory,顺便读MSR,PMC,TSC之类的~~~~
回复

使用道具 举报

发表于 2008-10-22 09:40:55 | 显示全部楼层
WINIO的驱动很小,可以用IDA看看,东西不是很多。# P( D5 d, \7 W4 |

7 o% ^& |% \4 A! `用Winio读Acpi table很方便,我已经实现了一个
回复

使用道具 举报

发表于 2008-11-26 16:13:25 | 显示全部楼层
一些WMI的东西,见:BIOS点滴Follow Bini系列之---WMI ACPI % L" g( A$ `# U, z9 E! J  l
http://www.ufoit.com/bbs/thread-420-1-1.html
回复

使用道具 举报

发表于 2009-9-4 17:49:57 | 显示全部楼层
太强了   。。。。。。。。
回复

使用道具 举报

发表于 2010-10-22 09:36:21 | 显示全部楼层
原帖由 bini 于 2008-6-17 09:07 发表
/ Q+ s" M4 R/ H1 P7 F2 }6 N7 u那你的问题,说起来,跟ACPI是没多少关系,但用ACPI的方法,也是会让系统最稳定,也是最适合用acpi windows程序开发,如低难度的就是WMI ACPI,见DDK中带的WMI-ACPI白皮书。API可以获取电池,CPU,等相关信息的。驱动,你可以建立自己的p ...

7 c& S+ e6 p$ s# c! t" e$ K$ l! a* _& a: \7 _% K( A9 S# v2 r3 P2 M
既然可以用IO方式訪問全部,為什么還存在wmi interface的訪問方式呢?
3 U4 T" [& Y5 y( cEC 3rd IO 可以在windowns可以訪問EC全部資料嗎?EC 3rd IO 是指68/6C 端口嗎?如果要通過EC 3rd IO為什么IBF、OBF為什么一直通不過?
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 加入计匠网

本版积分规则

Archiver|手机版|小黑屋|计匠网

GMT+8, 2024-11-21 20:04 , Processed in 0.027759 second(s), 16 queries .

Powered by Discuz! X3.5

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表