2015-10-27 19:20:34 +01:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2015 INRIA
|
2016-06-05 14:29:03 +02:00
|
|
|
* Copyright (C) 2016 Freie Universität Berlin
|
2015-10-27 19:20:34 +01:00
|
|
|
*
|
|
|
|
* This file is subject to the terms and conditions of the GNU Lesser
|
|
|
|
* General Public License v2.1. See the file LICENSE in the top level
|
|
|
|
* directory for more details.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
2016-06-05 13:14:29 +02:00
|
|
|
* @defgroup net_csma_sender CSMA/CA helper
|
|
|
|
* @ingroup net
|
2015-10-27 19:20:34 +01:00
|
|
|
* @brief This interface allows code from layer 2 (MAC) or higher
|
|
|
|
* to send packets with CSMA/CA, whatever the abilities and/or
|
|
|
|
* configuration of a given radio transceiver device are.
|
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
* @brief Interface definition for the CSMA/CA helper
|
|
|
|
*
|
|
|
|
* @author Kévin Roussel <Kevin.Roussel@inria.fr>
|
2016-06-05 14:29:03 +02:00
|
|
|
* @author Martine Lenders <mlenders@inf.fu-berlin.de>
|
2015-10-27 19:20:34 +01:00
|
|
|
*/
|
|
|
|
|
2017-05-23 18:19:52 +02:00
|
|
|
#ifndef NET_CSMA_SENDER_H
|
|
|
|
#define NET_CSMA_SENDER_H
|
2016-06-05 13:14:29 +02:00
|
|
|
|
2016-06-05 13:06:12 +02:00
|
|
|
#include <stdint.h>
|
2015-10-27 19:20:34 +01:00
|
|
|
|
2017-02-15 13:07:34 +01:00
|
|
|
#include "net/netdev.h"
|
2015-10-27 19:20:34 +01:00
|
|
|
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2020-06-09 17:40:18 +02:00
|
|
|
/**
|
|
|
|
* @defgroup net_csma_sender_conf CSMA/CA helper compile configurations
|
|
|
|
* @ingroup config
|
|
|
|
* @{
|
|
|
|
*/
|
2015-10-27 19:20:34 +01:00
|
|
|
/**
|
|
|
|
* @brief Default Minimal CSMA/CA Backoff Exponent
|
|
|
|
*/
|
2020-06-09 17:54:45 +02:00
|
|
|
#ifndef CONFIG_CSMA_SENDER_MIN_BE_DEFAULT
|
|
|
|
#define CONFIG_CSMA_SENDER_MIN_BE_DEFAULT (3U)
|
2016-06-05 14:29:03 +02:00
|
|
|
#endif
|
2015-10-27 19:20:34 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Default Maximal CSMA/CA Backoff Exponent
|
|
|
|
*/
|
2016-06-05 14:29:03 +02:00
|
|
|
#ifndef CSMA_SENDER_MAX_BE_DEFAULT
|
2016-06-05 13:07:04 +02:00
|
|
|
#define CSMA_SENDER_MAX_BE_DEFAULT (5U)
|
2016-06-05 14:29:03 +02:00
|
|
|
#endif
|
2015-10-27 19:20:34 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Default Maximal number of retries for sending
|
|
|
|
* a given packet with the CSMA/CA method
|
|
|
|
*/
|
2016-06-05 14:29:03 +02:00
|
|
|
#ifndef CSMA_SENDER_MAX_BACKOFFS_DEFAULT
|
2016-06-05 13:07:04 +02:00
|
|
|
#define CSMA_SENDER_MAX_BACKOFFS_DEFAULT (4U)
|
2016-06-05 14:29:03 +02:00
|
|
|
#endif
|
2015-10-27 19:20:34 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief CSMA/CA backoff period, in microseconds
|
|
|
|
*/
|
2016-06-05 14:29:03 +02:00
|
|
|
#ifndef CSMA_SENDER_BACKOFF_PERIOD_UNIT
|
2016-06-05 13:07:04 +02:00
|
|
|
#define CSMA_SENDER_BACKOFF_PERIOD_UNIT (320U)
|
2016-06-05 14:29:03 +02:00
|
|
|
#endif
|
2020-06-09 17:40:18 +02:00
|
|
|
/** @} */
|
2015-10-27 19:20:34 +01:00
|
|
|
|
|
|
|
/**
|
2016-06-05 14:29:03 +02:00
|
|
|
* @brief Configuration type for backoff
|
2015-10-27 19:20:34 +01:00
|
|
|
*/
|
2016-06-05 14:29:03 +02:00
|
|
|
typedef struct {
|
|
|
|
uint8_t min_be; /**< minimum backoff exponent */
|
|
|
|
uint8_t max_be; /**< maximum backoff exponent */
|
|
|
|
uint16_t max_backoffs; /**< maximum number of retries */
|
|
|
|
uint32_t backoff_period; /**< backoff period in microseconds */
|
|
|
|
} csma_sender_conf_t;
|
2015-10-27 19:20:34 +01:00
|
|
|
|
|
|
|
/**
|
2016-06-05 14:29:03 +02:00
|
|
|
* @brief Default configuration.
|
2015-10-27 19:20:34 +01:00
|
|
|
*/
|
2016-06-05 14:29:03 +02:00
|
|
|
extern const csma_sender_conf_t CSMA_SENDER_CONF_DEFAULT;
|
2015-10-27 19:20:34 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Sends a 802.15.4 frame using the CSMA/CA method
|
|
|
|
*
|
2016-06-05 14:28:31 +02:00
|
|
|
* @pre `dev != NULL`
|
|
|
|
*
|
2015-10-27 19:20:34 +01:00
|
|
|
* If the transceiver can (and is configured to) do hardware-assisted
|
|
|
|
* CSMA/CA, this feature is used. Otherwise, a software procedure is used.
|
|
|
|
*
|
|
|
|
* @param[in] dev netdev device, needs to be already initialized
|
2018-01-18 14:51:57 +01:00
|
|
|
* @param[in] iolist pointer to the data
|
2016-06-05 14:29:03 +02:00
|
|
|
* @param[in] conf configuration for the backoff;
|
|
|
|
* will be set to @ref CSMA_SENDER_CONF_DEFAULT if NULL.
|
2015-10-27 19:20:34 +01:00
|
|
|
*
|
|
|
|
* @return number of bytes that were actually send out
|
|
|
|
* @return -ENODEV if @p dev is invalid
|
|
|
|
* @return -ENOMSG if @p pkt is invalid
|
|
|
|
* @return -EOVERFLOW if the payload size of @p pkt exceeds the
|
|
|
|
* payload size that can be handled by the device
|
2019-09-14 15:47:10 +02:00
|
|
|
* @return -ECANCELED if an internal driver error occurred
|
2015-10-27 19:20:34 +01:00
|
|
|
* @return -EBUSY if radio medium never was available
|
|
|
|
* to send the given data
|
|
|
|
*/
|
2018-01-18 14:51:57 +01:00
|
|
|
int csma_sender_csma_ca_send(netdev_t *dev, iolist_t *iolist,
|
|
|
|
const csma_sender_conf_t *conf);
|
2015-10-27 19:20:34 +01:00
|
|
|
|
|
|
|
/**
|
2019-10-23 21:16:22 +02:00
|
|
|
* @brief Sends a 802.15.4 frame when medium is available.
|
2015-10-27 19:20:34 +01:00
|
|
|
*
|
2016-06-05 14:28:31 +02:00
|
|
|
* @pre `dev != NULL`
|
|
|
|
*
|
2015-10-27 19:20:34 +01:00
|
|
|
* This function is useful for sending packets without the whole CSMA/CA
|
2016-06-05 13:34:06 +02:00
|
|
|
* procedure, but *after* ensuring medium is available, that is after a
|
|
|
|
* successful CCA.
|
|
|
|
*
|
|
|
|
* It is especially useful for broadcasting specific packets, like beacons; or
|
|
|
|
* for many sending packets in burst.
|
|
|
|
*
|
|
|
|
* @warning **ATTENTION:** It only tries to send the given data once. If you
|
|
|
|
* want the complete CSMA/CA procedure with retries, use
|
|
|
|
* @ref csma_sender_csma_ca_send().
|
2015-10-27 19:20:34 +01:00
|
|
|
*
|
|
|
|
* @param[in] dev netdev device, needs to be already initialized
|
2018-01-18 14:51:57 +01:00
|
|
|
* @param[in] iolist pointer to the data
|
2015-10-27 19:20:34 +01:00
|
|
|
*
|
|
|
|
* @return number of bytes that were actually send out
|
|
|
|
* @return -ENODEV if @p dev is invalid
|
|
|
|
* @return -ENOMSG if @p pkt is invalid
|
|
|
|
* @return -EOVERFLOW if the payload size of @p pkt exceeds the
|
|
|
|
* payload size that can be handled by the device
|
2019-09-14 15:47:10 +02:00
|
|
|
* @return -ECANCELED if an internal driver error occurred
|
2015-10-27 19:20:34 +01:00
|
|
|
* @return -EBUSY if radio medium was not available
|
|
|
|
* to send the given data
|
|
|
|
*/
|
2018-01-18 14:51:57 +01:00
|
|
|
int csma_sender_cca_send(netdev_t *dev, iolist_t *iolist);
|
2015-10-27 19:20:34 +01:00
|
|
|
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2017-05-23 18:19:52 +02:00
|
|
|
#endif /* NET_CSMA_SENDER_H */
|
2015-10-27 19:20:34 +01:00
|
|
|
|
|
|
|
/** @} */
|