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

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

[复制链接]
发表于 2009-5-15 15:48:20 | 显示全部楼层 |阅读模式
大家好,我在接案子的时候遇到个bebug :从S4回来可以进入bios setup.4 ^7 J1 p$ X/ H4 ]' F5 M0 ~
我的解法是这样的,在POST的过程中系统检测按键的时候,我加了段代码去判断PM_BASE+04h的BIT10 – bit12是否等于110b。. w; u; V9 r8 ~" G. Y+ Z' {
代码如下:
3 z% [$ N0 U/ [) u1 G# Y5 SVOID CheckForKey( EFI_EVENT Event, VOID *Context )
" X/ P9 V+ O0 E/ K3 L! A{
( }" k6 f* a# j( p8 R/ F' A% f$ P% D0 q, v  {
………..  % K2 U" U- p3 C2 j' Z6 A  W7 s' `
  UINT8 Data,Data1;( b' c9 i0 I7 O

# D+ i3 Y) H7 L  P0 P- S) K" F! U    Status = gBS->LocateProtocol (&gEfiCpuIoProtocolGuid, NULL, &gCpuIo);
( [: t4 P+ c$ E* E& {7 {     if (EFI_ERROR(Status)) return;
; U: G& a" j3 f! k    Status=gCpuIo->Io.Read (gCpuIo, EfiCpuIoWidthUint8, 0x405 , 1, &Data);  //read PM BASE register 0x05,Get sleep type
% a( w( g+ R- c* @5 e% ?2 `        if((Data == 0x18)){$ }% ~1 [- U8 t& Q9 B4 F
          return;}
7 W) W% m/ d4 Y. V……….…….
8 {4 u$ g$ o1 h8 C* c}9 h6 z6 K6 |; Y) W8 ^; `: T
可是仍然从S4回来可以进入bios setup.
7 y, P: ?% L: {. W7 B8 o我想问1。PMBASE是不是在S4回来后被清空?4 {9 z$ f# A# F  H5 S. h. ]
       2.是何时被清空的?
* ~% Z/ s. n7 o7 c% E谢谢
发表于 2012-5-28 11:24:42 | 显示全部楼层
Power Management 1 Control Register 这边的register应该在S4状态下就是被清掉的,因为当时已经没有电了,也不用那段code特意的清掉他们,直接没有电了;
7 ~2 @3 }; m, m% i- v/ d$ i- ^所以你那code不起作用,你可以在进S4的时候,写systemflag到CMOS,再进行判断!
) ?, Q* a: h) ]+ S' ?" V个人认为这样oK;
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-5-22 02:24 , Processed in 0.033525 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2023 Discuz! Team.

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