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

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

[复制链接]
发表于 2009-5-15 15:48:20 | 显示全部楼层 |阅读模式
大家好,我在接案子的时候遇到个bebug :从S4回来可以进入bios setup.
6 x' _+ r- @4 H, P% u) \2 j( T; V我的解法是这样的,在POST的过程中系统检测按键的时候,我加了段代码去判断PM_BASE+04h的BIT10 – bit12是否等于110b。1 Q% L: b4 Y- X! a5 n2 N  N
代码如下:
% Z" N% F" b/ c* d& @VOID CheckForKey( EFI_EVENT Event, VOID *Context )$ W, u, X/ D  R! ~% t& r, \
{
/ l! m, }+ s- p% @6 g# B
7 w5 G" Z/ k* E8 v" {- ?………..  
, a+ [$ l/ N: a9 f3 u1 v0 _1 m' _' d  UINT8 Data,Data1;7 D: g; S* `! g6 a0 W- }: ~
1 f  X; c' o' I# C; L( u, H1 V# }
    Status = gBS->LocateProtocol (&gEfiCpuIoProtocolGuid, NULL, &gCpuIo);
, B5 ]( o7 V* W' u! t     if (EFI_ERROR(Status)) return;
) ]% }6 h) l7 x8 D: @5 B' l    Status=gCpuIo->Io.Read (gCpuIo, EfiCpuIoWidthUint8, 0x405 , 1, &Data);  //read PM BASE register 0x05,Get sleep type
9 o% v: {# a, u, e2 h6 j" H        if((Data == 0x18)){
# }0 t, t1 s8 N& T9 f# @          return;}
7 H; O# B8 M# `9 `! S& O……….…….
9 G) H' X0 z1 S8 {) o" m3 |' ~( U4 P}( T; `9 N4 j& k; @
可是仍然从S4回来可以进入bios setup.
1 a2 w# O0 u; M4 ~2 q0 L我想问1。PMBASE是不是在S4回来后被清空?, Q, \1 z0 i* r( @7 M. r
       2.是何时被清空的?
0 V9 e6 d- j0 Q& q0 S8 C: A谢谢
发表于 2012-5-28 11:24:42 | 显示全部楼层
Power Management 1 Control Register 这边的register应该在S4状态下就是被清掉的,因为当时已经没有电了,也不用那段code特意的清掉他们,直接没有电了;$ E, l# H4 Y( @7 n
所以你那code不起作用,你可以在进S4的时候,写systemflag到CMOS,再进行判断!# r: m$ A/ Q$ l6 [+ K
个人认为这样oK;
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-2-21 07:54 , Processed in 0.126710 second(s), 16 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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