|
|
大家好,我在接案子的时候遇到个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
谢谢 |
|