mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-18 12:52:44 +01:00
85 lines
2.2 KiB
C
85 lines
2.2 KiB
C
/**
|
|
* Generic radio driver interface
|
|
*
|
|
* Copyright (C) 2008-2009 Freie Universitaet Berlin (FUB).
|
|
* Copyright (C) 2013 INRIA.
|
|
*
|
|
* This file is subject to the terms and conditions of the GNU Lesser General
|
|
* Public License. See the file LICENSE in the top level directory for more
|
|
* details.
|
|
*
|
|
*/
|
|
|
|
#ifndef RADIO_H_
|
|
#define RADIO_H_
|
|
|
|
/**
|
|
* @defgroup net_datalink Data link layer
|
|
* @ingroup net
|
|
*
|
|
* @brief Defines interface of data link layers for use with micro mesh stack.
|
|
*
|
|
* @{
|
|
*/
|
|
|
|
/**
|
|
* @file
|
|
* @brief
|
|
*
|
|
* @author Freie Universität Berlin, Computer Systems & Telematics
|
|
* @author baar
|
|
* @author Thomas Hillebrandt <hillebra@inf.fu-berlin.de>
|
|
* @version $Revision: 1961 $
|
|
*
|
|
* @note $Id$
|
|
*/
|
|
|
|
#include <stdint.h>
|
|
#include <stdbool.h>
|
|
#include "radio/types.h"
|
|
|
|
#ifndef FEUERWARE_CONF_NUM_RADIOS
|
|
#define FEUERWARE_CONF_NUM_RADIOS 1
|
|
#endif
|
|
|
|
#define L1_PROTOCOL_CATCH_ALL (0xff) ///< Catch all protocol ID
|
|
|
|
enum layer_1_protocols {
|
|
LAYER_1_PROTOCOL_LL_ACK = 1, ///< Link-Level Acknowledgement (LL-ACK)
|
|
LAYER_1_PROTOCOL_MM = 2, ///< Micro Mesh network packet (MM)
|
|
};
|
|
|
|
/**
|
|
* Radio/MAC API.
|
|
*/
|
|
typedef struct {
|
|
const char *name;
|
|
const radio_address_t broadcast_address;
|
|
const uint8_t output_power_max;
|
|
/**
|
|
* @return the average transmission duration of one packet
|
|
* in milliseconds, e.g. till ACK received.
|
|
*/
|
|
int (*get_avg_transmission_duration)(void);
|
|
radio_address_t (*get_address)(void);
|
|
bool (*set_address)(radio_address_t address);
|
|
bool (*set_output_power)(uint8_t pa_idx);
|
|
bool (*set_packet_monitor)(packet_monitor_t monitor);
|
|
/**
|
|
* @return -1 if an error occurs (e.g. handler table full) else >= 0.
|
|
*/
|
|
int (*set_packet_handler)(protocol_t protocol, packet_handler_t handler);
|
|
/**
|
|
* @return A negative value if operation failed; else the number of transmitted bytes.
|
|
*/
|
|
int (*send)(radio_address_t address, protocol_t protocol, int priority, char *payload, int payload_len);
|
|
void (*print_stats)(void);
|
|
void (*print_config)(void);
|
|
} radio_t;
|
|
|
|
extern const struct radio *feuerware_radios[FEUERWARE_CONF_NUM_RADIOS];
|
|
|
|
/** @} */
|
|
|
|
#endif /* RADIO_H_ */
|