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

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

[复制链接]
发表于 2009-5-15 15:48:20 | 显示全部楼层 |阅读模式
大家好,我在接案子的时候遇到个bebug :从S4回来可以进入bios setup.5 _+ z1 y% ^& u" P8 b/ t
我的解法是这样的,在POST的过程中系统检测按键的时候,我加了段代码去判断PM_BASE+04h的BIT10 – bit12是否等于110b。. r  F9 {4 q7 N$ u7 H$ S! H
代码如下:' `# Y  @! t& V. ]8 L
VOID CheckForKey( EFI_EVENT Event, VOID *Context )
% ]  ~! n% `4 d: N  |1 A{
2 m8 o! }/ E3 W$ P0 ?1 U1 R( A9 J- x& @# Z: ?3 H2 c
………..  
4 `1 _; k! v( ]  UINT8 Data,Data1;
- d# n7 v, D3 M
3 f) u; F* e3 i    Status = gBS->LocateProtocol (&gEfiCpuIoProtocolGuid, NULL, &gCpuIo);9 V1 R- P8 ]  v% y* t* L' ?
     if (EFI_ERROR(Status)) return;
' m7 n- n' p3 t9 s, y$ Q, H    Status=gCpuIo->Io.Read (gCpuIo, EfiCpuIoWidthUint8, 0x405 , 1, &Data);  //read PM BASE register 0x05,Get sleep type4 u; D4 |# F4 L0 i3 c" u  ^# Z
        if((Data == 0x18)){- T3 O; m8 ~4 m! j" U
          return;}
7 Y0 N6 J( @% V1 N……….……." N% f, C6 z3 z2 w$ w: r, {
}- M' C: p; z# W" u
可是仍然从S4回来可以进入bios setup.$ Q; l6 m- c7 O% v: Q- E; K4 O
我想问1。PMBASE是不是在S4回来后被清空?. v  {: {2 J6 T/ s. n3 [6 D
       2.是何时被清空的?
$ U- `# _4 M. V  S  q4 f6 [0 A谢谢
发表于 2012-5-28 11:24:42 | 显示全部楼层
Power Management 1 Control Register 这边的register应该在S4状态下就是被清掉的,因为当时已经没有电了,也不用那段code特意的清掉他们,直接没有电了;: X, u$ c+ m- y8 s: H
所以你那code不起作用,你可以在进S4的时候,写systemflag到CMOS,再进行判断!
" r% }/ x$ X; }/ J3 g% k# m( p个人认为这样oK;
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-2-1 12:35 , Processed in 0.056559 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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