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

📄 logger.c

📁 无线传感器网络操作系统源代码
💻 C
字号:
/* * @(#)LOGGER.c * * "Copyright (c) 2001 and 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 and the following * two paragraphs 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." * * Author:  Philip Levis * * This component implements the logger for the simulator. * */#include "tos.h"#include "LOGGER.h"#include "dbg.h"#include "eeprom.h"void event_logger_handle(event_t* event, struct TOS_state* state);void event_logger_cleanup(event_t* event);void event_logger_create(event_t* event, int mote, long long time);     // Logger states.#define PHASE      1#define IDLE       0#define SEND_CMD   1#define READ_DATA  2#define WRITE_DATA 4/* Parameters for configuring the logger: *//* The log entry is of size 2 ^ LOG_2_SIZE */#define LOG_2_SIZE 4#define LOGGER_DELAY 40000   // 10 milliseconds (40,000 cycles) #define LOG_ENTRY_SIZE (1 << LOG_2_SIZE)/* Maximum number of log entries: 32768 / 16 => 2048 lines*/#define LOGGER_MAX_LINES (0x8000 >> LOG_2_SIZE)#define APPEND_ADDR_START 16#define TOS_FRAME_TYPE LOGGER_obj_frameTOS_FRAME_BEGIN(LOGGER_obj_frame) {    char state;    char *data_buf;    char data_len;    int last_line;    int read_line;    event_t event;}TOS_FRAME_END(LOGGER_obj_frame);char TOS_COMMAND(READ_LOG) (short line, char * data) {  if (VAR(state) == IDLE) {    VAR(data_buf) = data;    VAR(state) = READ_DATA;    VAR(data_len) = LOG_ENTRY_SIZE;    VAR(read_line) = line;    VAR(event).time = tos_state.tos_time + LOGGER_DELAY;    TOS_queue_insert_event(&VAR(event));    return 1;  }  else {    return 0;  }}char TOS_COMMAND(APPEND_LOG) (char *data) {  return TOS_CALL_COMMAND(WRITE_LOG)((short)VAR(last_line)+1, data);}char TOS_COMMAND(WRITE_LOG) (short line, char * data) {  if (VAR(state)== IDLE) {    VAR(data_buf) = data;    VAR(data_len) = LOG_ENTRY_SIZE;    VAR(last_line) = line;    VAR(state) = WRITE_DATA;    VAR(event).time = tos_state.tos_time + LOGGER_DELAY;    TOS_queue_insert_event(&VAR(event));    return 1;  }  else {    return 0;  }}char TOS_COMMAND(LOGGER_INIT) (void) {  VAR(state) = IDLE;  VAR(last_line) = APPEND_ADDR_START;  event_logger_create(&VAR(event), NODE_NUM, 0);  dbg(DBG_BOOT, ("Logger initialized.\n"));  return 1;}char TOS_EVENT(LOGGER_SPI_BYTE_DONE) (unsigned char in) {  if (VAR(state) == READ_DATA) {    int rval;    VAR(state) = IDLE;    rval = readEEPROM(VAR(data_buf), NODE_NUM, VAR(read_line) * LOG_ENTRY_SIZE, LOG_ENTRY_SIZE);    if (rval == 0) {      int i;      dbg(DBG_LOG, ("LOGGER: Log read of line %i completed.\n", VAR(read_line)));      dbg_clear(DBG_LOG, ("\t["));      for (i = 0; i < LOG_ENTRY_SIZE; i++) {	dbg_clear(DBG_LOG, ("%2hhx", VAR(data_buf)[i]));	dbg_clear(DBG_LOG, ("]\n"));      }    }    TOS_SIGNAL_EVENT(READ_LOG_DONE) (VAR(data_buf), 1);  }  else if (VAR(state) == WRITE_DATA) {    int rval;    VAR(state) = IDLE;    rval = writeEEPROM(VAR(data_buf), NODE_NUM, VAR(last_line) * LOG_ENTRY_SIZE, LOG_ENTRY_SIZE);    if (rval == 0) {      int i;      dbg(DBG_LOG, ( "LOGGER: Log write to line %i completed\n", VAR(last_line)));      dbg_clear(DBG_LOG, ("\t["));      for (i = 0; i < LOG_ENTRY_SIZE; i++) {	dbg_clear(DBG_LOG, ("%2hhx", VAR(data_buf)[i]));      }      dbg_clear(DBG_LOG, ("]\n"));    }    TOS_SIGNAL_EVENT(APPEND_LOG_DONE)(1);  }  else {    dbg(DBG_LOG | DBG_ERROR, ("LOGGER: Operation completed when unknown operation specified!\n"));  }  return 1;}void event_logger_handle(event_t* event, struct TOS_state* state) {  TOS_SIGNAL_EVENT(LOGGER_SPI_BYTE_DONE)(0);}void event_logger_cleanup(event_t* event) {  // Since logger events are statically allocated,  // we shouldn't deallocate anything; since this function  // should never be called, we set the fields so they  // will cause a SEGV if used as is.  event->time = -1;  event->handle = 0;  event->cleanup = 0;  event->mote = 0xffffffff;  return;}void event_logger_create(event_t* event, int mote, long long time) {  event->mote = mote;  event->time = time;  event->data = NULL;  event->handle = event_logger_handle;  event->cleanup = event_logger_cleanup;  event->pause = 0;}

⌨️ 快捷键说明

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