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

📄 hplclock.nc

📁 无线传感器网络中的节点定位算法。详见ReadMe文件。在TinyOS上实现的节点定位算法。
💻 NC
字号:
// $Id: HPLClock.nc,v 1.1 2004/09/24 21:44:32 dcm 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:		Jason Hill, David Gay, Philip Levis * Date last modified:  6/25/02 * */// The Mica-specific parts of the hardware presentation layer./** * @author Jason Hill * @author David Gay * @author Philip Levis */module HPLClock {    provides {        interface Clock;        interface StdControl;        async command uint32_t GetClock();        async command uint32_t GetClockSec();        async command uint16_t GetClockLow();    }}implementation{    uint8_t set_flag;    uint8_t mscale, nextScale, minterval ;    uint32_t systime;    command result_t StdControl.init() {      atomic {	mscale = DEFAULT_SCALE; 	minterval = DEFAULT_INTERVAL;      }      return SUCCESS;    }    command result_t StdControl.start() {      uint8_t mi, ms;      atomic {	mi = minterval;	ms = mscale;        systime = 0;      }            call Clock.setRate(mi, ms);      return SUCCESS;    }    command result_t StdControl.stop() {      uint8_t mi;      atomic {	mi = minterval;      }      call Clock.setRate(mi, 0);      return SUCCESS;    }    async command void Clock.setInterval(uint8_t value) {        outp(value, OCR0);    }     async command void Clock.setNextInterval(uint8_t value) {      atomic {	minterval = value;	set_flag = 1;      }    }    async command uint8_t Clock.getInterval() {        return inp(OCR0);    }    async command uint8_t Clock.getScale() {      uint8_t ms;      atomic {	ms = mscale;      }            return ms;    }    async command void Clock.setNextScale(uint8_t scale) {      atomic {	nextScale= scale;        set_flag=1;      }    }           async command result_t Clock.setIntervalAndScale(uint8_t interval, uint8_t scale) {                if (scale >7) return FAIL;        scale|=0x8;	atomic {	  cbi(TIMSK, OCIE0);	  outp(scale, TCCR0);	  mscale = scale;	  outp(0,TCNT0);	  outp(interval, OCR0);	  minterval = interval;	  sbi(TIMSK, OCIE0);	}        return SUCCESS;    }            async command uint8_t Clock.readCounter() {        return (inp(TCNT0));    }    async command void Clock.setCounter(uint8_t n) {        outp(n, TCNT0);    }    async command void Clock.intDisable() {        cbi(TIMSK, OCIE0);    }    async command void Clock.intEnable() {        sbi(TIMSK, OCIE0);    }  async command result_t Clock.setRate(char interval, char scale) {    scale &= 0x7;    scale |= 0x8;    atomic {      cbi(TIMSK, TOIE0);      cbi(TIMSK, OCIE0);     //Disable TC0 interrupt      sbi(ASSR, AS0);        //set Timer/Counter0 to be asynchronous      //from the CPU clock with a second external      //clock(32,768kHz)driving it.      outp(scale, TCCR0);    //prescale the timer to be clock/128 to make it      outp(0, TCNT0);      outp(interval, OCR0);      sbi(TIMSK, OCIE0);    }    return SUCCESS;  }  /* DCM: GetClock tells us the elapsed system time in units of 1024ths   * of a second.  The value rolls over after approximately 48 days. */  async command uint32_t GetClock() {      uint32_t clk;      atomic {          clk = systime;          /* If the clock has rolled over but the interrupt is still           * pending, we need to correct the time. */          if (inp(TIFR) & (1 << OCF0))              clk += inp(OCR0) + 1;          clk += (uint32_t)inp(TCNT0);      }      return clk;  }  /* DCM: GetClockSec tells us the elapsed system time in seconds.   * The value rolls over after approximately 48 days. */  async command uint32_t GetClockSec() {      return (call GetClock()) >> 10;  }  /* DCM: GetClockLow tells us the elapsed system time in units of 1024ths   * of a second and gives us the low 16 bits.  This value rolls over every   * 64 seconds. */  async command uint16_t GetClockLow() {      uint16_t clk;      atomic {          clk = systime;          /* If the clock has rolled over but the interrupt is still           * pending, we need to correct the time. */          if (inp(TIFR) & (1 << OCF0))              clk += inp(OCR0) + 1;          clk += (uint16_t)inp(TCNT0);      }      return clk;  }  default async event result_t Clock.fire() { return SUCCESS; }  TOSH_SIGNAL(SIG_OUTPUT_COMPARE0) {    if (set_flag) {	mscale = nextScale;	nextScale|=0x8;	outp(nextScale, TCCR0);		outp(minterval, OCR0);	set_flag=0;    }    systime += inp(OCR0);    systime += 1;    signal Clock.fire();  }}

⌨️ 快捷键说明

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