在你的驱动中只需要读取注册表中你设置的休眠时间
然后
创建一个线程
在线程中
waitforsingleobject(xxx,挂起时间)
把状态分为三个部分:繁忙、用户休眠、系统休眠
然后就是CASE.繁忙
case:用户休眠
case:系统休眠
这三个状态之间的顺序关系你自己定义,做什么操作也自己定义
HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\Power\ActivityTimers\UserActivity
HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\Power\ActivityTimers\SystemActivity
这两项编出来就有,
HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\Power\Timeouts
在这里有UserIdle ,SystemIdle ,Suspend三个的设置的值。
另外,waitforsingleobject(xxx,挂起时间),这个方法你成功了吗?
成功了
但是现在还有点小问题
好象是线程有时候创建不成功
我是在驱动里改的,现在还在调试中
用户在使用时候,系统处于On状态,用户停止输入,系统自动转入UserIdle状态,持续没有输入时间后,进入SystemIdle状态,持续一段时间后,系统将自动进入Suspend状态,
我将UserIdle和SystemIdle这两个时间设置为很短,只留Suspend这个时间
怎么在开始菜单下放一个挂起的项??
开始菜单的程序在哪??
你这问题不是还没有解决吗?怎么结贴了
我觉得23楼的做法不是根本解决问题的办法,而且系统已经提供了PM来切换状态,这样做反倒有可能导致系统的不正常。
其实找出这问题的根本原因应该不难,你先platform.cpp中的Message打开
// wait for an event; keep track of elapsed time
dwStartTime = GetTickCount();
dwStatus = WaitForMultipleObjects(dwNumEvents, hEvents, FALSE, dwTimeout);
dwElapsedTime = GetTickCount() - dwStartTime;
PMLOGMSG(ZONE_PLATFORM,
(_T("%s: wait returned %d, elapsed time %d, timeout was %d\r\n"), pszFname,
dwStatus, dwElapsedTime, dwTimeout));
如果你没有自己定制过PM的话,那就写一个小AP实时的调用一下函数GetTickCount();,然后看它跟实际的时间对不对得上,如果可以对上的话应该是不会有问题,如果对不上,请检查OEMInit()中调用的OALTimerInit(1, OEM_TICKS_1MS, OEM_TICK_COUNT_MARGIN);
下面是Intel PXA270的设定:
#define OEM_CLOCK_FREQ 3250000 // 3.25M ticks/sec
#define OEM_TICKS_1MS 3250 // 1ms in ticks
其它的CPU可能要查看其CPU的Spec