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

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

[复制链接]
发表于 2009-5-15 15:48:20 | 显示全部楼层 |阅读模式
大家好,我在接案子的时候遇到个bebug :从S4回来可以进入bios setup.* k: M( m( N) j# O, z+ n
我的解法是这样的,在POST的过程中系统检测按键的时候,我加了段代码去判断PM_BASE+04h的BIT10 – bit12是否等于110b。. W! `+ f( i" [( c4 O2 S
代码如下:
1 K0 V0 F2 O! \4 U8 ~- GVOID CheckForKey( EFI_EVENT Event, VOID *Context )
( z  y- C  p  y# s/ ~{; K3 P: O" O: c$ I' M  [  |

) W5 J# c1 l: g( s, @………..  6 x0 |' {. W) F- G, |% g
  UINT8 Data,Data1;$ G, A0 g* v  P

0 d5 d& B7 D& @# q$ D8 c- ^  O3 N; d    Status = gBS->LocateProtocol (&gEfiCpuIoProtocolGuid, NULL, &gCpuIo);" E4 c. v7 p8 g* g
     if (EFI_ERROR(Status)) return;0 |& t& ^/ ?+ K. y% }
    Status=gCpuIo->Io.Read (gCpuIo, EfiCpuIoWidthUint8, 0x405 , 1, &Data);  //read PM BASE register 0x05,Get sleep type
% Y6 b) z, E$ V. @        if((Data == 0x18)){' f( a0 s" i& W2 P0 Y4 [
          return;}
! w8 O/ W% }) g: l……….…….3 O! C' `$ w: A; o: m( M' |3 J  G
}- ?$ B3 R, g2 P+ z% W
可是仍然从S4回来可以进入bios setup.) O' m  {  L! N  P
我想问1。PMBASE是不是在S4回来后被清空?
, q# j2 p9 k1 d       2.是何时被清空的?" y' X! I8 K4 W( i" `# W" S
谢谢
发表于 2012-5-28 11:24:42 | 显示全部楼层
Power Management 1 Control Register 这边的register应该在S4状态下就是被清掉的,因为当时已经没有电了,也不用那段code特意的清掉他们,直接没有电了;" c* {+ u9 y; \* r- y+ P9 ~; T5 c
所以你那code不起作用,你可以在进S4的时候,写systemflag到CMOS,再进行判断!
+ z/ R1 x7 _- }, _4 L$ q7 G个人认为这样oK;
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-2-24 09:02 , Processed in 0.055834 second(s), 16 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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