⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 timerm.nc

📁 nesC写的heed算法
💻 NC
字号:
// $Id: TimerM.nc,v 1.17.2.7 2003/08/26 09:08:17 cssharp Exp $/*									tab:4 * "Copyright (c) 2000-2003 The Regents of the University  of California.   * 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 THE UNIVERSITY OF CALIFORNIA 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 THE UNIVERSITY OF * CALIFORNIA HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. *  * THE UNIVERSITY OF CALIFORNIA 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 THE UNIVERSITY OF CALIFORNIA HAS NO OBLIGATION TO * PROVIDE MAINTENANCE, SUPPORT, UPDATES, ENHANCEMENTS, OR MODIFICATIONS." * * Copyright (c) 2002-2003 Intel Corporation * All rights reserved. * * This file is distributed under the terms in the attached INTEL-LICENSE      * file. If you do not find these files, copies can be found by writing to * Intel Research Berkeley, 2150 Shattuck Avenue, Suite 1300, Berkeley, CA,  * 94704.  Attention:  Intel License Inquiry. *//* * * Authors:             Su Ping <sping@intel-research.net> * Revision:            $Id: TimerM.nc,v 1.17.2.7 2003/08/26 09:08:17 cssharp Exp $ * This implementation assumes that DEFAULT_SCALE is 3. *//** * @author Su Ping <sping@intel-research.net> */module TimerM {    provides interface Timer[uint8_t id];    provides interface StdControl;    uses {	interface Leds;	interface Clock;	interface PowerManagement;    }}implementation {    uint32_t mState;		// each bit represent a timer state     uint8_t  setIntervalFlag;     uint8_t mScale, mInterval;    int8_t queue_head;    int8_t queue_tail;    uint8_t queue_size;    uint8_t queue[NUM_TIMERS];    struct timer_s {        uint8_t type;		// one-short or repeat timer        int32_t ticks;		// clock ticks for a repeat timer         int32_t ticksLeft;	// ticks left before the timer expires    } mTimerList[NUM_TIMERS];      enum {	maxTimerInterval = 230    };    command result_t StdControl.init() {        mState=0;        setIntervalFlag = 0;        queue_head = queue_tail = -1;        queue_size = 0;        mScale = 3;        mInterval = maxTimerInterval;        return call Clock.setRate(mInterval, mScale) ;    }    command result_t StdControl.start() {        return SUCCESS;    }    command result_t StdControl.stop() {        mState=0;        mInterval = maxTimerInterval;        setIntervalFlag = 0;        return SUCCESS;    }    command result_t Timer.start[uint8_t id](char type, 				   uint32_t interval) {	uint8_t diff;        if (id >= NUM_TIMERS) return FAIL;        if (type>1) return FAIL;        mTimerList[id].ticks = interval ;        mTimerList[id].type = type;	        atomic {            diff = inp(TCNT0);            interval += diff;            mTimerList[id].ticksLeft = interval;            mState|=(0x1<<id);            if (interval < mInterval) {                mInterval=interval;                call Clock.setInterval(mInterval);                setIntervalFlag = 0;                call PowerManagement.adjustPower();            }	}         return SUCCESS;    }    static void adjustInterval() {        uint8_t i, val = maxTimerInterval;        if ( mState) {            for (i=0;i<NUM_TIMERS;i++) {                if ((mState&(0x1<<i)) && (mTimerList[i].ticksLeft <val )) {                    val = mTimerList[i].ticksLeft;		}            }            atomic {                mInterval =  val;                call Clock.setInterval(mInterval);                setIntervalFlag = 0;            }        } else {            atomic {              mInterval=maxTimerInterval;              call Clock.setInterval(mInterval);              setIntervalFlag = 0;            }        }	call PowerManagement.adjustPower();    }    command result_t Timer.stop[uint8_t id]() {        if (id>=NUM_TIMERS) return FAIL;        if (mState&(0x1<<id)) { // if the timer is running 	    atomic mState &= ~(0x1<<id);	    if (!mState) {	        setIntervalFlag = 1;	    } 	            return SUCCESS;        }        return FAIL; //timer not running    }    default event result_t Timer.fired[uint8_t id]() {        return SUCCESS;    }    void enqueue(uint8_t value) {      if (queue_tail == NUM_TIMERS - 1)	queue_tail = -1;      queue_tail++;      queue_size++;      queue[(uint8_t)queue_tail] = value;    }    uint8_t dequeue() {      if (queue_size == 0)        return NUM_TIMERS;      if (queue_head == NUM_TIMERS - 1)        queue_head = -1;      queue_head++;      queue_size--;      return queue[(uint8_t)queue_head];    }    task void signalOneTimer() {      uint8_t itimer = dequeue();      if (itimer < NUM_TIMERS)        signal Timer.fired[itimer]();    }    task void HandleFire() {        uint8_t i; 	setIntervalFlag = 1;        if (mState) {            for (i=0;i<NUM_TIMERS;i++)  {                if (mState&(0x1<<i)) {                    mTimerList[i].ticksLeft -= (mInterval+1) ;                     if (mTimerList[i].ticksLeft<=2) {                        if (mTimerList[i].type==TIMER_REPEAT) {                            mTimerList[i].ticksLeft += mTimerList[i].ticks;                        } else {// one shot timer                             mState &=~(0x1<<i);                         }                        enqueue(i);			post signalOneTimer();                    }                }            }        }	adjustInterval();    }    async event result_t Clock.fire() {	post HandleFire();        return SUCCESS;    }}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -