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

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

[复制链接]
发表于 2009-5-15 15:48:20 | 显示全部楼层 |阅读模式
大家好,我在接案子的时候遇到个bebug :从S4回来可以进入bios setup.' ?; Z& S( |5 B% _. e
我的解法是这样的,在POST的过程中系统检测按键的时候,我加了段代码去判断PM_BASE+04h的BIT10 – bit12是否等于110b。5 G; A$ y" ~8 C' o
代码如下:9 ]. E5 r( x- J9 m
VOID CheckForKey( EFI_EVENT Event, VOID *Context )
/ \5 v! o1 _  n{* q" C+ P+ j6 t' c& O& f
( Y4 s! t- [: V6 i5 U- W
………..  ) d- O) c2 @5 a, j4 q( ^# _
  UINT8 Data,Data1;9 N  _4 I- K6 d& f. T7 s, j2 ^

: Y% w8 W9 v! L' a    Status = gBS->LocateProtocol (&gEfiCpuIoProtocolGuid, NULL, &gCpuIo);
+ _$ ]* \$ w5 F8 z4 L# z# g     if (EFI_ERROR(Status)) return;
3 U7 ?0 Z& S$ O    Status=gCpuIo->Io.Read (gCpuIo, EfiCpuIoWidthUint8, 0x405 , 1, &Data);  //read PM BASE register 0x05,Get sleep type3 L9 ^5 Q' I: n+ Y/ z
        if((Data == 0x18)){" t9 M, J# b: M3 {
          return;}' [' K8 u6 L2 A! x* @( b% J
……….…….
! u& o) V. M  i' W$ m}0 H$ Z/ f% |2 J  P. [2 ^% [; m
可是仍然从S4回来可以进入bios setup.: r6 x4 |1 x4 q* K
我想问1。PMBASE是不是在S4回来后被清空?
0 C! l6 B) T# g( |       2.是何时被清空的?, N; g0 X* B( j- h  ?
谢谢
发表于 2012-5-28 11:24:42 | 显示全部楼层
Power Management 1 Control Register 这边的register应该在S4状态下就是被清掉的,因为当时已经没有电了,也不用那段code特意的清掉他们,直接没有电了;+ `  {! C" d: p" r9 V. }
所以你那code不起作用,你可以在进S4的时候,写systemflag到CMOS,再进行判断!
1 {: j3 ?8 S; J6 r4 M* Q+ F6 ?个人认为这样oK;
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-5-16 05:06 , Processed in 0.025237 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2023 Discuz! Team.

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