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

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

[复制链接]
发表于 2009-5-15 15:48:20 | 显示全部楼层 |阅读模式
大家好,我在接案子的时候遇到个bebug :从S4回来可以进入bios setup.7 z; m8 a3 `3 u6 K6 ]( C9 G3 z
我的解法是这样的,在POST的过程中系统检测按键的时候,我加了段代码去判断PM_BASE+04h的BIT10 – bit12是否等于110b。
2 E! n+ K- S( n2 R, }代码如下:
" }* B/ y$ F) F8 Q; x* t; tVOID CheckForKey( EFI_EVENT Event, VOID *Context )
1 k, H' \% w/ X: p, v, A4 L{
* ]% q8 M1 I. |1 e& E
. K# {5 D/ s+ q! f. Z' o& `+ J………..  ( A, T8 n* e# L) P: S
  UINT8 Data,Data1;
- O: F+ a3 ]  L$ P- w( ~# C, u& N7 [/ X0 h/ }2 V; ~
    Status = gBS->LocateProtocol (&gEfiCpuIoProtocolGuid, NULL, &gCpuIo);8 u; r$ x% u/ L7 j
     if (EFI_ERROR(Status)) return;
$ d' w. ?4 _- S+ Q; K* |    Status=gCpuIo->Io.Read (gCpuIo, EfiCpuIoWidthUint8, 0x405 , 1, &Data);  //read PM BASE register 0x05,Get sleep type
' q5 A4 d+ x( ~- D$ m. u9 B  V7 I  |        if((Data == 0x18)){7 i% q4 D9 S6 N5 @( q5 |/ H* r
          return;}& e- U; p+ ]0 D5 M/ p: `) M
……….…….
3 P* L1 O6 g% `+ S}
; y% _; b8 X& e7 F可是仍然从S4回来可以进入bios setup.
3 E  f" _3 e- a) G我想问1。PMBASE是不是在S4回来后被清空?7 g) x4 p% l6 D5 y
       2.是何时被清空的?
3 d! d  I! S" |2 i谢谢
发表于 2012-5-28 11:24:42 | 显示全部楼层
Power Management 1 Control Register 这边的register应该在S4状态下就是被清掉的,因为当时已经没有电了,也不用那段code特意的清掉他们,直接没有电了;6 D$ o1 |8 b! X( h
所以你那code不起作用,你可以在进S4的时候,写systemflag到CMOS,再进行判断!6 g; ]9 L4 j" G: h/ e
个人认为这样oK;
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-6-4 19:03 , Processed in 1.013684 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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