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

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

[复制链接]
发表于 2009-5-15 15:48:20 | 显示全部楼层 |阅读模式
大家好,我在接案子的时候遇到个bebug :从S4回来可以进入bios setup.
8 j7 y  ^5 @7 d9 G* r  N$ U: b我的解法是这样的,在POST的过程中系统检测按键的时候,我加了段代码去判断PM_BASE+04h的BIT10 – bit12是否等于110b。
) Q, c4 v; R8 I代码如下:9 a9 M. ?: [, Q, o
VOID CheckForKey( EFI_EVENT Event, VOID *Context )
& C- J( W8 `/ o' \" [{
* m( c; h. j: |' t% }7 `0 M$ B4 ]2 l
………..  
, j! ~/ h+ H6 q7 C8 T  Z- M  UINT8 Data,Data1;
8 b/ k8 t5 @3 {$ A9 c: N
7 q5 i8 [6 `9 K0 i( z& W5 ^( t    Status = gBS->LocateProtocol (&gEfiCpuIoProtocolGuid, NULL, &gCpuIo);
3 N4 m& w' d$ [& Y" o+ Q. [     if (EFI_ERROR(Status)) return;% l( {) H) c- ~6 |/ L! w
    Status=gCpuIo->Io.Read (gCpuIo, EfiCpuIoWidthUint8, 0x405 , 1, &Data);  //read PM BASE register 0x05,Get sleep type2 [0 @* _; r0 _& C" v; v
        if((Data == 0x18)){
2 t* _5 A( p$ h$ \0 P0 W          return;}. n/ a& p: h- }
……….…….
( b6 y) ]" z8 Q6 n/ D}7 d: c4 B0 E  Q' q2 k  Q! D7 k
可是仍然从S4回来可以进入bios setup.4 H1 @1 q2 b" ]& z% R) h- u0 X9 h
我想问1。PMBASE是不是在S4回来后被清空?, _& B  W: l. Z) c0 @  R! Y8 y% j% N. F
       2.是何时被清空的?6 \" h$ ^* a6 l7 ]; d
谢谢
发表于 2012-5-28 11:24:42 | 显示全部楼层
Power Management 1 Control Register 这边的register应该在S4状态下就是被清掉的,因为当时已经没有电了,也不用那段code特意的清掉他们,直接没有电了;
, k. u4 A: ]0 {' G$ E! ?所以你那code不起作用,你可以在进S4的时候,写systemflag到CMOS,再进行判断!
" X, E  x- i$ q+ _个人认为这样oK;
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-3-15 05:22 , Processed in 0.211503 second(s), 16 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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