📄 tossimpacketmodel.nc
字号:
// $Id: TossimPacketModel.nc,v 1.4 2006/12/12 18:23:32 vlahan Exp $/* * "Copyright (c) 2005 Stanford 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 following two paragraphs and the author appear in all * copies of this software. * * IN NO EVENT SHALL STANFORD UNIVERSITY 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 STANFORD UNIVERSITY HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH * DAMAGE. * * STANFORD UNIVERSITY 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 STANFORD UNIVERSITY * HAS NO OBLIGATION TO PROVIDE MAINTENANCE, SUPPORT, UPDATES, * ENHANCEMENTS, OR MODIFICATIONS." *//** * The interface to a packet-level radio simulation, which may sit * on top of higher fidelity simulators. * * @author Philip Levis * @date December 2 2005 */ #include <TinyError.h>#include <message.h>interface TossimPacketModel { /** * Send a packet with a data payload of <tt>len</tt>. To determine * the maximum available size, use the Packet interface of the * component providing Send. If send returns SUCCESS, then the * component will signal the sendDone event in the future; if send * returns an error, it will not signal sendDone. Note that a * component may accept a send request which it later finds it * cannot satisfy; in this case, it will signal sendDone with an * appropriate error code. */ command error_t send(int node, message_t* msg, uint8_t len); /** * Cancel a requested transmission. Returns SUCCESS if the * transmission was cancelled properly (not sent in its * entirety). Note that the component may not know * if the send was successfully cancelled, if the radio is * handling much of the logic; in this case, a component * should be conservative and return an appropriate error code. * A successful call to cancel must always result in a * sendFailed event, and never a sendSucceeded event. */ command error_t cancel(message_t* msg); /** * Signaled in response to an accepted send request. <tt>msg</tt> * is the sent buffer, and <tt>error</tt> indicates whether the * send was succesful, and if not, the cause of the failure. */ event void sendDone(message_t* msg, error_t error); /** * Signal that a packet was received. Note that there is no buffer * swap: a component using this interface must copy out the message * if it needs it. */ event void receive(message_t* msg); event bool shouldAck(message_t* msg);}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -