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

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

[复制链接]
发表于 2009-5-15 15:48:20 | 显示全部楼层 |阅读模式
大家好,我在接案子的时候遇到个bebug :从S4回来可以进入bios setup.
3 i/ E1 \$ G& {* V' s2 p我的解法是这样的,在POST的过程中系统检测按键的时候,我加了段代码去判断PM_BASE+04h的BIT10 – bit12是否等于110b。
2 v2 T; ~* e, E* S6 d$ g+ o代码如下:: H! |1 o. g! C( x+ P
VOID CheckForKey( EFI_EVENT Event, VOID *Context )% ?. _! s  S& o
{
  O+ G! C( [# K* k( j: J( c+ |. C9 R5 b; y
………..  
' q6 A; D. `! t: U  UINT8 Data,Data1;
: r: U& {: ^! f/ Q# |' g) ]; U/ x. v" i( o0 e% I& ~4 S
    Status = gBS->LocateProtocol (&gEfiCpuIoProtocolGuid, NULL, &gCpuIo);
4 w1 b% W0 G' U: N" j9 R     if (EFI_ERROR(Status)) return;
  G5 z! e, O6 }& Y8 J5 o! P    Status=gCpuIo->Io.Read (gCpuIo, EfiCpuIoWidthUint8, 0x405 , 1, &Data);  //read PM BASE register 0x05,Get sleep type% d( l6 I) g/ Y4 i! [, f! C; i
        if((Data == 0x18)){8 e5 }5 K& T# {( ~
          return;}
9 `( P; G8 r( p' B& F……….…….+ P1 t0 ^& }% L/ Q3 F1 E7 h
}
5 R# T2 R$ ^- r可是仍然从S4回来可以进入bios setup.
# _! P  ~- D$ x$ m# p  N1 d$ B2 w- H5 r我想问1。PMBASE是不是在S4回来后被清空?
$ p& v0 W; m5 e8 U% I8 d       2.是何时被清空的?
. E9 q& I+ D: _$ i0 e3 k" ?5 U谢谢
发表于 2012-5-28 11:24:42 | 显示全部楼层
Power Management 1 Control Register 这边的register应该在S4状态下就是被清掉的,因为当时已经没有电了,也不用那段code特意的清掉他们,直接没有电了;- e: t$ ]) L" ]* F# _/ x2 H
所以你那code不起作用,你可以在进S4的时候,写systemflag到CMOS,再进行判断!5 B, f. @9 o$ O6 q: h
个人认为这样oK;
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-12-1 07:52 , Processed in 0.129897 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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