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

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

[复制链接]
发表于 2009-5-15 15:48:20 | 显示全部楼层 |阅读模式
大家好,我在接案子的时候遇到个bebug :从S4回来可以进入bios setup.
, H) P1 n/ B; v7 k+ B我的解法是这样的,在POST的过程中系统检测按键的时候,我加了段代码去判断PM_BASE+04h的BIT10 – bit12是否等于110b。8 b- B1 @+ p& ~* Z: j3 A
代码如下:
  s4 l: H" G5 E8 k+ D3 ~( V7 L- s' iVOID CheckForKey( EFI_EVENT Event, VOID *Context )
6 q* J9 c3 H9 ^4 v3 j/ d& w. o9 C0 I{
+ Z: @5 B0 T# H' y0 x% \+ y3 h" j: [+ U3 S5 R% p1 V2 i5 |
………..  
( Q) ~3 c" k' l  UINT8 Data,Data1;
$ W. x& g, r/ k: p
% L" j( W" Z/ X) e/ u7 E& Z7 M; p    Status = gBS->LocateProtocol (&gEfiCpuIoProtocolGuid, NULL, &gCpuIo);
6 t0 {: p3 k2 b. L& q+ E* h     if (EFI_ERROR(Status)) return;
9 N8 @# U; [4 k/ V  o; o9 J3 D) @    Status=gCpuIo->Io.Read (gCpuIo, EfiCpuIoWidthUint8, 0x405 , 1, &Data);  //read PM BASE register 0x05,Get sleep type
" {9 o: Z9 B8 y6 `# s4 t; @1 m        if((Data == 0x18)){
" X8 P7 L& Q, M          return;}
! M# \  x( \1 T! Z; C( D# q* i……….…….
: i( |* @; F# U# q& X; ~' D}
- r6 l: U' I% x9 Z可是仍然从S4回来可以进入bios setup.
; l3 V- D+ R' ~' B% w4 b- B2 k我想问1。PMBASE是不是在S4回来后被清空?
. d8 g  N: T; Y8 K1 g4 Q+ f5 X+ r/ f       2.是何时被清空的?! f! P$ t0 d  |
谢谢
发表于 2012-5-28 11:24:42 | 显示全部楼层
Power Management 1 Control Register 这边的register应该在S4状态下就是被清掉的,因为当时已经没有电了,也不用那段code特意的清掉他们,直接没有电了;
6 c; {1 `* j# M4 i9 u; \, f3 `所以你那code不起作用,你可以在进S4的时候,写systemflag到CMOS,再进行判断!9 M6 L: f; M, H8 d% e$ _
个人认为这样oK;
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-3-4 21:15 , Processed in 0.026457 second(s), 16 queries .

Powered by Discuz! X3.5

© 2001-2023 Discuz! Team.

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