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

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

[复制链接]
发表于 2009-5-15 15:48:20 | 显示全部楼层 |阅读模式
大家好,我在接案子的时候遇到个bebug :从S4回来可以进入bios setup.
2 S1 x( ]) V: x7 Q! k, `我的解法是这样的,在POST的过程中系统检测按键的时候,我加了段代码去判断PM_BASE+04h的BIT10 – bit12是否等于110b。
/ t' C/ w$ V% A! m6 v代码如下:% C. l# [8 n: j# f; _1 P$ F
VOID CheckForKey( EFI_EVENT Event, VOID *Context )- j0 l7 a7 S- {6 X( A7 B+ @* {
{. G5 v- ^1 n, U* `1 S
( B) J9 W; r9 C7 {% E( [6 T
………..  1 l! {* M& v, P5 [# ^6 |
  UINT8 Data,Data1;
, {  o* n& a' |: a9 T" U8 ^9 R6 Z  H
    Status = gBS->LocateProtocol (&gEfiCpuIoProtocolGuid, NULL, &gCpuIo);
6 q* U: D9 p- [/ x8 f     if (EFI_ERROR(Status)) return;
, z$ Y" L' o9 r9 w    Status=gCpuIo->Io.Read (gCpuIo, EfiCpuIoWidthUint8, 0x405 , 1, &Data);  //read PM BASE register 0x05,Get sleep type
8 r2 [0 ?% [% @# s4 O        if((Data == 0x18)){9 O0 H1 D) b; b' b6 q
          return;}
+ s: Z4 v8 k; A……….…….
$ x, W& c( \0 |& [& h- y}
+ H  h/ @3 P0 q( x* \7 `0 G可是仍然从S4回来可以进入bios setup.
+ l8 Z+ ~2 |  t) o% y4 j我想问1。PMBASE是不是在S4回来后被清空?
  c' b( q0 S' h! K2 I$ g$ |* }) y       2.是何时被清空的?
7 I! I2 u0 Y9 e6 R: r0 d0 P谢谢
发表于 2012-5-28 11:24:42 | 显示全部楼层
Power Management 1 Control Register 这边的register应该在S4状态下就是被清掉的,因为当时已经没有电了,也不用那段code特意的清掉他们,直接没有电了;
* q  s/ @" u1 b' c4 F7 t& ~0 d所以你那code不起作用,你可以在进S4的时候,写systemflag到CMOS,再进行判断!9 o# S4 u8 B8 i3 {! k* h0 Z
个人认为这样oK;
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-4-20 05:43 , Processed in 0.041294 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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