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

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

[复制链接]
发表于 2009-5-15 15:48:20 | 显示全部楼层 |阅读模式
大家好,我在接案子的时候遇到个bebug :从S4回来可以进入bios setup.9 [; D, j% a1 r3 l6 o. _
我的解法是这样的,在POST的过程中系统检测按键的时候,我加了段代码去判断PM_BASE+04h的BIT10 – bit12是否等于110b。
6 N  [, i3 p- X( Z! O代码如下:
3 ?: J% M1 Q/ cVOID CheckForKey( EFI_EVENT Event, VOID *Context )! M6 n. |! X8 }; D
{% n4 o5 c: l/ _: G; T8 v

( x" N: a; B& W* A………..  7 C7 f! @4 E" L6 X5 H! ^$ s
  UINT8 Data,Data1;
& w4 ?4 u7 v% u+ y8 }9 C& `9 [8 \9 J  h& a  _& ~
    Status = gBS->LocateProtocol (&gEfiCpuIoProtocolGuid, NULL, &gCpuIo);% A* H" m- A6 r3 ^; u9 B1 T
     if (EFI_ERROR(Status)) return;, v  N. ]( v6 J( ?8 ~
    Status=gCpuIo->Io.Read (gCpuIo, EfiCpuIoWidthUint8, 0x405 , 1, &Data);  //read PM BASE register 0x05,Get sleep type) ~5 m$ ~! R. R' g% |* R
        if((Data == 0x18)){
- j" u$ B* c- r( S          return;}
- W+ z/ l* E6 r4 m2 J# z% E+ y……….……., m/ x: t3 Z- s+ H+ d2 b' K
}0 t3 x' Y6 h3 F* @" s
可是仍然从S4回来可以进入bios setup.# S+ z' Q# E$ a
我想问1。PMBASE是不是在S4回来后被清空?" \% j5 |3 {8 p: A& `+ s
       2.是何时被清空的?
# Z+ R' u5 H' t# C7 I谢谢
发表于 2012-5-28 11:24:42 | 显示全部楼层
Power Management 1 Control Register 这边的register应该在S4状态下就是被清掉的,因为当时已经没有电了,也不用那段code特意的清掉他们,直接没有电了;
- }5 y$ t6 j" C# E5 u所以你那code不起作用,你可以在进S4的时候,写systemflag到CMOS,再进行判断!& ?# E, c1 m$ ]% u! x- K4 h: |( X  z
个人认为这样oK;
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-5-6 13:15 , Processed in 0.041902 second(s), 16 queries .

Powered by Discuz! X3.5

© 2001-2023 Discuz! Team.

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