|
大家好,我在接案子的时候遇到个bebug :从S4回来可以进入bios setup.6 I. E# v+ y8 ^3 p* x+ b0 w
我的解法是这样的,在POST的过程中系统检测按键的时候,我加了段代码去判断PM_BASE+04h的BIT10 – bit12是否等于110b。
2 F0 h* p% [# s代码如下:
, E: F+ O2 Z# y4 P3 ]VOID CheckForKey( EFI_EVENT Event, VOID *Context )
' V4 j0 L" u0 Q0 K' T# _( {{
% y: S- ]; c2 s. a; o7 _5 z7 E* R, U( Z- z* G
……….. 1 N D' r" U$ Y& {' x1 [
UINT8 Data,Data1;
3 y$ }5 U2 f/ |" j6 S0 G) Z) D% F4 }" Q/ E% M( [
Status = gBS->LocateProtocol (&gEfiCpuIoProtocolGuid, NULL, &gCpuIo);& Y' X* u2 n- h
if (EFI_ERROR(Status)) return;, |" p/ j. U- m' ~" }) k
Status=gCpuIo->Io.Read (gCpuIo, EfiCpuIoWidthUint8, 0x405 , 1, &Data); //read PM BASE register 0x05,Get sleep type& P8 d3 W! \, o
if((Data == 0x18)){# U7 g5 J. K" u" U' h0 x) w
return;}/ h0 V8 x% e* a/ a# p
……….…….: ^ p4 S9 b' ~
}
; z1 a6 P2 N- i# ?7 ^ {( e+ t$ I可是仍然从S4回来可以进入bios setup.& r* F- v" \6 d+ |, L1 R
我想问1。PMBASE是不是在S4回来后被清空?
. ?/ ` p3 X; D 2.是何时被清空的?
& T) ?; o7 h- }3 j5 ^3 t谢谢 |
|