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

bebug :从S4回来可以进入bios setup.

[复制链接]
发表于 2009-5-15 15:48:20 | 显示全部楼层 |阅读模式
大家好,我在接案子的时候遇到个bebug :从S4回来可以进入bios setup.6 I. E# v+ y8 ^3 p* x+ b0 w
我的解法是这样的,在POST的过程中系统检测按键的时候,我加了段代码去判断PM_BASE+04h的BIT10 – bit12是否等于110b。
2 F0 h* p% [# s代码如下:
, E: F+ O2 Z# y4 P3 ]VOID CheckForKey( EFI_EVENT Event, VOID *Context )
' V4 j0 L" u0 Q0 K' T# _( {{
% y: S- ]; c2 s. a; o7 _5 z7 E* R, U( Z- z* G
………..  1 N  D' r" U$ Y& {' x1 [
  UINT8 Data,Data1;
3 y$ }5 U2 f/ |" j6 S0 G) Z) D% F4 }" Q/ E% M( [
    Status = gBS->LocateProtocol (&gEfiCpuIoProtocolGuid, NULL, &gCpuIo);& Y' X* u2 n- h
     if (EFI_ERROR(Status)) return;, |" p/ j. U- m' ~" }) k
    Status=gCpuIo->Io.Read (gCpuIo, EfiCpuIoWidthUint8, 0x405 , 1, &Data);  //read PM BASE register 0x05,Get sleep type& P8 d3 W! \, o
        if((Data == 0x18)){# U7 g5 J. K" u" U' h0 x) w
          return;}/ h0 V8 x% e* a/ a# p
……….…….: ^  p4 S9 b' ~
}
; z1 a6 P2 N- i# ?7 ^  {( e+ t$ I可是仍然从S4回来可以进入bios setup.& r* F- v" \6 d+ |, L1 R
我想问1。PMBASE是不是在S4回来后被清空?
. ?/ `  p3 X; D       2.是何时被清空的?
& T) ?; o7 h- }3 j5 ^3 t谢谢
发表于 2012-5-28 11:24:42 | 显示全部楼层
Power Management 1 Control Register 这边的register应该在S4状态下就是被清掉的,因为当时已经没有电了,也不用那段code特意的清掉他们,直接没有电了;
3 W- V: ^5 v5 `+ {2 l. K  j所以你那code不起作用,你可以在进S4的时候,写systemflag到CMOS,再进行判断!
6 d9 C4 M& h2 `, n7 a' d& Q! {个人认为这样oK;
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-6-13 07:06 , Processed in 0.074722 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2023 Discuz! Team.

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