📄 asyncdeferredpowermanagerp.nc
字号:
/*
* "Copyright (c) 2005 Washington University in St. Louis.
* All rights reserved.
*
* Permission to use, copy, modify, and distribute this software and its
* documentation for any purpose, without fee, and without written agreement is
* hereby granted, provided that the above copyright notice, the following
* two paragraphs and the author appear in all copies of this software.
*
* IN NO EVENT SHALL WASHINGTON UNIVERSITY IN ST. LOUIS BE LIABLE TO ANY PARTY
* FOR DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES ARISING
* OUT OF THE USE OF THIS SOFTWARE AND ITS DOCUMENTATION, EVEN IF WASHINGTON
* UNIVERSITY IN ST. LOUIS HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*
* WASHINGTON UNIVERSITY IN ST. LOUIS SPECIFICALLY DISCLAIMS ANY WARRANTIES,
* INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY
* AND FITNESS FOR A PARTICULAR PURPOSE. THE SOFTWARE PROVIDED HEREUNDER IS
* ON AN "AS IS" BASIS, AND WASHINGTON UNIVERSITY IN ST. LOUIS HAS NO
* OBLIGATION TO PROVIDE MAINTENANCE, SUPPORT, UPDATES, ENHANCEMENTS, OR
* MODIFICATIONS."
*
*/
/*
* - Revision -------------------------------------------------------------
* $Revision: 1.5 $
* $Date: 2007/02/04 19:55:23 $
* ========================================================================
*/
/**
* Please refer to TEP 115 for more information about this component and its
* intended use.<br><br>
*
* This is the internal implementation of the deffered power management
* policy for managing the power states of non-virtualized devices.
* Non-virtualized devices are shared using a parameterized Resource
* interface, and are powered down according to some policy whenever there
* are no more pending requests to that Resource. The policy implemented
* by this component is to delay the power down of a device by some contant
* factor. Such a policy is useful whenever a device has a long wake-up
* latency. The cost of waiting for the device to power up can be
* avoided if the device is requested again before some predetermined
* amount of time.
*
* @param <b>delay</b> -- The amount of time the power manager should wait
* before shutting down the device once it is free.
*
* @author Kevin Klues (klueska@cs.wustl.edu)
*/
generic module AsyncDeferredPowerManagerP(uint32_t delay) {
uses {
interface AsyncStdControl;
interface PowerDownCleanup;
interface ResourceDefaultOwner;
interface ArbiterInfo;
interface Timer<TMilli> as TimerMilli;
}
}
implementation {
norace bool stopTimer = FALSE;
task void stopTimerTask() {
call TimerMilli.stop();
stopTimer = FALSE;
}
task void timerTask() {
if(stopTimer == FALSE)
call TimerMilli.startOneShot(delay);
}
async event void ResourceDefaultOwner.requested() {
stopTimer = TRUE;
post stopTimerTask();
call AsyncStdControl.start();
call ResourceDefaultOwner.release();
}
async event void ResourceDefaultOwner.immediateRequested() {
stopTimer = TRUE;
post stopTimerTask();
call AsyncStdControl.start();
call ResourceDefaultOwner.release();
}
async event void ResourceDefaultOwner.granted() {
post timerTask();
}
event void TimerMilli.fired() {
if(stopTimer == FALSE) {
call PowerDownCleanup.cleanup();
call AsyncStdControl.stop();
}
}
default async command void PowerDownCleanup.cleanup() {
}
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -