2014-11-30 21:22:52 +01:00
|
|
|
/*
|
2013-08-29 14:41:55 +02:00
|
|
|
* nativenet transceiver interface
|
|
|
|
*
|
2014-02-11 18:15:43 +01:00
|
|
|
* A configurable transceiver for the native port.
|
2013-08-29 14:41:55 +02:00
|
|
|
*
|
|
|
|
* At the moment only the tap interface is supported, but more network
|
|
|
|
* layers are intended. So the "configurable" part is a lie for now ;-)
|
|
|
|
* The effect of calls like nativenet_set_channel depend on the
|
|
|
|
* network layer.
|
|
|
|
*
|
2014-05-15 18:07:02 +02:00
|
|
|
* Copyright (C) 2013 Ludwig Ortmann <ludwig.ortmann@fu-berlin.de>
|
2013-08-29 14:41:55 +02:00
|
|
|
*
|
2014-08-23 15:43:13 +02: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.
|
2013-08-29 14:41:55 +02:00
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
2014-11-30 21:22:52 +01:00
|
|
|
* @defgroup native_net Native network interface
|
2013-11-27 17:54:30 +01:00
|
|
|
* @ingroup native_cpu
|
2013-08-29 14:41:55 +02:00
|
|
|
* @{
|
|
|
|
* @author Ludwig Ortmann <ludwig.ortmann@fu-berlin.de>
|
|
|
|
*/
|
|
|
|
|
2013-08-15 19:39:29 +02:00
|
|
|
#ifndef NATIVENET_H
|
|
|
|
#define NATIVENET_H
|
|
|
|
|
2013-08-08 11:08:33 +02:00
|
|
|
#include <net/ethernet.h>
|
|
|
|
|
2014-11-10 05:19:04 +01:00
|
|
|
#include "radio/types.h"
|
2014-07-06 22:57:56 +02:00
|
|
|
#include "kernel_types.h"
|
2014-08-06 15:51:46 +02:00
|
|
|
#include "netdev/base.h"
|
2014-07-06 22:57:56 +02:00
|
|
|
|
2013-08-08 11:08:33 +02:00
|
|
|
#define RX_BUF_SIZE (10)
|
|
|
|
#define TRANSCEIVER_BUFFER_SIZE (3)
|
|
|
|
|
2014-08-06 15:51:46 +02:00
|
|
|
/**
|
|
|
|
* @brief Number of registrable netdev_rcv_data_cb_t callbacks per nativenet
|
|
|
|
* device
|
|
|
|
*/
|
|
|
|
#define NATIVENET_DEV_CB_MAX (128)
|
|
|
|
|
2013-08-08 11:08:33 +02:00
|
|
|
#ifndef NATIVE_MAX_DATA_LENGTH
|
2013-08-29 15:12:06 +02:00
|
|
|
#include "tap.h"
|
2014-10-13 10:53:20 +02:00
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2013-12-13 18:53:48 +01:00
|
|
|
#ifdef MODULE_SIXLOWPAN
|
2014-07-01 18:31:40 +02:00
|
|
|
#define NATIVE_MAX_DATA_LENGTH (127)
|
2013-12-13 18:53:48 +01:00
|
|
|
#else
|
2013-08-29 15:12:06 +02:00
|
|
|
#define NATIVE_MAX_DATA_LENGTH (TAP_MAX_DATA)
|
2013-12-13 18:53:48 +01:00
|
|
|
#endif
|
2013-08-08 11:08:33 +02:00
|
|
|
#else
|
2013-08-29 15:12:06 +02:00
|
|
|
#warning be careful not to exceed (TAP_MAX_DATA) with NATIVE_MAX_DATA_LENGTH
|
2013-08-08 11:08:33 +02:00
|
|
|
#endif /* NATIVE_MAX_DATA_LENGTH */
|
|
|
|
|
2013-08-29 14:41:55 +02:00
|
|
|
/**
|
2014-08-06 15:51:46 +02:00
|
|
|
* @brief Implementation of netdev_driver_t for nativenet
|
|
|
|
*/
|
|
|
|
extern const netdev_driver_t nativenet_driver;
|
|
|
|
|
|
|
|
/**
|
2014-11-30 21:32:12 +01:00
|
|
|
* @brief Default @ref netdev API device
|
2014-08-06 15:51:46 +02:00
|
|
|
*/
|
|
|
|
extern netdev_t nativenet_default_dev;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Initialize @ref sys_transceiver and @ref nativenet_default_dev
|
2013-08-29 14:41:55 +02:00
|
|
|
*
|
|
|
|
* @param transceiver_pid the pid of the transceiver thread
|
|
|
|
*/
|
2014-07-06 22:57:56 +02:00
|
|
|
void nativenet_init(kernel_pid_t transceiver_pid);
|
2013-08-29 14:41:55 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Shutdown transceiver
|
|
|
|
*/
|
2014-05-07 13:29:34 +02:00
|
|
|
void nativenet_powerdown(void);
|
2013-08-08 11:08:33 +02:00
|
|
|
|
2013-08-29 14:41:55 +02:00
|
|
|
/**
|
|
|
|
* Enable/disable monitor mode
|
|
|
|
*
|
|
|
|
* @param mode 0 off, 1 on
|
|
|
|
*/
|
2013-08-08 11:08:33 +02:00
|
|
|
void nativenet_set_monitor(uint8_t mode);
|
|
|
|
|
2013-08-29 14:41:55 +02:00
|
|
|
/**
|
|
|
|
* Send a packet
|
|
|
|
*
|
|
|
|
* @param packet a radio packet
|
2013-12-24 10:54:51 +01:00
|
|
|
* @return -1 if the operation failed, the number of transmitted bytes
|
|
|
|
* up to INT8_MAX otherwise
|
2013-08-29 14:41:55 +02:00
|
|
|
*/
|
2013-11-23 14:03:26 +01:00
|
|
|
int8_t nativenet_send(radio_packet_t *packet);
|
2013-08-08 11:08:33 +02:00
|
|
|
|
2013-08-29 14:41:55 +02:00
|
|
|
/**
|
|
|
|
* Set transceiver address
|
|
|
|
*
|
|
|
|
* @param address the address
|
|
|
|
* @return the address
|
|
|
|
*/
|
2013-08-21 19:22:32 +02:00
|
|
|
radio_address_t nativenet_set_address(radio_address_t address);
|
2013-08-29 14:41:55 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Get transceiver address
|
|
|
|
*
|
|
|
|
* @return the address
|
|
|
|
*/
|
2014-05-07 13:29:34 +02:00
|
|
|
radio_address_t nativenet_get_address(void);
|
2013-08-08 11:08:33 +02:00
|
|
|
|
2014-02-05 09:46:52 +01:00
|
|
|
/**
|
|
|
|
* @brief Sets the IEEE long address of the nativenet transceiver.
|
|
|
|
*
|
|
|
|
* @param[in] addr The desired address.
|
|
|
|
*
|
|
|
|
* @return The set address after calling.
|
|
|
|
*/
|
|
|
|
uint64_t nativenet_set_address_long(uint64_t addr);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Gets the current IEEE long address of the nativenet
|
|
|
|
* transceiver.
|
|
|
|
*
|
|
|
|
* @return The current IEEE long address.
|
|
|
|
*/
|
|
|
|
uint64_t nativenet_get_address_long(void);
|
|
|
|
|
2013-08-29 14:41:55 +02:00
|
|
|
/**
|
|
|
|
* Set transceiver channel
|
|
|
|
*
|
|
|
|
* @param channel the channel
|
|
|
|
* @return the channel
|
|
|
|
*/
|
2013-08-08 11:08:33 +02:00
|
|
|
int16_t nativenet_set_channel(uint8_t channel);
|
2013-08-29 14:41:55 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Get transceiver channel
|
|
|
|
*
|
|
|
|
* @return the channel
|
|
|
|
*/
|
2014-05-07 13:29:34 +02:00
|
|
|
int16_t nativenet_get_channel(void);
|
2013-08-08 11:08:33 +02:00
|
|
|
|
2013-08-29 14:41:55 +02:00
|
|
|
/**
|
|
|
|
* Set transceiver pan
|
|
|
|
*
|
2014-11-30 22:34:50 +01:00
|
|
|
* @param pan the pan
|
2013-08-29 14:41:55 +02:00
|
|
|
* @return the pan
|
|
|
|
*/
|
2013-08-08 11:08:33 +02:00
|
|
|
uint16_t nativenet_set_pan(uint16_t pan);
|
2013-08-29 14:41:55 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Get transceiver pan
|
|
|
|
*
|
|
|
|
* @return the pan
|
|
|
|
*/
|
2014-05-07 13:29:34 +02:00
|
|
|
uint16_t nativenet_get_pan(void);
|
2013-08-08 11:08:33 +02:00
|
|
|
|
2013-08-29 14:41:55 +02:00
|
|
|
/**
|
|
|
|
* Enable transceiver rx mode
|
|
|
|
*/
|
2014-05-07 13:29:34 +02:00
|
|
|
void nativenet_switch_to_rx(void);
|
2014-10-13 10:53:20 +02:00
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2013-08-29 14:41:55 +02:00
|
|
|
/** @} */
|
2013-08-15 19:39:29 +02:00
|
|
|
#endif /* NATIVENET_H */
|