[Tinyos-2-commits] CVS: tinyos-2.x/tos/chips/cc2420/lowpan
CC2420TinyosNetworkC.nc, NONE, 1.1 CC2420TinyosNetworkP.nc,
NONE, 1.1 readme.txt, NONE, 1.1
dmm
rincon at users.sourceforge.net
Tue Jul 3 17:37:17 PDT 2007
- Previous message: [Tinyos-2-commits] CVS: tinyos-2.x/tos/chips/cc2420/link
PacketLinkC.nc, NONE, 1.1 PacketLinkDummyC.nc, NONE,
1.1 PacketLinkDummyP.nc, NONE, 1.1 PacketLinkP.nc, NONE,
1.1 readme.txt, NONE, 1.1
- Next message: [Tinyos-2-commits] CVS: tinyos-2.x/tos/chips/cc2420/lpl
DefaultLpl.h, NONE, 1.1 DefaultLplC.nc, NONE,
1.1 DefaultLplP.nc, NONE, 1.1 DummyLplC.nc, NONE,
1.1 DummyLplP.nc, NONE, 1.1 PowerCycleC.nc, NONE,
1.1 PowerCycleP.nc, NONE, 1.1 readme.txt, NONE, 1.1
- Messages sorted by:
[ date ]
[ thread ]
[ subject ]
[ author ]
Update of /cvsroot/tinyos/tinyos-2.x/tos/chips/cc2420/lowpan
In directory sc8-pr-cvs10.sourceforge.net:/tmp/cvs-serv30635/lowpan
Added Files:
CC2420TinyosNetworkC.nc CC2420TinyosNetworkP.nc readme.txt
Log Message:
New CC2420 architecture in place for 2.0.2 release. See the README.txt file for changes. Test results from TUnit testing are included.
--- NEW FILE: CC2420TinyosNetworkC.nc ---
/*
* Copyright (c) 2005-2006 Rincon Research Corporation
* 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 Rincon Research Corporation 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 THE
* RINCON RESEARCH 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
*/
/**
* Original TinyOS T-Frames use a packet header that is not compatible with
* other 6LowPAN networks. They do not include the network byte
* responsible for identifying the packing as being sourced from a TinyOS
* network.
*
* TinyOS I-Frames are interoperability packets that do include a network
* byte as defined by 6LowPAN specifications. The I-Frame header type is
* the default packet header used in TinyOS networks.
*
* Since either packet header is acceptable, this layer must do some
* preprocessing (sorry) to figure out whether or not it needs to include
* the functionality to process I-frames. If I-Frames are used, then
* the network byte is added on the way out and checked on the way in.
* If the packet came from a network different from a TinyOS network, the
* user may access it through the DispatchP's NonTinyosReceive[] Receive
* interface and process it in a different radio stack.
*
* If T-Frames are used instead, this layer is simply pass-through wiring to the
* layer beneath.
*
* Define "CC2420_IFRAME_TYPE" to use the interoperability frame and
* this layer
*
* @author David Moss
*/
#include "CC2420.h"
configuration CC2420TinyosNetworkC {
provides {
interface Send;
interface Receive;
}
uses {
interface Receive as SubReceive;
interface Send as SubSend;
}
}
implementation {
#ifdef CC2420_IFRAME_TYPE
components CC2420TinyosNetworkP;
components CC2420PacketC;
CC2420TinyosNetworkP.Send = Send;
CC2420TinyosNetworkP.Receive = Receive;
CC2420TinyosNetworkP.SubSend = SubSend;
CC2420TinyosNetworkP.SubReceive = SubReceive;
CC2420TinyosNetworkP.CC2420PacketBody -> CC2420PacketC;
#else
Send = SubSend;
Receive = SubReceive;
#endif
}
--- NEW FILE: CC2420TinyosNetworkP.nc ---
/*
* Copyright (c) 2005-2006 Rincon Research Corporation
* 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 Rincon Research Corporation 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 THE
* RINCON RESEARCH 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
*/
/**
* Fills in the network ID byte for outgoing packets for compatibility with
* other 6LowPAN networks. Filters incoming packets that are not
* TinyOS network compatible. Provides the 6LowpanSnoop interface to
* sniff for packets that were not originated from TinyOS.
*
* @author David Moss
*/
#include "CC2420.h"
module CC2420TinyosNetworkP {
provides {
interface Send;
interface Receive;
interface Receive as NonTinyosReceive[uint8_t networkId];
}
uses {
interface Send as SubSend;
interface Receive as SubReceive;
interface CC2420PacketBody;
}
}
implementation {
/***************** Send Commands ****************/
command error_t Send.send(message_t* msg, uint8_t len) {
(call CC2420PacketBody.getHeader(msg))->network = TINYOS_6LOWPAN_NETWORK_ID;
return call SubSend.send(msg, len);
}
command error_t Send.cancel(message_t* msg) {
return call SubSend.cancel(msg);
}
command uint8_t Send.maxPayloadLength() {
return call SubSend.maxPayloadLength();
}
command void* Send.getPayload(message_t* msg) {
return call SubSend.getPayload(msg);
}
/***************** Receive Commands ****************/
command void* Receive.getPayload(message_t* msg, uint8_t* len) {
return call SubReceive.getPayload(msg, len);
}
command uint8_t Receive.payloadLength(message_t* msg) {
return call SubReceive.payloadLength(msg);
}
/***************** NonTinyosReceive Commands ****************/
command void* NonTinyosReceive.getPayload[uint8_t networkId](message_t* msg, uint8_t* len) {
return call SubReceive.getPayload(msg, len);
}
command uint8_t NonTinyosReceive.payloadLength[uint8_t networkId](message_t* msg) {
return call SubReceive.payloadLength(msg);
}
/***************** SubSend Events *****************/
event void SubSend.sendDone(message_t* msg, error_t error) {
signal Send.sendDone(msg, error);
}
/***************** SubReceive Events ***************/
event message_t *SubReceive.receive(message_t *msg, void *payload, uint8_t len) {
if((call CC2420PacketBody.getHeader(msg))->network == TINYOS_6LOWPAN_NETWORK_ID) {
return signal Receive.receive(msg, payload, len);
} else {
return signal NonTinyosReceive.receive[(call CC2420PacketBody.getHeader(msg))->network](msg, payload, len);
}
}
/***************** Defaults ****************/
default event message_t *NonTinyosReceive.receive[uint8_t networkId](message_t *msg, void *payload, uint8_t len) {
return msg;
}
}
--- NEW FILE: readme.txt ---
See TEP 125 for more information.
- Previous message: [Tinyos-2-commits] CVS: tinyos-2.x/tos/chips/cc2420/link
PacketLinkC.nc, NONE, 1.1 PacketLinkDummyC.nc, NONE,
1.1 PacketLinkDummyP.nc, NONE, 1.1 PacketLinkP.nc, NONE,
1.1 readme.txt, NONE, 1.1
- Next message: [Tinyos-2-commits] CVS: tinyos-2.x/tos/chips/cc2420/lpl
DefaultLpl.h, NONE, 1.1 DefaultLplC.nc, NONE,
1.1 DefaultLplP.nc, NONE, 1.1 DummyLplC.nc, NONE,
1.1 DummyLplP.nc, NONE, 1.1 PowerCycleC.nc, NONE,
1.1 PowerCycleP.nc, NONE, 1.1 readme.txt, NONE, 1.1
- Messages sorted by:
[ date ]
[ thread ]
[ subject ]
[ author ]
More information about the Tinyos-2-commits
mailing list