📄 periodicsampleloggerp.nc
字号:
/*
* Copyright (c) 2007 Stanford University.
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
* - Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* - Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the
* distribution.
* - Neither the name of the Stanford University nor the names of
* its contributors may be used to endorse or promote products derived
* from this software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
* ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL STANFORD
* UNIVERSITY OR ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
* STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
* OF THE POSSIBILITY OF SUCH DAMAGE.
*/
/**
* @author Kevin Klues <klueska@cs.stanford.edu>
* @date July 24, 2007
*/
generic module PeriodicSampleLoggerP(uint32_t period_ms,
uint8_t num_sensors,
typedef sensor_type_t) {
uses {
interface Boot;
interface Read<sensor_type_t> as Sensor[uint8_t];
interface Timer<TMilli> as Timer;
interface LogWrite;
interface Leds;
}
}
implementation {
#include "GenericSensorSample.h"
generic_sensor_sample_t sample[2];
generic_sensor_sample_t* current_sample;
uint8_t current_sample_id;
task void eraseTask();
task void appendTask();
void readSensors() {
int i;
for(i=0; i<num_sensors; i++)
call Sensor.read[i]();
}
void appendSample(generic_sensor_sample_t* s) {
//printf("WRITE LOC: %d\n", call LogWrite.currentOffset());
if(call LogWrite.append(s, sizeof(generic_sensor_sample_t)) != SUCCESS)
post appendTask();
}
task void eraseTask() {
if(call LogWrite.erase() != SUCCESS)
post eraseTask();
}
task void appendTask() {
appendSample(&(sample[!current_sample_id]));
}
event void Boot.booted() {
if(call LogWrite.erase() != SUCCESS)
post eraseTask();
}
event void LogWrite.eraseDone(error_t error) {
sample[0].sample_num = 0;
sample[1].sample_num = 1;
current_sample_id = 0;
current_sample = &(sample[current_sample_id]);
readSensors();
call Timer.startPeriodic(period_ms);
}
event void Timer.fired() {
call Leds.led0Toggle();
appendSample(current_sample);
current_sample_id = !current_sample_id;
current_sample = &(sample[current_sample_id]);
readSensors();
}
event void Sensor.readDone[uint8_t i](error_t result, sensor_type_t val) {
if(result == SUCCESS) {
current_sample->values[i] = val;
call Leds.led1Toggle();
}
else {
current_sample->values[i] = ((generic_sensor_sample_type_union_t)(0xFFFFFFFF)).st;
call Leds.led2Toggle();
}
}
event void LogWrite.appendDone(void* buf, storage_len_t len, bool recordsLost, error_t error){
if(error != SUCCESS)
post appendTask();
else ((generic_sensor_sample_t*)buf)->sample_num+=2;
}
event void LogWrite.syncDone(error_t error) {}
default command error_t Sensor.read[uint8_t i]() {return SUCCESS;}
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -