📄 infiniteretrypowermanagerp.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.1 $ * $Date: 2008/05/17 02:18:09 $ * ======================================================================== */ /** * Please refer to TEP 115 for more information about this component and its * intended use.<br><br> * * This is the internal implementation of the standard 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 power down a device as soon as it becomes free. * Such a policy is useful whenever a device has a negligible wake-up * latency. There is no cost associated with waiting for the device to * power up, so it can be powered on and off as often as possible. * * @author Kevin Klues (klueska@cs.wustl.edu) */ generic module PowerManagerP() { uses { interface StdControl; interface SplitControl; interface PowerDownCleanup; interface ResourceDefaultOwner; interface ArbiterInfo; }}implementation { norace bool stopping = FALSE; norace bool requested = FALSE; task void startTask() { if(call StdControl.start() == SUCCESS) if(call SplitControl.start() == SUCCESS) return; post startTask(); } task void stopTask() { if(call StdControl.stop() == SUCCESS) if(call SplitControl.stop() == SUCCESS) return; post startTask(); } async event void ResourceDefaultOwner.requested() { if(stopping == FALSE) { post startTask(); } else requested = TRUE; } async event void ResourceDefaultOwner.immediateRequested() { } default command error_t StdControl.start() { return SUCCESS; } default command error_t SplitControl.start() { signal SplitControl.startDone(SUCCESS); return SUCCESS; } event void SplitControl.startDone(error_t error) { if(error != SUCCESS) { post startTask(); return; } if(call ResourceDefaultOwner.isOwner()) call ResourceDefaultOwner.release(); } async event void ResourceDefaultOwner.granted() { atomic stopping = TRUE; call PowerDownCleanup.cleanup(); post stopTask(); } event void SplitControl.stopDone(error_t error) { if(error != SUCCESS) { post stopTask(); return; } if(requested == TRUE) { call StdControl.start(); call SplitControl.start(); } atomic { requested = FALSE; stopping = FALSE; } } default command error_t StdControl.stop() { return SUCCESS; } default command error_t SplitControl.stop() { signal SplitControl.stopDone(SUCCESS); return SUCCESS; } default async command void PowerDownCleanup.cleanup() { }}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -