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

📄 blockingblockstorageimplp.nc

📁 tinyos2.0版本驱动
💻 NC
字号:
/* * Copyright (c) 2008 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. */ /* * Copyright (c) 2008 Johns Hopkins University. * 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 (updated) modification history and the author appear in * all copies of this source code. * * 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 THE COPYRIGHT HOLDERS OR CONTRIBUTORS * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, LOSS OF USE, DATA, * OR PROFITS) 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> * @author Chieh-Jan Mike Liang <cliang4@cs.jhu.edu> */ module BlockingBlockStorageImplP {  provides {    interface Init;    interface BlockingBlock[uint8_t volume_id];  }  uses {    interface BlockRead[uint8_t volume_id];    interface BlockWrite[uint8_t volume_id];    interface SystemCall;    interface SystemCallQueue;  }}implementation {    typedef struct read_write_params {    storage_addr_t addr;    void*          buf;    storage_len_t* len;    error_t        error;  } read_write_params_t;    typedef struct crc_params {    storage_addr_t addr;    storage_len_t* len;    uint16_t       crc;    uint16_t       *finalCrc;        error_t        error;  } crc_params_t;    typedef struct erase_sync_params {    error_t error;  } erase_sync_params_t;  syscall_queue_t vol_queue;  command error_t Init.init() {    call SystemCallQueue.init(&vol_queue);    return SUCCESS;  }  command storage_len_t BlockingBlock.getSize[uint8_t volume_id]() {    return call BlockRead.getSize[volume_id]();  }    /**************************** Reading ********************************/  void readTask(syscall_t* s) {    read_write_params_t* p = s->params;    p->error = call BlockRead.read[s->id](p->addr, p->buf, *(p->len));    if(p->error != SUCCESS)      call SystemCall.finish(s);  }    command error_t BlockingBlock.read[uint8_t volume_id](storage_addr_t addr, void *buf, storage_len_t* len) {    syscall_t s;    read_write_params_t p;    atomic {      if(call SystemCallQueue.find(&vol_queue, volume_id) != NULL)        return EBUSY;      call SystemCallQueue.enqueue(&vol_queue, &s);    }        p.addr = addr;    p.buf = buf;    p.len = len;    call SystemCall.start(&readTask, &s, volume_id, &p);        atomic {      call SystemCallQueue.remove(&vol_queue, &s);      return p.error;    }  }  event void BlockRead.readDone[uint8_t volume_id](storage_addr_t addr, void *buf, storage_len_t len, error_t error) {    syscall_t* s = call SystemCallQueue.find(&vol_queue, volume_id);    read_write_params_t* p = s->params;    p->error = error;    *(p->len) = len;    call SystemCall.finish(s);  }    /**************************** Writing ********************************/  void writeTask(syscall_t* s) {    read_write_params_t* p = s->params;    p->error = call BlockWrite.write[s->id](p->addr, p->buf, *(p->len));    if(p->error != SUCCESS)      call SystemCall.finish(s);  }    command error_t BlockingBlock.write[uint8_t volume_id](storage_addr_t addr, void* buf, storage_len_t* len) {    syscall_t s;    read_write_params_t p;    atomic {      if(call SystemCallQueue.find(&vol_queue, volume_id) != NULL)        return EBUSY;      call SystemCallQueue.enqueue(&vol_queue, &s);    }        p.addr = addr;    p.buf = buf;    p.len = len;    call SystemCall.start(&writeTask, &s, volume_id, &p);    atomic {      call SystemCallQueue.remove(&vol_queue, &s);      return p.error;    }  }    event void BlockWrite.writeDone[uint8_t volume_id](storage_addr_t addr, void* buf, storage_len_t len, error_t error) {    syscall_t* s = call SystemCallQueue.find(&vol_queue, volume_id);    read_write_params_t* p = s->params;    *(p->len) = len;    p->error = error;    call SystemCall.finish(s);  }  /**************************** Computing CRC ********************************/  void crcTask(syscall_t* s) {    crc_params_t* p = s->params;    p->error = call BlockRead.computeCrc[s->id](p->addr, *(p->len), p->crc);    if(p->error != SUCCESS)      call SystemCall.finish(s);  }    command error_t BlockingBlock.computeCrc[uint8_t volume_id](storage_addr_t addr, storage_len_t* len, uint16_t crc, uint16_t *finalCrc) {    syscall_t s;    crc_params_t p;    atomic {      if(call SystemCallQueue.find(&vol_queue, volume_id) != NULL)        return EBUSY;      call SystemCallQueue.enqueue(&vol_queue, &s);    }        p.addr = addr;    p.len = len;    p.crc = crc;    p.finalCrc = finalCrc;    call SystemCall.start(&crcTask, &s, volume_id, &p);        atomic {      call SystemCallQueue.remove(&vol_queue, &s);      return p.error;    }  }    event void BlockRead.computeCrcDone[uint8_t volume_id](storage_addr_t addr, storage_len_t len, uint16_t crc, error_t error) {    syscall_t* s = call SystemCallQueue.find(&vol_queue, volume_id);    crc_params_t* p = s->params;    *(p->finalCrc) = crc;    *(p->len) = len;    p->error = error;    call SystemCall.finish(s);  }  /**************************** Erasing ********************************/  void eraseTask(syscall_t* s) {    erase_sync_params_t* p = s->params;    p->error = call BlockWrite.erase[s->id]();    if(p->error != SUCCESS)      call SystemCall.finish(s);  }    command error_t BlockingBlock.erase[uint8_t volume_id]() {    syscall_t s;    erase_sync_params_t p;    atomic {      if(call SystemCallQueue.find(&vol_queue, volume_id) != NULL)        return EBUSY;      call SystemCallQueue.enqueue(&vol_queue, &s);    }        call SystemCall.start(&eraseTask, &s, volume_id, &p);        atomic {      call SystemCallQueue.remove(&vol_queue, &s);      return p.error;    }  }  event void BlockWrite.eraseDone[uint8_t volume_id](error_t error) {    syscall_t* s = call SystemCallQueue.find(&vol_queue, volume_id);    erase_sync_params_t* p = s->params;    p->error = error;    call SystemCall.finish(s);  }  /**************************** Syncing ********************************/  void syncTask(syscall_t* s) {    erase_sync_params_t* p = s->params;    p->error = call BlockWrite.sync[s->id]();    if(p->error != SUCCESS)      call SystemCall.finish(s);  }    command error_t BlockingBlock.sync[uint8_t volume_id]() {    syscall_t s;    erase_sync_params_t p;    atomic {      if(call SystemCallQueue.find(&vol_queue, volume_id) != NULL)        return EBUSY;      call SystemCallQueue.enqueue(&vol_queue, &s);    }        call SystemCall.start(&syncTask, &s, volume_id, &p);        atomic {      call SystemCallQueue.remove(&vol_queue, &s);      return p.error;    }  }    event void BlockWrite.syncDone[uint8_t volume_id](error_t error) {    syscall_t* s = call SystemCallQueue.find(&vol_queue, volume_id);    erase_sync_params_t* p = s->params;    p->error = error;    call SystemCall.finish(s);  }    default command error_t BlockRead.read[uint8_t volume_id](storage_addr_t addr, void* buf, storage_len_t len) { return FAIL; }  default command error_t BlockRead.computeCrc[uint8_t volume_id](storage_addr_t addr, storage_len_t len, uint16_t crc) { return FAIL; }  default command storage_len_t BlockRead.getSize[uint8_t volume_id]() { return 0; }  default command error_t BlockWrite.write[uint8_t volume_id](storage_addr_t addr, void* buf, storage_len_t len) { return FAIL; }  default command error_t BlockWrite.erase[uint8_t volume_id]() { return FAIL; }  default command error_t BlockWrite.sync[uint8_t volume_id]() { return FAIL; }}

⌨️ 快捷键说明

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