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

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

[复制链接]
发表于 2009-5-15 15:48:20 | 显示全部楼层 |阅读模式
大家好,我在接案子的时候遇到个bebug :从S4回来可以进入bios setup.
: m, i$ w  P- ?# U% H我的解法是这样的,在POST的过程中系统检测按键的时候,我加了段代码去判断PM_BASE+04h的BIT10 – bit12是否等于110b。
) u: a3 n( n! ~  a代码如下:2 k2 k+ E: ^' K0 }+ }" e
VOID CheckForKey( EFI_EVENT Event, VOID *Context )! X- }4 r+ t# b8 T/ _& O1 n
{
+ G& @- A* n* W. {6 W. t4 [/ E! S& P- [0 G; y
………..  
0 e# x1 b; U7 s8 h  UINT8 Data,Data1;
0 G/ \" M; J1 e$ ~! D1 X0 Q4 W/ ~( z
    Status = gBS->LocateProtocol (&gEfiCpuIoProtocolGuid, NULL, &gCpuIo);
! a) q. d. ]7 g! n% |     if (EFI_ERROR(Status)) return;6 l8 c/ V& N; ^6 N5 u; K5 ?
    Status=gCpuIo->Io.Read (gCpuIo, EfiCpuIoWidthUint8, 0x405 , 1, &Data);  //read PM BASE register 0x05,Get sleep type/ q" m* {  H9 }% h, N
        if((Data == 0x18)){
* P6 Y- Y7 g. l; u# @* b- K          return;}
2 W% v, S, E) m7 Z7 ]# r……….…….
" B( V( b0 I7 y! J0 n  M}) _/ k# i% V$ l3 a
可是仍然从S4回来可以进入bios setup.
/ P6 o5 \; t" n; ~0 h6 d我想问1。PMBASE是不是在S4回来后被清空?' c6 ?% P% q3 I) Q
       2.是何时被清空的?4 Z; N9 {5 q! \' C1 S; [- T
谢谢
发表于 2012-5-28 11:24:42 | 显示全部楼层
Power Management 1 Control Register 这边的register应该在S4状态下就是被清掉的,因为当时已经没有电了,也不用那段code特意的清掉他们,直接没有电了;
& G# a- i3 h/ W7 I所以你那code不起作用,你可以在进S4的时候,写systemflag到CMOS,再进行判断!
7 n& j/ [8 o4 @3 C( N2 l* y个人认为这样oK;
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-12-1 07:51 , Processed in 0.073246 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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