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

请教我这样把系统放到C4为何不行?

[复制链接]
发表于 2008-10-17 17:49:46 | 显示全部楼层 |阅读模式
因为系统要在某个特定的情况下需要特别省电,然后回来要特别快所以没有办法用S3,我现在想了个办法是, 要进到这个特殊的用户使用模式的时候触发SMI,在SMI handler 里面通过一个while(1)循环把cpu放到C4。 为了从这个特定的模式返回所以在这个循环中会在每次从C4因为interrupt而返回的时候检查 ICH 的某个GPIO,如果电平没有变化那么就继续把CPU放到C4,否则的话就从 SMI handler 返回。 而这个GPIO从L到H也是用户按键,通过EC firmware 来做的。
9 M$ P) L% k; g5 ?& F
; M8 w9 l4 s) k! o! ~2 `现在的问题是: 持续的把CPU 放到C4 我从数字电源上看到的功耗并没有丝毫的下降。。。
" @- H2 l/ `: [$ V$ G* s' W  X/ ?; W. Y9 `
不解是为何? 按照c4的说法至少CPU这边的能耗是会下来一些的呀。& _7 Y- f  r- s
7 s$ G7 w, T, y6 y
另外想求教论坛的前辈,有没有其他的办法事先我所需要的这个功能就是在某种情况下shutdown CPU/Chipset,让系统的功耗降得尽可能的低,同事要保证系统恢复到原始状态的延迟小于10ms。
发表于 2008-10-17 18:48:25 | 显示全部楼层
为什么不用S1?
回复

使用道具 举报

发表于 2008-10-18 00:46:06 | 显示全部楼层
我倒想听听你所谓SMI中的while(1)是如何进入C4的。哈哈,狂抓
9 B" f6 a* c+ n+ [+ {  }3 J3 @$ E8 M典型的是让马儿跑,又不让马儿吃草。& [; _! A0 x. T+ ~) x5 x# Z

! ^0 c9 a4 `' U- L同意xtdumpling同学的,用S1,对速度没太大的要求,就用S3。
回复

使用道具 举报

 楼主| 发表于 2008-10-22 09:29:52 | 显示全部楼层
>>> 我倒想听听你所谓SMI中的while(1)是如何进入C4的。哈哈,狂抓4 w  @$ a7 ?3 m+ D" d

6 ?6 m7 E/ I9 lSMI_Handler() {, E- x3 a- J7 d9 `8 W
while( 1 ) {2 K4 j. a' p& J! P
    read_ACPI_LVL4();  //  <---- CPU into C4.
6 E; f6 c- v2 B3 h! [                       //  Interrupts or breakup events take CPU out of C4;) J+ x! I1 z7 o" T
    if( GPIO_is_High() ) + v$ P; u% j$ n& a% {+ M
       break;6 e+ ~2 O, V# i' r& h+ T
}
7 V, U* O8 m+ ?: W}1 H# Q1 @5 I/ N- }
有什么不对吗? 8 `  G# I$ C6 y0 Q! K
' Y8 r5 t1 F$ x, W. Q' X! |
现在的问题是,用示波器观察STP_CLK/STP_CPU 等pin都没有发现assert,另外进到C4 按道理cpu应该会发VID 给VR 的结果也没有看到,不知为何。 是因为在SMI 里面写LVL3/4 register 不会让CPU 进入到C4吗?3 K, o* e1 u7 H* J

! q& T8 q9 V: v6 ~5 U* u2 v另外请教,让系统进入到S1然后返回的延时大概是什么样子? 可否达到要求?2 |7 k5 ^! i, K. x8 f9 N1 B! A% T
还请大侠多指点几句。。。 不要抓狂。。
8 a7 L% ?$ u: k5 ]* }: U! s
7 i9 N+ s$ ^% o/ X1 U0 k  m7 D1 @! h[ 本帖最后由 1点0 于 2008-10-22 09:36 编辑 ]
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-12-1 08:37 , Processed in 0.075670 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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