73

帖子

0

TA的资源

一粒金砂(初级)

21
 
我的注册表里一直都是对的,但就是不准。

回复

65

帖子

0

TA的资源

一粒金砂(初级)

22
 
引用 17 楼 wangxin_801115 的回复:
在PUBLIC中
的power.cpp有设置休眠时间的函数
但是这个都是固定的不需要修改啊

在你的驱动中只需要读取注册表中你设置的休眠时间再乘1000
然后waitforsingleobject(xxx,挂起时间)

就可以了

你这个方法是怎么用的?
 
 

回复

64

帖子

0

TA的资源

一粒金砂(初级)

23
 
你是在哪读的 你设置的 注册表值的??
 
 
 

回复

63

帖子

0

TA的资源

一粒金砂(初级)

24
 
在你的驱动中只需要读取注册表中你设置的休眠时间
然后
创建一个线程
在线程中
waitforsingleobject(xxx,挂起时间)

把状态分为三个部分:繁忙、用户休眠、系统休眠
然后就是CASE.繁忙
       case:用户休眠
        case:系统休眠
这三个状态之间的顺序关系你自己定义,做什么操作也自己定义
 
 
 

回复

68

帖子

0

TA的资源

一粒金砂(初级)

25
 
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,挂起时间),这个方法你成功了吗?
 
 
 

回复

77

帖子

0

TA的资源

一粒金砂(初级)

26
 
成功了
但是现在还有点小问题
好象是线程有时候创建不成功
 
 
 

回复

61

帖子

0

TA的资源

一粒金砂(初级)

27
 
楼主怎么做的??
说说思路!
 
 
 

回复

62

帖子

0

TA的资源

一粒金砂(初级)

28
 
我是在驱动里改的,现在还在调试中
用户在使用时候,系统处于On状态,用户停止输入,系统自动转入UserIdle状态,持续没有输入时间后,进入SystemIdle状态,持续一段时间后,系统将自动进入Suspend状态,
我将UserIdle和SystemIdle这两个时间设置为很短,只留Suspend这个时间
 
 
 

回复

79

帖子

0

TA的资源

一粒金砂(初级)

29
 
一个思路!
我的问题已经找到了
一个逻辑想错了
 
 
 

回复

72

帖子

0

TA的资源

一粒金砂(初级)

30
 
怎么在开始菜单下放一个挂起的项??
开始菜单的程序在哪??
 
 
 

回复

74

帖子

0

TA的资源

一粒金砂(初级)

31
 
开始菜单里有挂起呀!
 
 
 

回复

65

帖子

0

TA的资源

一粒金砂(中级)

32
 
你这问题不是还没有解决吗?怎么结贴了
我觉得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

 
 
 

回复
您需要登录后才可以回帖 登录 | 注册

随便看看
查找数据手册?

EEWorld Datasheet 技术支持

相关文章 更多>>
关闭
站长推荐上一条 1/9 下一条

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

About Us 关于我们 客户服务 联系方式 器件索引 网站地图 最新更新 手机版

站点相关: 国产芯 安防电子 汽车电子 手机便携 工业控制 家用电子 医疗电子 测试测量 网络通信 物联网

北京市海淀区中关村大街18号B座15层1530室 电话:(010)82350740 邮编:100190

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2025 EEWORLD.com.cn, Inc. All rights reserved
快速回复 返回顶部 返回列表