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

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

[复制链接]
发表于 2009-5-15 15:48:20 | 显示全部楼层 |阅读模式
大家好,我在接案子的时候遇到个bebug :从S4回来可以进入bios setup.- A- ]0 ?. e/ \! P: d, c
我的解法是这样的,在POST的过程中系统检测按键的时候,我加了段代码去判断PM_BASE+04h的BIT10 – bit12是否等于110b。
- p. j8 R8 H1 f, u/ B代码如下:# Z8 s4 U) e; Z) \: T2 H1 p
VOID CheckForKey( EFI_EVENT Event, VOID *Context )
2 E+ P! L( @: _5 G, U% o; V# U/ R{
- V6 u7 Z+ D' f
6 f% S3 Y# s6 u. W2 I+ c/ g………..  
) J! Q$ T# N+ f  UINT8 Data,Data1;) i! N7 ?* r# c+ ?5 o

# O$ y# o9 C4 L( t. @1 F    Status = gBS->LocateProtocol (&gEfiCpuIoProtocolGuid, NULL, &gCpuIo);5 _: ]4 k" q7 _( W7 J$ I& A
     if (EFI_ERROR(Status)) return;# U( v: O+ [  V, r$ Q: S9 c
    Status=gCpuIo->Io.Read (gCpuIo, EfiCpuIoWidthUint8, 0x405 , 1, &Data);  //read PM BASE register 0x05,Get sleep type3 D, V% w7 z" S; E; H% S4 |2 m
        if((Data == 0x18)){# \3 B. Q3 N/ u. @
          return;}% x- n" ~& @1 h8 I- ?. B
……….…….
  e" W/ K& m; X) [# w9 S( H}; |( Q" b% q) y4 W
可是仍然从S4回来可以进入bios setup.
3 w9 U+ _% e  g我想问1。PMBASE是不是在S4回来后被清空?& s6 K6 a8 y8 y' r
       2.是何时被清空的?% }! r2 g0 ?2 Y( d. R1 u
谢谢
发表于 2012-5-28 11:24:42 | 显示全部楼层
Power Management 1 Control Register 这边的register应该在S4状态下就是被清掉的,因为当时已经没有电了,也不用那段code特意的清掉他们,直接没有电了;
) P) q$ C& m$ i8 x( l所以你那code不起作用,你可以在进S4的时候,写systemflag到CMOS,再进行判断!
, B* j! P  N# G/ Q% V个人认为这样oK;
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-11-21 16:48 , Processed in 0.021324 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2023 Discuz! Team.

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