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

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

[复制链接]
发表于 2009-5-15 15:48:20 | 显示全部楼层 |阅读模式
大家好,我在接案子的时候遇到个bebug :从S4回来可以进入bios setup.
  W7 k. |, Y# }9 B( L% A, ]. t' k我的解法是这样的,在POST的过程中系统检测按键的时候,我加了段代码去判断PM_BASE+04h的BIT10 – bit12是否等于110b。4 m' X+ n- o2 r4 R$ F1 n2 S! \; E' G  V
代码如下:
9 m  B$ G0 |. C, mVOID CheckForKey( EFI_EVENT Event, VOID *Context )
, R3 l$ z& ^/ l- K9 _{; f' p+ ]& M% s+ x2 r

9 m" H9 N0 O3 L5 l% y………..  1 h4 }1 Q' i( ?  @3 x
  UINT8 Data,Data1;
7 ^2 H. e- u9 E. T0 ~3 n* X: [8 W; _: i: R
    Status = gBS->LocateProtocol (&gEfiCpuIoProtocolGuid, NULL, &gCpuIo);
6 x. k5 z- k# w/ E4 ]: u" r0 x     if (EFI_ERROR(Status)) return;
0 L) B; W+ p4 d    Status=gCpuIo->Io.Read (gCpuIo, EfiCpuIoWidthUint8, 0x405 , 1, &Data);  //read PM BASE register 0x05,Get sleep type
; j% t1 x# S- C8 h4 N5 D        if((Data == 0x18)){2 t2 b" r: }; O& K
          return;}
5 }% O; d0 j# ?, e……….…….$ M8 U# f# \  @/ t5 s
}. \) P( x# q; |. R" y( e. v
可是仍然从S4回来可以进入bios setup.
5 o& o8 o' R4 c我想问1。PMBASE是不是在S4回来后被清空?
' |8 }5 O, z; |; h* S       2.是何时被清空的?, ?& ~' y$ l# n; `5 h9 J2 {' O
谢谢
发表于 2012-5-28 11:24:42 | 显示全部楼层
Power Management 1 Control Register 这边的register应该在S4状态下就是被清掉的,因为当时已经没有电了,也不用那段code特意的清掉他们,直接没有电了;
! z1 W' P9 C/ D所以你那code不起作用,你可以在进S4的时候,写systemflag到CMOS,再进行判断!0 v' ^% D3 ^3 y, j
个人认为这样oK;
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-1-12 00:44 , Processed in 0.268484 second(s), 16 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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