interface SplitControl;
interface Send;
interface Receive;
+ interface RadioConfig;
}
uses
{
SplitControl = MessageBufferLayerP;
Send = MessageBufferLayerP;
- Receive = MessageBufferLayerP.Receive;
+ Receive = MessageBufferLayerP;
+ RadioConfig = MessageBufferLayerP;
RadioState = MessageBufferLayerP;
MessageBufferLayerP.Tasklet -> TaskletC;
interface Send;
interface Receive;
+ interface RadioConfig;
}
uses
{
STATE_TX_DONE = 3,
STATE_TURN_ON = 4,
STATE_TURN_OFF = 5,
+ STATE_CHANNEL = 6,
};
command error_t SplitControl.start()
return error;
}
+ command error_t RadioConfig.setChannel(uint8_t channel)
+ {
+ error_t error;
+
+ call Tasklet.suspend();
+
+ if( state != STATE_READY )
+ error = EBUSY;
+ else
+ error = call RadioState.setChannel(channel);
+
+ if( error == SUCCESS )
+ state = STATE_CHANNEL;
+
+ call Tasklet.resume();
+
+ return error;
+ }
+
task void stateDoneTask()
{
uint8_t s;
s = state;
// change the state before so we can be reentered from the event
- if( s == STATE_TURN_ON || s == STATE_TURN_OFF )
- state = STATE_READY;
+ state = STATE_READY;
if( s == STATE_TURN_ON )
signal SplitControl.startDone(SUCCESS);
- else
+ else if( s == STATE_TURN_OFF )
signal SplitControl.stopDone(SUCCESS);
+ else if( s == STATE_CHANNEL )
+ signal RadioConfig.setChannelDone();
+ else // not our event, ignore it
+ state = s;
}
tasklet_async event void RadioState.done()
{
}
+ default event void RadioConfig.setChannelDone()
+ {
+ }
+
/*----------------- Send -----------------*/
message_t* txMsg;
interface AMPacket;
interface PacketAcknowledgements;
interface LowPowerListening;
+ interface RadioConfig;
interface PacketField<uint8_t> as PacketLinkQuality;
interface PacketField<uint8_t> as PacketTransmitPower;
PacketTimeStampRadio = RF230PacketC;
PacketTimeStampMilli = RF230PacketC;
LowPowerListening = LowPowerListeningLayerC;
+ RadioConfig = MessageBufferLayerC;
components ActiveMessageLayerC;
#ifdef TFRAMES_ENABLED
--- /dev/null
+/*
+ * Copyright (c) 2009, Vanderbilt 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 THE VANDERBILT 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 THE VANDERBILT
+ * UNIVERSITY HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ *
+ * THE VANDERBILT 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 THE VANDERBILT UNIVERSITY HAS NO OBLIGATION TO
+ * PROVIDE MAINTENANCE, SUPPORT, UPDATES, ENHANCEMENTS, OR MODIFICATIONS.
+ *
+ * Author: Miklos Maroti
+ */
+
+interface RadioConfig
+{
+ /**
+ * Sets the current channel. Returns EBUSY if the stack is unable
+ * to change the channel this time (some other operation is in progress),
+ * EALREADY if the selected channel is already set, SUCCESS otherwise.
+ */
+ command error_t setChannel(uint8_t channel);
+
+ /**
+ * This event is signaled exactly once for each sucessfully posted state
+ * setChannel command when it is completed.
+ */
+ event void setChannelDone();
+}