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

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

[复制链接]
发表于 2009-5-15 15:48:20 | 显示全部楼层 |阅读模式
大家好,我在接案子的时候遇到个bebug :从S4回来可以进入bios setup.5 b; T. K4 u% a2 L, ~3 s# j1 x4 T
我的解法是这样的,在POST的过程中系统检测按键的时候,我加了段代码去判断PM_BASE+04h的BIT10 – bit12是否等于110b。2 }- l$ T, I3 F9 ?; w0 F: I7 {
代码如下:
* b4 U9 T: y5 H+ G/ MVOID CheckForKey( EFI_EVENT Event, VOID *Context )
) U" |+ S: H7 g; p5 j, p5 s1 U: r{
5 e& q8 o! m& K0 |' p0 l# n( G' x' N9 k/ b- s, b6 e. j, h
………..  
8 \) W: ]' V; h3 D7 W- ?: j  UINT8 Data,Data1;; e$ X6 Z4 k& S+ V0 H

1 o0 I! ^4 p  k. ]: b8 V+ S    Status = gBS->LocateProtocol (&gEfiCpuIoProtocolGuid, NULL, &gCpuIo);
) e, N9 E$ d0 y8 O; S     if (EFI_ERROR(Status)) return;5 l4 J, X6 @: q% W- v. B' _) \
    Status=gCpuIo->Io.Read (gCpuIo, EfiCpuIoWidthUint8, 0x405 , 1, &Data);  //read PM BASE register 0x05,Get sleep type
% {6 q" W' |0 ?6 a        if((Data == 0x18)){
/ w  p  E% K3 T6 t: ]4 n3 ]  V          return;}- J7 P& `+ h% [' e
……….…….0 E3 S" R( x  D2 C7 Y
}
) i$ ?7 _8 b, Q2 U; _' r可是仍然从S4回来可以进入bios setup.
# g5 w: {) t6 z5 Q6 m' s我想问1。PMBASE是不是在S4回来后被清空?% C, X& J" e6 W8 Y+ F
       2.是何时被清空的?) ?/ }) I  R6 y
谢谢
发表于 2012-5-28 11:24:42 | 显示全部楼层
Power Management 1 Control Register 这边的register应该在S4状态下就是被清掉的,因为当时已经没有电了,也不用那段code特意的清掉他们,直接没有电了;
. f+ z8 z: i9 y& I7 \4 |& t所以你那code不起作用,你可以在进S4的时候,写systemflag到CMOS,再进行判断!/ @& I4 B4 ?" Z% j7 ^6 ?7 a
个人认为这样oK;
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-12-1 02:57 , Processed in 0.070330 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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