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

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

[复制链接]
发表于 2009-5-15 15:48:20 | 显示全部楼层 |阅读模式
大家好,我在接案子的时候遇到个bebug :从S4回来可以进入bios setup.
4 v; W- {5 }3 ^* y+ O" U8 z  F, u1 o9 @我的解法是这样的,在POST的过程中系统检测按键的时候,我加了段代码去判断PM_BASE+04h的BIT10 – bit12是否等于110b。
6 B- A4 _0 [7 o代码如下:
, A: Q. p6 [5 qVOID CheckForKey( EFI_EVENT Event, VOID *Context )
/ A8 P+ j! Z$ ~! s/ O2 [{0 l/ F. Z0 X' ]) H+ P) x1 t: \! u

, v1 A2 v3 N) I( r………..  
% Z* l4 ~* Y: J  UINT8 Data,Data1;/ X) S7 S  F% x1 C7 f# W

& A7 R# L: N: u6 S    Status = gBS->LocateProtocol (&gEfiCpuIoProtocolGuid, NULL, &gCpuIo);! ]6 N3 L2 n# H
     if (EFI_ERROR(Status)) return;
+ L. i7 Q! [( ]4 s    Status=gCpuIo->Io.Read (gCpuIo, EfiCpuIoWidthUint8, 0x405 , 1, &Data);  //read PM BASE register 0x05,Get sleep type
; T3 y, f" l  A+ B5 a2 ~        if((Data == 0x18)){
% q% j; j5 L- m) f5 A0 k* K& G& l4 i          return;}
- D  }6 w+ j4 D……….…….
$ E& n& r6 T7 I( w; j$ r}
( a& Y4 C& A9 ~可是仍然从S4回来可以进入bios setup.* c7 b: F9 r2 R) t6 F
我想问1。PMBASE是不是在S4回来后被清空?
: J+ W( s- G; t6 ?8 {* ]       2.是何时被清空的?  P; b+ F+ |0 J% k% k
谢谢
发表于 2012-5-28 11:24:42 | 显示全部楼层
Power Management 1 Control Register 这边的register应该在S4状态下就是被清掉的,因为当时已经没有电了,也不用那段code特意的清掉他们,直接没有电了;# `: {6 l! [" ?7 x* ?* y4 A
所以你那code不起作用,你可以在进S4的时候,写systemflag到CMOS,再进行判断!
; |( U3 l2 ?: y' p4 x; v个人认为这样oK;
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-5-2 02:25 , Processed in 0.059869 second(s), 16 queries .

Powered by Discuz! X3.5

© 2001-2023 Discuz! Team.

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