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

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

[复制链接]
发表于 2009-5-15 15:48:20 | 显示全部楼层 |阅读模式
大家好,我在接案子的时候遇到个bebug :从S4回来可以进入bios setup.- Y' |  @. o1 ?5 r, S2 i9 F/ N" n( u
我的解法是这样的,在POST的过程中系统检测按键的时候,我加了段代码去判断PM_BASE+04h的BIT10 – bit12是否等于110b。0 e) h# K8 Z/ o. |! f
代码如下:
9 X4 ~; M- J5 R6 r+ bVOID CheckForKey( EFI_EVENT Event, VOID *Context ), ~5 o  b/ }: `
{
% n7 L& G- W8 _$ _. H" N6 L- s+ e* D( B/ b$ G
………..  
0 Q( C; X: ?, E* O  UINT8 Data,Data1;: a$ ]  Z- [/ C
# R/ J+ l: L, c7 y: I" Q6 I# [
    Status = gBS->LocateProtocol (&gEfiCpuIoProtocolGuid, NULL, &gCpuIo);
' y! O, T) C# Z# R9 C- b     if (EFI_ERROR(Status)) return;
/ r: g( c+ R  m0 Z" g    Status=gCpuIo->Io.Read (gCpuIo, EfiCpuIoWidthUint8, 0x405 , 1, &Data);  //read PM BASE register 0x05,Get sleep type( c0 x$ c5 ~0 `4 E
        if((Data == 0x18)){
' }+ A8 b3 B% L9 ?# K          return;}* F5 Q' m  X! _/ t
……….…….
+ Y& W" b6 s" U5 ?) I}
7 O' G% U9 e- b可是仍然从S4回来可以进入bios setup.
  i- z. M# ?8 i9 H+ \& x我想问1。PMBASE是不是在S4回来后被清空?8 k  J& R: b+ ]% ^7 |& P2 w7 r: a# W
       2.是何时被清空的?
' ~. n) ^9 |8 x2 e" o8 x谢谢
发表于 2012-5-28 11:24:42 | 显示全部楼层
Power Management 1 Control Register 这边的register应该在S4状态下就是被清掉的,因为当时已经没有电了,也不用那段code特意的清掉他们,直接没有电了;
7 y+ H0 c, m+ w! I* d所以你那code不起作用,你可以在进S4的时候,写systemflag到CMOS,再进行判断!
/ K0 W) L* a7 j4 x; d" p: B个人认为这样oK;
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-6-17 10:47 , Processed in 0.042455 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2023 Discuz! Team.

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