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

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

[复制链接]
发表于 2009-5-15 15:48:20 | 显示全部楼层 |阅读模式
大家好,我在接案子的时候遇到个bebug :从S4回来可以进入bios setup.
1 W; I$ w( V9 s- Z5 c1 H我的解法是这样的,在POST的过程中系统检测按键的时候,我加了段代码去判断PM_BASE+04h的BIT10 – bit12是否等于110b。
# A) W- Z' E- Z5 V1 n8 \* V: ]代码如下:/ z$ l0 T2 D# ^! N" s2 `/ J
VOID CheckForKey( EFI_EVENT Event, VOID *Context )
! ]7 u- W) d8 D  m+ I7 w( X- W{
7 n* z) w8 Y9 e: P; g9 h4 ]" n$ x. _) Z2 o; ~# w
………..  7 j5 }2 y/ ~4 Q
  UINT8 Data,Data1;
; Y8 [' R# V; z+ h
" U5 p# b# Y) A7 I- V/ H9 o    Status = gBS->LocateProtocol (&gEfiCpuIoProtocolGuid, NULL, &gCpuIo);
5 \4 K; p2 }& l1 b( f% ^3 C     if (EFI_ERROR(Status)) return;
6 K1 T# t$ F& K    Status=gCpuIo->Io.Read (gCpuIo, EfiCpuIoWidthUint8, 0x405 , 1, &Data);  //read PM BASE register 0x05,Get sleep type
: j: {: ^. ?/ p& }9 X        if((Data == 0x18)){
/ h# D6 J  j) {  P, b          return;}) `1 C' H- @3 E. w: Q% ~0 o
……….…….9 S6 ]( n! h( b- E, N" w
}
' x' Y4 v( J: W' b$ q6 E可是仍然从S4回来可以进入bios setup.* q( \. m5 U" O2 S- a9 W& i: S& C
我想问1。PMBASE是不是在S4回来后被清空?
/ ?& P  i( p- C/ g       2.是何时被清空的?
, _. i6 E$ ~" U/ ~- n谢谢
发表于 2012-5-28 11:24:42 | 显示全部楼层
Power Management 1 Control Register 这边的register应该在S4状态下就是被清掉的,因为当时已经没有电了,也不用那段code特意的清掉他们,直接没有电了;
( [1 Z/ {& M* F+ z) w所以你那code不起作用,你可以在进S4的时候,写systemflag到CMOS,再进行判断!
! x3 K; ~, V. N4 I个人认为这样oK;
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-1-19 00:34 , Processed in 0.057893 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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