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

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

[复制链接]
发表于 2009-5-15 15:48:20 | 显示全部楼层 |阅读模式
大家好,我在接案子的时候遇到个bebug :从S4回来可以进入bios setup.9 I1 N2 }8 ~  f$ D: r' @/ g
我的解法是这样的,在POST的过程中系统检测按键的时候,我加了段代码去判断PM_BASE+04h的BIT10 – bit12是否等于110b。
& ?) y: {1 B. j8 Z3 P3 e  ]代码如下:
" [# N2 }7 h) L" T+ EVOID CheckForKey( EFI_EVENT Event, VOID *Context )
# s! ~2 ^% g5 W- z$ X" m{
8 {& }  M& w7 u3 r" Q
, x1 ~8 y: L9 X………..  5 M+ L0 C& `3 ?8 a4 e
  UINT8 Data,Data1;. b# L. w' M7 m4 u7 r

# H7 Z7 j1 x/ G; w6 v    Status = gBS->LocateProtocol (&gEfiCpuIoProtocolGuid, NULL, &gCpuIo);
! e+ Q8 N0 o/ X1 W3 p' Q4 X     if (EFI_ERROR(Status)) return;
1 a2 K+ G; i/ x( g! `) I, ~    Status=gCpuIo->Io.Read (gCpuIo, EfiCpuIoWidthUint8, 0x405 , 1, &Data);  //read PM BASE register 0x05,Get sleep type% B% _8 ]& a- x3 j; Y& m1 ?, ]
        if((Data == 0x18)){
) k4 P3 v/ C3 R* c9 B; Q          return;}+ y& J/ b7 a0 K) t! [& q
……….…….) s+ J+ _  T2 r0 B8 D" @
}% ]8 M6 d. N3 r# K8 `
可是仍然从S4回来可以进入bios setup.
( H% q) `$ |. y( B$ x* O我想问1。PMBASE是不是在S4回来后被清空?
( _$ K* r, A/ n& J8 v7 _) C       2.是何时被清空的?% M- _8 q( I/ @0 i* {
谢谢
发表于 2012-5-28 11:24:42 | 显示全部楼层
Power Management 1 Control Register 这边的register应该在S4状态下就是被清掉的,因为当时已经没有电了,也不用那段code特意的清掉他们,直接没有电了;
, x. ?. a  Q7 S' G9 u: i所以你那code不起作用,你可以在进S4的时候,写systemflag到CMOS,再进行判断!
7 f6 o* A& l# R. d. }/ s: P个人认为这样oK;
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-12-13 14:03 , Processed in 0.110072 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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