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

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

[复制链接]
发表于 2009-5-15 15:48:20 | 显示全部楼层 |阅读模式
大家好,我在接案子的时候遇到个bebug :从S4回来可以进入bios setup.. G4 x7 O) \( H' d% J& J( R/ d
我的解法是这样的,在POST的过程中系统检测按键的时候,我加了段代码去判断PM_BASE+04h的BIT10 – bit12是否等于110b。6 o( o0 B6 H) J, I
代码如下:( m" {* `, c: n# _/ k* z! Z
VOID CheckForKey( EFI_EVENT Event, VOID *Context )
$ p5 \6 g- q' \3 Z5 ~; A{; a6 K& t8 }- l* \# M& P, X' w" h
" |# L- j! v# k, l  H2 `5 e/ X) g
………..  
! X* x; A" \7 B9 a% g  UINT8 Data,Data1;! @; E2 I1 S: b- y7 }

2 f$ M5 h/ v# o' A' g5 A! c4 Z/ e! I    Status = gBS->LocateProtocol (&gEfiCpuIoProtocolGuid, NULL, &gCpuIo);! m! d7 A" j) r5 H! D
     if (EFI_ERROR(Status)) return;% Z- Y  l/ c: B# _  B; c
    Status=gCpuIo->Io.Read (gCpuIo, EfiCpuIoWidthUint8, 0x405 , 1, &Data);  //read PM BASE register 0x05,Get sleep type9 ?- v7 d6 \. l
        if((Data == 0x18)){; m- b0 Q* f+ C* a9 ?& ~* ?
          return;}" V6 R% |. P+ q0 N+ K: n$ O  v) j
……….…….! r2 r/ m+ Z- j" h) n
}  r9 h6 q( @5 N# [; t2 g% |" h* K
可是仍然从S4回来可以进入bios setup.. M9 r% ?0 a% A
我想问1。PMBASE是不是在S4回来后被清空?
8 N# V$ k# f5 [" v       2.是何时被清空的?
' m5 l3 C- P  i* L$ Y2 Z谢谢
发表于 2012-5-28 11:24:42 | 显示全部楼层
Power Management 1 Control Register 这边的register应该在S4状态下就是被清掉的,因为当时已经没有电了,也不用那段code特意的清掉他们,直接没有电了;* f% B' Z/ h+ J* a/ m- }
所以你那code不起作用,你可以在进S4的时候,写systemflag到CMOS,再进行判断!
! N% u. \  {) q2 U: S' a! L8 ?" K个人认为这样oK;
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-12-21 15:29 , Processed in 0.398580 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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