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

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

[复制链接]
发表于 2009-5-15 15:48:20 | 显示全部楼层 |阅读模式
大家好,我在接案子的时候遇到个bebug :从S4回来可以进入bios setup.
# H9 H  _9 E4 ]: ]0 R6 n, W8 ?" Z; V我的解法是这样的,在POST的过程中系统检测按键的时候,我加了段代码去判断PM_BASE+04h的BIT10 – bit12是否等于110b。
+ I/ M. D3 ~- z2 q& D8 i: X; p; p代码如下:; s/ ?! S0 N6 c' a. J
VOID CheckForKey( EFI_EVENT Event, VOID *Context )( p& i) t+ d# q4 y
{
& K% L: y1 l6 b+ C1 @; `3 E; q+ r# Z. }- I' ^1 ~
………..  ( {: K- G: f, |+ c+ O5 |8 Z) o
  UINT8 Data,Data1;
6 e& Y2 R# v; t1 W+ C5 ~& f  ^# j/ }* o. P" Y2 c
    Status = gBS->LocateProtocol (&gEfiCpuIoProtocolGuid, NULL, &gCpuIo);& |; _8 F0 @+ m! W( J/ T
     if (EFI_ERROR(Status)) return;
2 H7 X0 g2 g* ~. _3 S2 Q    Status=gCpuIo->Io.Read (gCpuIo, EfiCpuIoWidthUint8, 0x405 , 1, &Data);  //read PM BASE register 0x05,Get sleep type/ N$ H% Y( C" F& g& L, @) `6 g
        if((Data == 0x18)){
4 w% E1 d( O- ^4 Q) x  b          return;}
# H2 M8 l& W: a+ J……….……." S: d, e8 U5 B. H' \
}4 ~) ^0 E8 q9 B6 l4 H
可是仍然从S4回来可以进入bios setup.
/ N0 H: M& p  O6 R- n我想问1。PMBASE是不是在S4回来后被清空?  Y; d8 u- y9 C9 C1 T2 n  j
       2.是何时被清空的?
" h1 m+ k. u( y; N6 ^谢谢
发表于 2012-5-28 11:24:42 | 显示全部楼层
Power Management 1 Control Register 这边的register应该在S4状态下就是被清掉的,因为当时已经没有电了,也不用那段code特意的清掉他们,直接没有电了;
& x3 }8 e- ~2 J  ]所以你那code不起作用,你可以在进S4的时候,写systemflag到CMOS,再进行判断!
/ v! z4 y- V# }6 d个人认为这样oK;
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-2-1 04:10 , Processed in 0.054721 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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