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

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

[复制链接]
发表于 2009-5-15 15:48:20 | 显示全部楼层 |阅读模式
大家好,我在接案子的时候遇到个bebug :从S4回来可以进入bios setup.
9 @2 N* u9 S6 {" Q2 h我的解法是这样的,在POST的过程中系统检测按键的时候,我加了段代码去判断PM_BASE+04h的BIT10 – bit12是否等于110b。0 q2 [- s* z0 U4 b
代码如下:5 }5 c% W& B: U: P; b) I7 g& O7 K$ ?
VOID CheckForKey( EFI_EVENT Event, VOID *Context )
! b6 ?$ Z& y  z: Y( G{
' F/ `: k9 A, s7 y5 v* ~* q3 S# F1 j+ e; _7 ?5 @$ s) d
………..  
; T% Q+ D$ g5 O- O  `  UINT8 Data,Data1;( _' O0 X1 p% S1 K. Y

/ G; e* d2 b  S& [    Status = gBS->LocateProtocol (&gEfiCpuIoProtocolGuid, NULL, &gCpuIo);
! V$ i, P, }# {% ^3 r+ R5 Y' {  v. y  f     if (EFI_ERROR(Status)) return;0 @, H8 z* e, r
    Status=gCpuIo->Io.Read (gCpuIo, EfiCpuIoWidthUint8, 0x405 , 1, &Data);  //read PM BASE register 0x05,Get sleep type5 l  ]$ c. k( N) W) }' E# O- N. ?0 t
        if((Data == 0x18)){
. u1 |+ ~& v5 W6 d          return;}
; O3 A" Q. U% c3 s……….…….
5 L! W$ O7 L, J1 d}
& [, o5 s" {$ G3 c. E7 N9 c9 V+ b2 _可是仍然从S4回来可以进入bios setup.9 C( L" v) `6 V7 Y
我想问1。PMBASE是不是在S4回来后被清空?& q5 j$ \# n( E$ d" E$ t
       2.是何时被清空的?
# _# Z1 b7 q' U谢谢
发表于 2012-5-28 11:24:42 | 显示全部楼层
Power Management 1 Control Register 这边的register应该在S4状态下就是被清掉的,因为当时已经没有电了,也不用那段code特意的清掉他们,直接没有电了;* ^$ t4 g! N" ^7 T" Q' i, u! C/ z- y
所以你那code不起作用,你可以在进S4的时候,写systemflag到CMOS,再进行判断!
- h6 ]4 Z& Y1 w5 W& w个人认为这样oK;
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-4-24 22:37 , Processed in 0.041497 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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