A work-in-progress rework of the Contiki MAC and radio layers. The
main ideas are:
* Separates the Contiki low-layer network stack into four layers:
network (e.g. sicslowpan / rime), Medium Access Control MAC
(e.g. CSMA), Radio Duty Cycling RDC (e.g. ContikiMAC, X-MAC), and
radio (e.g. cc2420).
* Introduces a new way to configure the network stack. Four #defines
that specify what mechanism/protocol/driver to use at the four
layers: NETSTACK_CONF_NETWORK, NETSTACK_CONF_MAC, NETSTACK_CONF_RDC,
NETSTACK_CONF_RADIO.
* Adds a callback mechanism to inform the MAC and network layers about
the fate of a transmitted packet: if the packet was not possible to
transmit, the cause of the failure is reported, and if the packets
was successfully transmitted, the number of tries before it was
finally transmitted is reported.
* NULL-protocols at both the MAC and RDC layers: nullmac and nullrdc,
which can be used when MAC and RDC functionality is not needed.
* Extends the radio API with three new functions that enable more
efficient radio duty cycling protocols: channel check, pending
packet, and receiving packet.
* New initialization mechanism, which takes advantage of the NETSTACK
#defines.
2010-02-18 22:48:39 +01:00
|
|
|
/*
|
2010-11-23 19:11:00 +01:00
|
|
|
* Copyright (c) 2010, Swedish Institute of Computer Science.
|
A work-in-progress rework of the Contiki MAC and radio layers. The
main ideas are:
* Separates the Contiki low-layer network stack into four layers:
network (e.g. sicslowpan / rime), Medium Access Control MAC
(e.g. CSMA), Radio Duty Cycling RDC (e.g. ContikiMAC, X-MAC), and
radio (e.g. cc2420).
* Introduces a new way to configure the network stack. Four #defines
that specify what mechanism/protocol/driver to use at the four
layers: NETSTACK_CONF_NETWORK, NETSTACK_CONF_MAC, NETSTACK_CONF_RDC,
NETSTACK_CONF_RADIO.
* Adds a callback mechanism to inform the MAC and network layers about
the fate of a transmitted packet: if the packet was not possible to
transmit, the cause of the failure is reported, and if the packets
was successfully transmitted, the number of tries before it was
finally transmitted is reported.
* NULL-protocols at both the MAC and RDC layers: nullmac and nullrdc,
which can be used when MAC and RDC functionality is not needed.
* Extends the radio API with three new functions that enable more
efficient radio duty cycling protocols: channel check, pending
packet, and receiving packet.
* New initialization mechanism, which takes advantage of the NETSTACK
#defines.
2010-02-18 22:48:39 +01:00
|
|
|
* All rights reserved.
|
|
|
|
*
|
|
|
|
* Redistribution and use in source and binary forms, with or without
|
|
|
|
* modification, are permitted provided that the following conditions
|
|
|
|
* are met:
|
|
|
|
* 1. Redistributions of source code must retain the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer.
|
|
|
|
* 2. 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.
|
|
|
|
* 3. Neither the name of the Institute 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 INSTITUTE 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 INSTITUTE OR 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.
|
|
|
|
*
|
|
|
|
* This file is part of the Contiki operating system.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \file
|
2010-11-23 19:11:00 +01:00
|
|
|
* A null RDC implementation that uses framer for headers.
|
A work-in-progress rework of the Contiki MAC and radio layers. The
main ideas are:
* Separates the Contiki low-layer network stack into four layers:
network (e.g. sicslowpan / rime), Medium Access Control MAC
(e.g. CSMA), Radio Duty Cycling RDC (e.g. ContikiMAC, X-MAC), and
radio (e.g. cc2420).
* Introduces a new way to configure the network stack. Four #defines
that specify what mechanism/protocol/driver to use at the four
layers: NETSTACK_CONF_NETWORK, NETSTACK_CONF_MAC, NETSTACK_CONF_RDC,
NETSTACK_CONF_RADIO.
* Adds a callback mechanism to inform the MAC and network layers about
the fate of a transmitted packet: if the packet was not possible to
transmit, the cause of the failure is reported, and if the packets
was successfully transmitted, the number of tries before it was
finally transmitted is reported.
* NULL-protocols at both the MAC and RDC layers: nullmac and nullrdc,
which can be used when MAC and RDC functionality is not needed.
* Extends the radio API with three new functions that enable more
efficient radio duty cycling protocols: channel check, pending
packet, and receiving packet.
* New initialization mechanism, which takes advantage of the NETSTACK
#defines.
2010-02-18 22:48:39 +01:00
|
|
|
* \author
|
|
|
|
* Adam Dunkels <adam@sics.se>
|
2010-11-23 19:11:00 +01:00
|
|
|
* Niclas Finne <nfi@sics.se>
|
A work-in-progress rework of the Contiki MAC and radio layers. The
main ideas are:
* Separates the Contiki low-layer network stack into four layers:
network (e.g. sicslowpan / rime), Medium Access Control MAC
(e.g. CSMA), Radio Duty Cycling RDC (e.g. ContikiMAC, X-MAC), and
radio (e.g. cc2420).
* Introduces a new way to configure the network stack. Four #defines
that specify what mechanism/protocol/driver to use at the four
layers: NETSTACK_CONF_NETWORK, NETSTACK_CONF_MAC, NETSTACK_CONF_RDC,
NETSTACK_CONF_RADIO.
* Adds a callback mechanism to inform the MAC and network layers about
the fate of a transmitted packet: if the packet was not possible to
transmit, the cause of the failure is reported, and if the packets
was successfully transmitted, the number of tries before it was
finally transmitted is reported.
* NULL-protocols at both the MAC and RDC layers: nullmac and nullrdc,
which can be used when MAC and RDC functionality is not needed.
* Extends the radio API with three new functions that enable more
efficient radio duty cycling protocols: channel check, pending
packet, and receiving packet.
* New initialization mechanism, which takes advantage of the NETSTACK
#defines.
2010-02-18 22:48:39 +01:00
|
|
|
*/
|
|
|
|
|
2013-11-15 19:21:41 +01:00
|
|
|
#include "net/mac/mac-sequence.h"
|
A work-in-progress rework of the Contiki MAC and radio layers. The
main ideas are:
* Separates the Contiki low-layer network stack into four layers:
network (e.g. sicslowpan / rime), Medium Access Control MAC
(e.g. CSMA), Radio Duty Cycling RDC (e.g. ContikiMAC, X-MAC), and
radio (e.g. cc2420).
* Introduces a new way to configure the network stack. Four #defines
that specify what mechanism/protocol/driver to use at the four
layers: NETSTACK_CONF_NETWORK, NETSTACK_CONF_MAC, NETSTACK_CONF_RDC,
NETSTACK_CONF_RADIO.
* Adds a callback mechanism to inform the MAC and network layers about
the fate of a transmitted packet: if the packet was not possible to
transmit, the cause of the failure is reported, and if the packets
was successfully transmitted, the number of tries before it was
finally transmitted is reported.
* NULL-protocols at both the MAC and RDC layers: nullmac and nullrdc,
which can be used when MAC and RDC functionality is not needed.
* Extends the radio API with three new functions that enable more
efficient radio duty cycling protocols: channel check, pending
packet, and receiving packet.
* New initialization mechanism, which takes advantage of the NETSTACK
#defines.
2010-02-18 22:48:39 +01:00
|
|
|
#include "net/mac/nullrdc.h"
|
2010-06-14 21:19:16 +02:00
|
|
|
#include "net/packetbuf.h"
|
2011-10-13 17:23:53 +02:00
|
|
|
#include "net/queuebuf.h"
|
A work-in-progress rework of the Contiki MAC and radio layers. The
main ideas are:
* Separates the Contiki low-layer network stack into four layers:
network (e.g. sicslowpan / rime), Medium Access Control MAC
(e.g. CSMA), Radio Duty Cycling RDC (e.g. ContikiMAC, X-MAC), and
radio (e.g. cc2420).
* Introduces a new way to configure the network stack. Four #defines
that specify what mechanism/protocol/driver to use at the four
layers: NETSTACK_CONF_NETWORK, NETSTACK_CONF_MAC, NETSTACK_CONF_RDC,
NETSTACK_CONF_RADIO.
* Adds a callback mechanism to inform the MAC and network layers about
the fate of a transmitted packet: if the packet was not possible to
transmit, the cause of the failure is reported, and if the packets
was successfully transmitted, the number of tries before it was
finally transmitted is reported.
* NULL-protocols at both the MAC and RDC layers: nullmac and nullrdc,
which can be used when MAC and RDC functionality is not needed.
* Extends the radio API with three new functions that enable more
efficient radio duty cycling protocols: channel check, pending
packet, and receiving packet.
* New initialization mechanism, which takes advantage of the NETSTACK
#defines.
2010-02-18 22:48:39 +01:00
|
|
|
#include "net/netstack.h"
|
2013-03-17 23:47:00 +01:00
|
|
|
#include "net/rime/rimestats.h"
|
2011-02-22 20:14:19 +01:00
|
|
|
#include <string.h>
|
A work-in-progress rework of the Contiki MAC and radio layers. The
main ideas are:
* Separates the Contiki low-layer network stack into four layers:
network (e.g. sicslowpan / rime), Medium Access Control MAC
(e.g. CSMA), Radio Duty Cycling RDC (e.g. ContikiMAC, X-MAC), and
radio (e.g. cc2420).
* Introduces a new way to configure the network stack. Four #defines
that specify what mechanism/protocol/driver to use at the four
layers: NETSTACK_CONF_NETWORK, NETSTACK_CONF_MAC, NETSTACK_CONF_RDC,
NETSTACK_CONF_RADIO.
* Adds a callback mechanism to inform the MAC and network layers about
the fate of a transmitted packet: if the packet was not possible to
transmit, the cause of the failure is reported, and if the packets
was successfully transmitted, the number of tries before it was
finally transmitted is reported.
* NULL-protocols at both the MAC and RDC layers: nullmac and nullrdc,
which can be used when MAC and RDC functionality is not needed.
* Extends the radio API with three new functions that enable more
efficient radio duty cycling protocols: channel check, pending
packet, and receiving packet.
* New initialization mechanism, which takes advantage of the NETSTACK
#defines.
2010-02-18 22:48:39 +01:00
|
|
|
|
2013-08-15 14:32:35 +02:00
|
|
|
#if CONTIKI_TARGET_COOJA
|
|
|
|
#include "lib/simEnvChange.h"
|
|
|
|
#endif /* CONTIKI_TARGET_COOJA */
|
|
|
|
|
2010-11-23 19:11:00 +01:00
|
|
|
#define DEBUG 0
|
|
|
|
#if DEBUG
|
|
|
|
#include <stdio.h>
|
|
|
|
#define PRINTF(...) printf(__VA_ARGS__)
|
|
|
|
#else
|
|
|
|
#define PRINTF(...)
|
|
|
|
#endif
|
|
|
|
|
2011-06-15 17:51:57 +02:00
|
|
|
#ifdef NULLRDC_CONF_ADDRESS_FILTER
|
|
|
|
#define NULLRDC_ADDRESS_FILTER NULLRDC_CONF_ADDRESS_FILTER
|
|
|
|
#else
|
|
|
|
#define NULLRDC_ADDRESS_FILTER 1
|
|
|
|
#endif /* NULLRDC_CONF_ADDRESS_FILTER */
|
|
|
|
|
2010-11-23 19:11:00 +01:00
|
|
|
#ifndef NULLRDC_802154_AUTOACK
|
|
|
|
#ifdef NULLRDC_CONF_802154_AUTOACK
|
|
|
|
#define NULLRDC_802154_AUTOACK NULLRDC_CONF_802154_AUTOACK
|
|
|
|
#else
|
|
|
|
#define NULLRDC_802154_AUTOACK 0
|
|
|
|
#endif /* NULLRDC_CONF_802154_AUTOACK */
|
|
|
|
#endif /* NULLRDC_802154_AUTOACK */
|
|
|
|
|
2011-02-22 20:14:19 +01:00
|
|
|
#ifndef NULLRDC_802154_AUTOACK_HW
|
|
|
|
#ifdef NULLRDC_CONF_802154_AUTOACK_HW
|
|
|
|
#define NULLRDC_802154_AUTOACK_HW NULLRDC_CONF_802154_AUTOACK_HW
|
|
|
|
#else
|
|
|
|
#define NULLRDC_802154_AUTOACK_HW 0
|
|
|
|
#endif /* NULLRDC_CONF_802154_AUTOACK_HW */
|
|
|
|
#endif /* NULLRDC_802154_AUTOACK_HW */
|
|
|
|
|
2010-11-23 19:11:00 +01:00
|
|
|
#if NULLRDC_802154_AUTOACK
|
|
|
|
#include "sys/rtimer.h"
|
|
|
|
#include "dev/watchdog.h"
|
|
|
|
|
2013-03-17 23:47:00 +01:00
|
|
|
#ifdef NULLRDC_CONF_ACK_WAIT_TIME
|
|
|
|
#define ACK_WAIT_TIME NULLRDC_CONF_ACK_WAIT_TIME
|
|
|
|
#else /* NULLRDC_CONF_ACK_WAIT_TIME */
|
2010-11-23 19:11:00 +01:00
|
|
|
#define ACK_WAIT_TIME RTIMER_SECOND / 2500
|
2013-03-17 23:47:00 +01:00
|
|
|
#endif /* NULLRDC_CONF_ACK_WAIT_TIME */
|
|
|
|
#ifdef NULLRDC_CONF_AFTER_ACK_DETECTED_WAIT_TIME
|
|
|
|
#define AFTER_ACK_DETECTED_WAIT_TIME NULLRDC_CONF_AFTER_ACK_DETECTED_WAIT_TIME
|
|
|
|
#else /* NULLRDC_CONF_AFTER_ACK_DETECTED_WAIT_TIME */
|
2010-11-23 19:11:00 +01:00
|
|
|
#define AFTER_ACK_DETECTED_WAIT_TIME RTIMER_SECOND / 1500
|
2013-03-17 23:47:00 +01:00
|
|
|
#endif /* NULLRDC_CONF_AFTER_ACK_DETECTED_WAIT_TIME */
|
2011-02-22 20:14:19 +01:00
|
|
|
#endif /* NULLRDC_802154_AUTOACK */
|
2010-11-23 19:11:00 +01:00
|
|
|
|
2013-03-17 23:47:00 +01:00
|
|
|
#ifdef NULLRDC_CONF_SEND_802154_ACK
|
|
|
|
#define NULLRDC_SEND_802154_ACK NULLRDC_CONF_SEND_802154_ACK
|
|
|
|
#else /* NULLRDC_CONF_SEND_802154_ACK */
|
|
|
|
#define NULLRDC_SEND_802154_ACK 0
|
|
|
|
#endif /* NULLRDC_CONF_SEND_802154_ACK */
|
|
|
|
|
|
|
|
#if NULLRDC_SEND_802154_ACK
|
|
|
|
#include "net/mac/frame802154.h"
|
|
|
|
#endif /* NULLRDC_SEND_802154_ACK */
|
|
|
|
|
|
|
|
#define ACK_LEN 3
|
|
|
|
|
A work-in-progress rework of the Contiki MAC and radio layers. The
main ideas are:
* Separates the Contiki low-layer network stack into four layers:
network (e.g. sicslowpan / rime), Medium Access Control MAC
(e.g. CSMA), Radio Duty Cycling RDC (e.g. ContikiMAC, X-MAC), and
radio (e.g. cc2420).
* Introduces a new way to configure the network stack. Four #defines
that specify what mechanism/protocol/driver to use at the four
layers: NETSTACK_CONF_NETWORK, NETSTACK_CONF_MAC, NETSTACK_CONF_RDC,
NETSTACK_CONF_RADIO.
* Adds a callback mechanism to inform the MAC and network layers about
the fate of a transmitted packet: if the packet was not possible to
transmit, the cause of the failure is reported, and if the packets
was successfully transmitted, the number of tries before it was
finally transmitted is reported.
* NULL-protocols at both the MAC and RDC layers: nullmac and nullrdc,
which can be used when MAC and RDC functionality is not needed.
* Extends the radio API with three new functions that enable more
efficient radio duty cycling protocols: channel check, pending
packet, and receiving packet.
* New initialization mechanism, which takes advantage of the NETSTACK
#defines.
2010-02-18 22:48:39 +01:00
|
|
|
/*---------------------------------------------------------------------------*/
|
2013-07-28 22:32:09 +02:00
|
|
|
static int
|
|
|
|
send_one_packet(mac_callback_t sent, void *ptr)
|
A work-in-progress rework of the Contiki MAC and radio layers. The
main ideas are:
* Separates the Contiki low-layer network stack into four layers:
network (e.g. sicslowpan / rime), Medium Access Control MAC
(e.g. CSMA), Radio Duty Cycling RDC (e.g. ContikiMAC, X-MAC), and
radio (e.g. cc2420).
* Introduces a new way to configure the network stack. Four #defines
that specify what mechanism/protocol/driver to use at the four
layers: NETSTACK_CONF_NETWORK, NETSTACK_CONF_MAC, NETSTACK_CONF_RDC,
NETSTACK_CONF_RADIO.
* Adds a callback mechanism to inform the MAC and network layers about
the fate of a transmitted packet: if the packet was not possible to
transmit, the cause of the failure is reported, and if the packets
was successfully transmitted, the number of tries before it was
finally transmitted is reported.
* NULL-protocols at both the MAC and RDC layers: nullmac and nullrdc,
which can be used when MAC and RDC functionality is not needed.
* Extends the radio API with three new functions that enable more
efficient radio duty cycling protocols: channel check, pending
packet, and receiving packet.
* New initialization mechanism, which takes advantage of the NETSTACK
#defines.
2010-02-18 22:48:39 +01:00
|
|
|
{
|
|
|
|
int ret;
|
2013-07-28 22:32:09 +02:00
|
|
|
int last_sent_ok = 0;
|
|
|
|
|
2013-12-12 23:58:52 +01:00
|
|
|
packetbuf_set_addr(PACKETBUF_ADDR_SENDER, &linkaddr_node_addr);
|
2011-02-22 20:14:19 +01:00
|
|
|
#if NULLRDC_802154_AUTOACK || NULLRDC_802154_AUTOACK_HW
|
2010-11-23 19:11:00 +01:00
|
|
|
packetbuf_set_attr(PACKETBUF_ATTR_MAC_ACK, 1);
|
2011-02-22 20:14:19 +01:00
|
|
|
#endif /* NULLRDC_802154_AUTOACK || NULLRDC_802154_AUTOACK_HW */
|
2010-11-23 19:11:00 +01:00
|
|
|
|
2013-06-22 20:29:30 +02:00
|
|
|
if((NETSTACK_FRAMER.create() < 0) || !NETSTACK_LLSEC.on_frame_created()) {
|
2010-11-23 19:11:00 +01:00
|
|
|
/* Failed to allocate space for headers */
|
|
|
|
PRINTF("nullrdc: send failed, too large header\n");
|
|
|
|
ret = MAC_TX_ERR_FATAL;
|
A work-in-progress rework of the Contiki MAC and radio layers. The
main ideas are:
* Separates the Contiki low-layer network stack into four layers:
network (e.g. sicslowpan / rime), Medium Access Control MAC
(e.g. CSMA), Radio Duty Cycling RDC (e.g. ContikiMAC, X-MAC), and
radio (e.g. cc2420).
* Introduces a new way to configure the network stack. Four #defines
that specify what mechanism/protocol/driver to use at the four
layers: NETSTACK_CONF_NETWORK, NETSTACK_CONF_MAC, NETSTACK_CONF_RDC,
NETSTACK_CONF_RADIO.
* Adds a callback mechanism to inform the MAC and network layers about
the fate of a transmitted packet: if the packet was not possible to
transmit, the cause of the failure is reported, and if the packets
was successfully transmitted, the number of tries before it was
finally transmitted is reported.
* NULL-protocols at both the MAC and RDC layers: nullmac and nullrdc,
which can be used when MAC and RDC functionality is not needed.
* Extends the radio API with three new functions that enable more
efficient radio duty cycling protocols: channel check, pending
packet, and receiving packet.
* New initialization mechanism, which takes advantage of the NETSTACK
#defines.
2010-02-18 22:48:39 +01:00
|
|
|
} else {
|
2010-11-23 19:11:00 +01:00
|
|
|
#if NULLRDC_802154_AUTOACK
|
|
|
|
int is_broadcast;
|
|
|
|
uint8_t dsn;
|
|
|
|
dsn = ((uint8_t *)packetbuf_hdrptr())[2] & 0xff;
|
|
|
|
|
|
|
|
NETSTACK_RADIO.prepare(packetbuf_hdrptr(), packetbuf_totlen());
|
|
|
|
|
2013-12-12 23:58:52 +01:00
|
|
|
is_broadcast = linkaddr_cmp(packetbuf_addr(PACKETBUF_ADDR_RECEIVER),
|
|
|
|
&linkaddr_null);
|
2010-11-23 19:11:00 +01:00
|
|
|
|
|
|
|
if(NETSTACK_RADIO.receiving_packet() ||
|
|
|
|
(!is_broadcast && NETSTACK_RADIO.pending_packet())) {
|
|
|
|
|
|
|
|
/* Currently receiving a packet over air or the radio has
|
|
|
|
already received a packet that needs to be read before
|
|
|
|
sending with auto ack. */
|
|
|
|
ret = MAC_TX_COLLISION;
|
|
|
|
} else {
|
2013-03-17 23:47:00 +01:00
|
|
|
if(!is_broadcast) {
|
|
|
|
RIMESTATS_ADD(reliabletx);
|
|
|
|
}
|
|
|
|
|
2010-11-23 19:11:00 +01:00
|
|
|
switch(NETSTACK_RADIO.transmit(packetbuf_totlen())) {
|
|
|
|
case RADIO_TX_OK:
|
|
|
|
if(is_broadcast) {
|
|
|
|
ret = MAC_TX_OK;
|
|
|
|
} else {
|
|
|
|
rtimer_clock_t wt;
|
|
|
|
|
|
|
|
/* Check for ack */
|
|
|
|
wt = RTIMER_NOW();
|
|
|
|
watchdog_periodic();
|
2013-08-15 14:32:35 +02:00
|
|
|
while(RTIMER_CLOCK_LT(RTIMER_NOW(), wt + ACK_WAIT_TIME)) {
|
|
|
|
#if CONTIKI_TARGET_COOJA
|
|
|
|
simProcessRunValue = 1;
|
|
|
|
cooja_mt_yield();
|
|
|
|
#endif /* CONTIKI_TARGET_COOJA */
|
|
|
|
}
|
2010-11-23 19:11:00 +01:00
|
|
|
|
|
|
|
ret = MAC_TX_NOACK;
|
|
|
|
if(NETSTACK_RADIO.receiving_packet() ||
|
|
|
|
NETSTACK_RADIO.pending_packet() ||
|
|
|
|
NETSTACK_RADIO.channel_clear() == 0) {
|
|
|
|
int len;
|
|
|
|
uint8_t ackbuf[ACK_LEN];
|
|
|
|
|
2013-08-15 14:32:35 +02:00
|
|
|
if(AFTER_ACK_DETECTED_WAIT_TIME > 0) {
|
|
|
|
wt = RTIMER_NOW();
|
|
|
|
watchdog_periodic();
|
|
|
|
while(RTIMER_CLOCK_LT(RTIMER_NOW(),
|
|
|
|
wt + AFTER_ACK_DETECTED_WAIT_TIME)) {
|
|
|
|
#if CONTIKI_TARGET_COOJA
|
|
|
|
simProcessRunValue = 1;
|
|
|
|
cooja_mt_yield();
|
|
|
|
#endif /* CONTIKI_TARGET_COOJA */
|
|
|
|
}
|
|
|
|
}
|
2010-11-23 19:11:00 +01:00
|
|
|
|
|
|
|
if(NETSTACK_RADIO.pending_packet()) {
|
|
|
|
len = NETSTACK_RADIO.read(ackbuf, ACK_LEN);
|
|
|
|
if(len == ACK_LEN && ackbuf[2] == dsn) {
|
|
|
|
/* Ack received */
|
2013-03-17 23:47:00 +01:00
|
|
|
RIMESTATS_ADD(ackrx);
|
2010-11-23 19:11:00 +01:00
|
|
|
ret = MAC_TX_OK;
|
|
|
|
} else {
|
|
|
|
/* Not an ack or ack not for us: collision */
|
|
|
|
ret = MAC_TX_COLLISION;
|
|
|
|
}
|
|
|
|
}
|
2013-03-17 23:47:00 +01:00
|
|
|
} else {
|
|
|
|
PRINTF("nullrdc tx noack\n");
|
|
|
|
}
|
2010-11-23 19:11:00 +01:00
|
|
|
}
|
|
|
|
break;
|
|
|
|
case RADIO_TX_COLLISION:
|
|
|
|
ret = MAC_TX_COLLISION;
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
ret = MAC_TX_ERR;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#else /* ! NULLRDC_802154_AUTOACK */
|
|
|
|
|
|
|
|
switch(NETSTACK_RADIO.send(packetbuf_hdrptr(), packetbuf_totlen())) {
|
|
|
|
case RADIO_TX_OK:
|
|
|
|
ret = MAC_TX_OK;
|
|
|
|
break;
|
|
|
|
case RADIO_TX_COLLISION:
|
|
|
|
ret = MAC_TX_COLLISION;
|
|
|
|
break;
|
2011-02-22 19:57:29 +01:00
|
|
|
case RADIO_TX_NOACK:
|
|
|
|
ret = MAC_TX_NOACK;
|
|
|
|
break;
|
2010-11-23 19:11:00 +01:00
|
|
|
default:
|
|
|
|
ret = MAC_TX_ERR;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif /* ! NULLRDC_802154_AUTOACK */
|
A work-in-progress rework of the Contiki MAC and radio layers. The
main ideas are:
* Separates the Contiki low-layer network stack into four layers:
network (e.g. sicslowpan / rime), Medium Access Control MAC
(e.g. CSMA), Radio Duty Cycling RDC (e.g. ContikiMAC, X-MAC), and
radio (e.g. cc2420).
* Introduces a new way to configure the network stack. Four #defines
that specify what mechanism/protocol/driver to use at the four
layers: NETSTACK_CONF_NETWORK, NETSTACK_CONF_MAC, NETSTACK_CONF_RDC,
NETSTACK_CONF_RADIO.
* Adds a callback mechanism to inform the MAC and network layers about
the fate of a transmitted packet: if the packet was not possible to
transmit, the cause of the failure is reported, and if the packets
was successfully transmitted, the number of tries before it was
finally transmitted is reported.
* NULL-protocols at both the MAC and RDC layers: nullmac and nullrdc,
which can be used when MAC and RDC functionality is not needed.
* Extends the radio API with three new functions that enable more
efficient radio duty cycling protocols: channel check, pending
packet, and receiving packet.
* New initialization mechanism, which takes advantage of the NETSTACK
#defines.
2010-02-18 22:48:39 +01:00
|
|
|
}
|
2013-07-28 22:32:09 +02:00
|
|
|
if(ret == MAC_TX_OK) {
|
|
|
|
last_sent_ok = 1;
|
|
|
|
}
|
A work-in-progress rework of the Contiki MAC and radio layers. The
main ideas are:
* Separates the Contiki low-layer network stack into four layers:
network (e.g. sicslowpan / rime), Medium Access Control MAC
(e.g. CSMA), Radio Duty Cycling RDC (e.g. ContikiMAC, X-MAC), and
radio (e.g. cc2420).
* Introduces a new way to configure the network stack. Four #defines
that specify what mechanism/protocol/driver to use at the four
layers: NETSTACK_CONF_NETWORK, NETSTACK_CONF_MAC, NETSTACK_CONF_RDC,
NETSTACK_CONF_RADIO.
* Adds a callback mechanism to inform the MAC and network layers about
the fate of a transmitted packet: if the packet was not possible to
transmit, the cause of the failure is reported, and if the packets
was successfully transmitted, the number of tries before it was
finally transmitted is reported.
* NULL-protocols at both the MAC and RDC layers: nullmac and nullrdc,
which can be used when MAC and RDC functionality is not needed.
* Extends the radio API with three new functions that enable more
efficient radio duty cycling protocols: channel check, pending
packet, and receiving packet.
* New initialization mechanism, which takes advantage of the NETSTACK
#defines.
2010-02-18 22:48:39 +01:00
|
|
|
mac_call_sent_callback(sent, ptr, ret, 1);
|
2013-07-28 22:32:09 +02:00
|
|
|
return last_sent_ok;
|
|
|
|
}
|
|
|
|
/*---------------------------------------------------------------------------*/
|
|
|
|
static void
|
|
|
|
send_packet(mac_callback_t sent, void *ptr)
|
|
|
|
{
|
|
|
|
send_one_packet(sent, ptr);
|
A work-in-progress rework of the Contiki MAC and radio layers. The
main ideas are:
* Separates the Contiki low-layer network stack into four layers:
network (e.g. sicslowpan / rime), Medium Access Control MAC
(e.g. CSMA), Radio Duty Cycling RDC (e.g. ContikiMAC, X-MAC), and
radio (e.g. cc2420).
* Introduces a new way to configure the network stack. Four #defines
that specify what mechanism/protocol/driver to use at the four
layers: NETSTACK_CONF_NETWORK, NETSTACK_CONF_MAC, NETSTACK_CONF_RDC,
NETSTACK_CONF_RADIO.
* Adds a callback mechanism to inform the MAC and network layers about
the fate of a transmitted packet: if the packet was not possible to
transmit, the cause of the failure is reported, and if the packets
was successfully transmitted, the number of tries before it was
finally transmitted is reported.
* NULL-protocols at both the MAC and RDC layers: nullmac and nullrdc,
which can be used when MAC and RDC functionality is not needed.
* Extends the radio API with three new functions that enable more
efficient radio duty cycling protocols: channel check, pending
packet, and receiving packet.
* New initialization mechanism, which takes advantage of the NETSTACK
#defines.
2010-02-18 22:48:39 +01:00
|
|
|
}
|
|
|
|
/*---------------------------------------------------------------------------*/
|
2011-10-03 15:17:30 +02:00
|
|
|
static void
|
2011-09-27 16:05:30 +02:00
|
|
|
send_list(mac_callback_t sent, void *ptr, struct rdc_buf_list *buf_list)
|
|
|
|
{
|
2013-03-17 23:49:32 +01:00
|
|
|
while(buf_list != NULL) {
|
2013-07-28 22:32:09 +02:00
|
|
|
/* We backup the next pointer, as it may be nullified by
|
|
|
|
* mac_call_sent_callback() */
|
|
|
|
struct rdc_buf_list *next = buf_list->next;
|
|
|
|
int last_sent_ok;
|
|
|
|
|
2011-09-27 16:05:30 +02:00
|
|
|
queuebuf_to_packetbuf(buf_list->buf);
|
2013-07-28 22:32:09 +02:00
|
|
|
last_sent_ok = send_one_packet(sent, ptr);
|
|
|
|
|
|
|
|
/* If packet transmission was not successful, we should back off and let
|
|
|
|
* upper layers retransmit, rather than potentially sending out-of-order
|
|
|
|
* packet fragments. */
|
|
|
|
if(!last_sent_ok) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
buf_list = next;
|
2011-09-27 16:05:30 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
/*---------------------------------------------------------------------------*/
|
A work-in-progress rework of the Contiki MAC and radio layers. The
main ideas are:
* Separates the Contiki low-layer network stack into four layers:
network (e.g. sicslowpan / rime), Medium Access Control MAC
(e.g. CSMA), Radio Duty Cycling RDC (e.g. ContikiMAC, X-MAC), and
radio (e.g. cc2420).
* Introduces a new way to configure the network stack. Four #defines
that specify what mechanism/protocol/driver to use at the four
layers: NETSTACK_CONF_NETWORK, NETSTACK_CONF_MAC, NETSTACK_CONF_RDC,
NETSTACK_CONF_RADIO.
* Adds a callback mechanism to inform the MAC and network layers about
the fate of a transmitted packet: if the packet was not possible to
transmit, the cause of the failure is reported, and if the packets
was successfully transmitted, the number of tries before it was
finally transmitted is reported.
* NULL-protocols at both the MAC and RDC layers: nullmac and nullrdc,
which can be used when MAC and RDC functionality is not needed.
* Extends the radio API with three new functions that enable more
efficient radio duty cycling protocols: channel check, pending
packet, and receiving packet.
* New initialization mechanism, which takes advantage of the NETSTACK
#defines.
2010-02-18 22:48:39 +01:00
|
|
|
static void
|
|
|
|
packet_input(void)
|
|
|
|
{
|
2013-07-28 22:32:09 +02:00
|
|
|
int original_datalen;
|
|
|
|
uint8_t *original_dataptr;
|
|
|
|
|
|
|
|
original_datalen = packetbuf_datalen();
|
|
|
|
original_dataptr = packetbuf_dataptr();
|
2012-11-24 17:18:59 +01:00
|
|
|
|
2010-11-23 19:11:00 +01:00
|
|
|
#if NULLRDC_802154_AUTOACK
|
|
|
|
if(packetbuf_datalen() == ACK_LEN) {
|
|
|
|
/* Ignore ack packets */
|
2013-03-17 23:47:00 +01:00
|
|
|
PRINTF("nullrdc: ignored ack\n");
|
2010-11-23 19:11:00 +01:00
|
|
|
} else
|
|
|
|
#endif /* NULLRDC_802154_AUTOACK */
|
2012-01-01 03:00:21 +01:00
|
|
|
if(NETSTACK_FRAMER.parse() < 0) {
|
2010-11-23 19:11:00 +01:00
|
|
|
PRINTF("nullrdc: failed to parse %u\n", packetbuf_datalen());
|
2011-06-15 17:51:57 +02:00
|
|
|
#if NULLRDC_ADDRESS_FILTER
|
2013-12-12 23:58:52 +01:00
|
|
|
} else if(!linkaddr_cmp(packetbuf_addr(PACKETBUF_ADDR_RECEIVER),
|
|
|
|
&linkaddr_node_addr) &&
|
|
|
|
!linkaddr_cmp(packetbuf_addr(PACKETBUF_ADDR_RECEIVER),
|
|
|
|
&linkaddr_null)) {
|
2011-06-15 17:51:57 +02:00
|
|
|
PRINTF("nullrdc: not for us\n");
|
|
|
|
#endif /* NULLRDC_ADDRESS_FILTER */
|
2010-11-23 19:11:00 +01:00
|
|
|
} else {
|
2013-07-28 22:32:09 +02:00
|
|
|
int duplicate = 0;
|
|
|
|
|
2011-02-22 20:14:19 +01:00
|
|
|
#if NULLRDC_802154_AUTOACK || NULLRDC_802154_AUTOACK_HW
|
2014-01-12 13:58:34 +01:00
|
|
|
#if RDC_WITH_DUPLICATE_DETECTION
|
2013-11-15 19:21:41 +01:00
|
|
|
/* Check for duplicate packet. */
|
|
|
|
duplicate = mac_sequence_is_duplicate();
|
|
|
|
if(duplicate) {
|
|
|
|
/* Drop the packet. */
|
|
|
|
PRINTF("nullrdc: drop duplicate link layer packet %u\n",
|
|
|
|
packetbuf_attr(PACKETBUF_ATTR_PACKET_ID));
|
|
|
|
} else {
|
|
|
|
mac_sequence_register_seqno();
|
2010-11-23 19:11:00 +01:00
|
|
|
}
|
2014-01-12 13:58:34 +01:00
|
|
|
#endif /* RDC_WITH_DUPLICATE_DETECTION */
|
2010-11-23 19:11:00 +01:00
|
|
|
#endif /* NULLRDC_802154_AUTOACK */
|
2013-03-17 23:47:00 +01:00
|
|
|
|
2014-01-12 13:58:34 +01:00
|
|
|
/* TODO We may want to acknowledge only authentic frames */
|
2013-03-17 23:47:00 +01:00
|
|
|
#if NULLRDC_SEND_802154_ACK
|
|
|
|
{
|
|
|
|
frame802154_t info154;
|
|
|
|
frame802154_parse(original_dataptr, original_datalen, &info154);
|
|
|
|
if(info154.fcf.frame_type == FRAME802154_DATAFRAME &&
|
|
|
|
info154.fcf.ack_required != 0 &&
|
2013-12-12 23:58:52 +01:00
|
|
|
linkaddr_cmp((linkaddr_t *)&info154.dest_addr,
|
|
|
|
&linkaddr_node_addr)) {
|
2013-03-17 23:47:00 +01:00
|
|
|
uint8_t ackdata[ACK_LEN] = {0, 0, 0};
|
|
|
|
|
|
|
|
ackdata[0] = FRAME802154_ACKFRAME;
|
|
|
|
ackdata[1] = 0;
|
|
|
|
ackdata[2] = info154.seq;
|
|
|
|
NETSTACK_RADIO.send(ackdata, ACK_LEN);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#endif /* NULLRDC_SEND_ACK */
|
2013-07-28 22:32:09 +02:00
|
|
|
if(!duplicate) {
|
|
|
|
NETSTACK_MAC.input();
|
|
|
|
}
|
2010-11-23 19:11:00 +01:00
|
|
|
}
|
A work-in-progress rework of the Contiki MAC and radio layers. The
main ideas are:
* Separates the Contiki low-layer network stack into four layers:
network (e.g. sicslowpan / rime), Medium Access Control MAC
(e.g. CSMA), Radio Duty Cycling RDC (e.g. ContikiMAC, X-MAC), and
radio (e.g. cc2420).
* Introduces a new way to configure the network stack. Four #defines
that specify what mechanism/protocol/driver to use at the four
layers: NETSTACK_CONF_NETWORK, NETSTACK_CONF_MAC, NETSTACK_CONF_RDC,
NETSTACK_CONF_RADIO.
* Adds a callback mechanism to inform the MAC and network layers about
the fate of a transmitted packet: if the packet was not possible to
transmit, the cause of the failure is reported, and if the packets
was successfully transmitted, the number of tries before it was
finally transmitted is reported.
* NULL-protocols at both the MAC and RDC layers: nullmac and nullrdc,
which can be used when MAC and RDC functionality is not needed.
* Extends the radio API with three new functions that enable more
efficient radio duty cycling protocols: channel check, pending
packet, and receiving packet.
* New initialization mechanism, which takes advantage of the NETSTACK
#defines.
2010-02-18 22:48:39 +01:00
|
|
|
}
|
|
|
|
/*---------------------------------------------------------------------------*/
|
|
|
|
static int
|
|
|
|
on(void)
|
|
|
|
{
|
|
|
|
return NETSTACK_RADIO.on();
|
|
|
|
}
|
|
|
|
/*---------------------------------------------------------------------------*/
|
|
|
|
static int
|
|
|
|
off(int keep_radio_on)
|
|
|
|
{
|
|
|
|
if(keep_radio_on) {
|
|
|
|
return NETSTACK_RADIO.on();
|
|
|
|
} else {
|
|
|
|
return NETSTACK_RADIO.off();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
/*---------------------------------------------------------------------------*/
|
|
|
|
static unsigned short
|
|
|
|
channel_check_interval(void)
|
|
|
|
{
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
/*---------------------------------------------------------------------------*/
|
|
|
|
static void
|
|
|
|
init(void)
|
|
|
|
{
|
|
|
|
on();
|
|
|
|
}
|
|
|
|
/*---------------------------------------------------------------------------*/
|
2010-02-23 21:09:11 +01:00
|
|
|
const struct rdc_driver nullrdc_driver = {
|
A work-in-progress rework of the Contiki MAC and radio layers. The
main ideas are:
* Separates the Contiki low-layer network stack into four layers:
network (e.g. sicslowpan / rime), Medium Access Control MAC
(e.g. CSMA), Radio Duty Cycling RDC (e.g. ContikiMAC, X-MAC), and
radio (e.g. cc2420).
* Introduces a new way to configure the network stack. Four #defines
that specify what mechanism/protocol/driver to use at the four
layers: NETSTACK_CONF_NETWORK, NETSTACK_CONF_MAC, NETSTACK_CONF_RDC,
NETSTACK_CONF_RADIO.
* Adds a callback mechanism to inform the MAC and network layers about
the fate of a transmitted packet: if the packet was not possible to
transmit, the cause of the failure is reported, and if the packets
was successfully transmitted, the number of tries before it was
finally transmitted is reported.
* NULL-protocols at both the MAC and RDC layers: nullmac and nullrdc,
which can be used when MAC and RDC functionality is not needed.
* Extends the radio API with three new functions that enable more
efficient radio duty cycling protocols: channel check, pending
packet, and receiving packet.
* New initialization mechanism, which takes advantage of the NETSTACK
#defines.
2010-02-18 22:48:39 +01:00
|
|
|
"nullrdc",
|
|
|
|
init,
|
|
|
|
send_packet,
|
2011-09-27 16:05:30 +02:00
|
|
|
send_list,
|
A work-in-progress rework of the Contiki MAC and radio layers. The
main ideas are:
* Separates the Contiki low-layer network stack into four layers:
network (e.g. sicslowpan / rime), Medium Access Control MAC
(e.g. CSMA), Radio Duty Cycling RDC (e.g. ContikiMAC, X-MAC), and
radio (e.g. cc2420).
* Introduces a new way to configure the network stack. Four #defines
that specify what mechanism/protocol/driver to use at the four
layers: NETSTACK_CONF_NETWORK, NETSTACK_CONF_MAC, NETSTACK_CONF_RDC,
NETSTACK_CONF_RADIO.
* Adds a callback mechanism to inform the MAC and network layers about
the fate of a transmitted packet: if the packet was not possible to
transmit, the cause of the failure is reported, and if the packets
was successfully transmitted, the number of tries before it was
finally transmitted is reported.
* NULL-protocols at both the MAC and RDC layers: nullmac and nullrdc,
which can be used when MAC and RDC functionality is not needed.
* Extends the radio API with three new functions that enable more
efficient radio duty cycling protocols: channel check, pending
packet, and receiving packet.
* New initialization mechanism, which takes advantage of the NETSTACK
#defines.
2010-02-18 22:48:39 +01:00
|
|
|
packet_input,
|
|
|
|
on,
|
|
|
|
off,
|
|
|
|
channel_check_interval,
|
|
|
|
};
|
|
|
|
/*---------------------------------------------------------------------------*/
|