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

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

[复制链接]
发表于 2009-5-15 15:48:20 | 显示全部楼层 |阅读模式
大家好,我在接案子的时候遇到个bebug :从S4回来可以进入bios setup.( `$ x1 W+ n& A8 U( N0 d4 v7 I
我的解法是这样的,在POST的过程中系统检测按键的时候,我加了段代码去判断PM_BASE+04h的BIT10 – bit12是否等于110b。
  v0 ^% g4 S, V. u5 p7 o, @代码如下:
* q9 d. i  d2 \  f* ^8 mVOID CheckForKey( EFI_EVENT Event, VOID *Context )% }& g& h$ }/ _" G  L5 V
{
8 t- W+ P! P; S$ z1 R" R4 g2 z! {! L# Z" {" {' h
………..  ' b/ p+ F1 i& U' W+ D
  UINT8 Data,Data1;8 D& y3 Z/ m, T9 q3 s+ L
1 Y# l) n- c  T8 m3 @- d5 g
    Status = gBS->LocateProtocol (&gEfiCpuIoProtocolGuid, NULL, &gCpuIo);
9 L+ l$ Z5 M9 j, |9 k5 P     if (EFI_ERROR(Status)) return;' m4 {6 a* @" P# x
    Status=gCpuIo->Io.Read (gCpuIo, EfiCpuIoWidthUint8, 0x405 , 1, &Data);  //read PM BASE register 0x05,Get sleep type6 E7 p; m! @: T) n7 |1 F/ O2 V9 }$ N
        if((Data == 0x18)){1 x( m& T/ J+ {0 L9 i/ I2 Q% \! ?
          return;}; [# S6 @6 t% ^# @, ~* Y% L
……….…….) {# l; P7 Q, v7 @; y, ~7 }
}) O. u1 u0 b, b: F, ~
可是仍然从S4回来可以进入bios setup.; |; K1 p. `, \4 h
我想问1。PMBASE是不是在S4回来后被清空?- w# m2 @0 Q8 f2 b" @  I9 D
       2.是何时被清空的?7 x7 r/ f7 f9 S9 r
谢谢
发表于 2012-5-28 11:24:42 | 显示全部楼层
Power Management 1 Control Register 这边的register应该在S4状态下就是被清掉的,因为当时已经没有电了,也不用那段code特意的清掉他们,直接没有电了;
5 y" G2 d: E, G2 A( M7 ^, I所以你那code不起作用,你可以在进S4的时候,写systemflag到CMOS,再进行判断!) S" T" A2 p. C5 L% R
个人认为这样oK;
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-6-29 02:42 , Processed in 0.357967 second(s), 16 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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