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

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

[复制链接]
发表于 2009-5-15 15:48:20 | 显示全部楼层 |阅读模式
大家好,我在接案子的时候遇到个bebug :从S4回来可以进入bios setup.* L" P! k% `$ H5 t) ?* Y
我的解法是这样的,在POST的过程中系统检测按键的时候,我加了段代码去判断PM_BASE+04h的BIT10 – bit12是否等于110b。! }2 v1 g* w) D0 B! {
代码如下:5 d4 h5 j% s- ?! k; P
VOID CheckForKey( EFI_EVENT Event, VOID *Context )$ ~- v1 y1 r2 q$ y; R( R
{
5 \: J1 L+ Z: `1 b% L9 N( B: a# o0 f  b" {1 K: a. U
………..  7 F+ S5 _2 }2 X3 s% V
  UINT8 Data,Data1;" W4 }/ |* U4 Y+ e

7 T% L8 _& s4 y4 M0 T/ \    Status = gBS->LocateProtocol (&gEfiCpuIoProtocolGuid, NULL, &gCpuIo);
1 l+ J) [% s$ p" H. q& }* X8 O     if (EFI_ERROR(Status)) return;! _" ^9 E) O. O% \; h$ n
    Status=gCpuIo->Io.Read (gCpuIo, EfiCpuIoWidthUint8, 0x405 , 1, &Data);  //read PM BASE register 0x05,Get sleep type1 z+ J) j5 e- ?+ X/ w: j
        if((Data == 0x18)){. H! w, ]3 Y2 G
          return;}. t% {3 Y  A# h& j2 l
……….…….
. c. M9 y/ |, J& [$ X% D}
- c/ |, v& [- A: P7 t可是仍然从S4回来可以进入bios setup.# _6 W. p( b: a
我想问1。PMBASE是不是在S4回来后被清空?2 N  h! Q3 w9 ]7 M: d( {
       2.是何时被清空的?
/ J) x- @/ v; N8 r9 R谢谢
发表于 2012-5-28 11:24:42 | 显示全部楼层
Power Management 1 Control Register 这边的register应该在S4状态下就是被清掉的,因为当时已经没有电了,也不用那段code特意的清掉他们,直接没有电了;) {" f( w/ I8 U. E8 o* F$ `1 R
所以你那code不起作用,你可以在进S4的时候,写systemflag到CMOS,再进行判断!  \$ c6 z: w# w# C/ U# ]" [
个人认为这样oK;
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-5-16 06:48 , Processed in 0.118875 second(s), 16 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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