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

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

[复制链接]
发表于 2009-5-15 15:48:20 | 显示全部楼层 |阅读模式
大家好,我在接案子的时候遇到个bebug :从S4回来可以进入bios setup.2 K& }2 C! q% c  m8 ?( J
我的解法是这样的,在POST的过程中系统检测按键的时候,我加了段代码去判断PM_BASE+04h的BIT10 – bit12是否等于110b。& c, p" |: H4 ~
代码如下:
; t6 _, e/ m( S3 m. l# r4 V7 XVOID CheckForKey( EFI_EVENT Event, VOID *Context )
. d8 r. U+ K! }( S& H. {- C{6 q- w" u7 V9 |5 P0 |; G) B
, n4 m6 I9 W  {: a5 P0 P
………..  + G6 Y8 b2 M+ F5 Q: l
  UINT8 Data,Data1;1 s* a' @. K4 B# V- k
0 D+ b. n& p. r8 u1 B" Q+ I6 D
    Status = gBS->LocateProtocol (&gEfiCpuIoProtocolGuid, NULL, &gCpuIo);" }% ]: h3 x# F' Z
     if (EFI_ERROR(Status)) return;! {) K2 B% f7 F4 O/ A7 S
    Status=gCpuIo->Io.Read (gCpuIo, EfiCpuIoWidthUint8, 0x405 , 1, &Data);  //read PM BASE register 0x05,Get sleep type
- E% u0 W: f' v; f7 y9 F        if((Data == 0x18)){4 x1 S/ H8 s( \5 ?
          return;}
2 b8 S) W. L/ f2 A; r: B( A……….…….
4 u$ M2 [- y* ~* _1 d, P" x- z' {}6 X6 _. ?6 J# r6 U
可是仍然从S4回来可以进入bios setup.2 w$ m5 |3 p0 x( E3 D
我想问1。PMBASE是不是在S4回来后被清空?1 K! R; s  o2 U7 h5 L2 \# w& e
       2.是何时被清空的?6 `, a; ?3 W9 Q) K. U
谢谢
发表于 2012-5-28 11:24:42 | 显示全部楼层
Power Management 1 Control Register 这边的register应该在S4状态下就是被清掉的,因为当时已经没有电了,也不用那段code特意的清掉他们,直接没有电了;
$ r8 X) E* v# L- X8 x0 R: B) K所以你那code不起作用,你可以在进S4的时候,写systemflag到CMOS,再进行判断!, W5 C: _. \* k
个人认为这样oK;
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-5-22 03:27 , Processed in 0.046673 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2023 Discuz! Team.

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