2015-05-19 09:50:29 +02:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2015 Kaspar Schleiser <kaspar@schleiser.de>
|
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
2018-06-01 12:17:51 +02:00
|
|
|
* @ingroup drivers_netdev
|
2015-05-19 09:50:29 +02:00
|
|
|
* @brief Low-level ethernet driver for native tap interfaces
|
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
2017-02-15 13:07:34 +01:00
|
|
|
* @brief Definitions for @ref netdev ethernet driver for host system's
|
2015-08-09 22:02:10 +02:00
|
|
|
* TAP interfaces
|
2015-05-19 09:50:29 +02:00
|
|
|
*
|
|
|
|
* @author Kaspar Schleiser <kaspar@schleiser.de>
|
|
|
|
*/
|
2017-02-15 13:07:34 +01:00
|
|
|
#ifndef NETDEV_TAP_H
|
|
|
|
#define NETDEV_TAP_H
|
2015-05-19 09:50:29 +02:00
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#include <stdint.h>
|
2022-02-25 17:20:17 +01:00
|
|
|
#include <stdbool.h>
|
2017-02-15 13:07:34 +01:00
|
|
|
#include "net/netdev.h"
|
2015-05-19 09:50:29 +02:00
|
|
|
|
2015-08-21 16:08:43 +02:00
|
|
|
#include "net/ethernet/hdr.h"
|
2015-05-19 09:50:29 +02:00
|
|
|
|
2015-07-01 15:59:21 +02:00
|
|
|
#ifdef __MACH__
|
|
|
|
#include "net/if_var.h"
|
2015-08-21 16:08:43 +02:00
|
|
|
#else
|
|
|
|
#include "net/if.h"
|
2015-07-01 15:59:21 +02:00
|
|
|
#endif
|
|
|
|
|
2015-05-19 09:50:29 +02:00
|
|
|
/**
|
|
|
|
* @brief tap interface state
|
|
|
|
*/
|
2017-02-15 13:07:34 +01:00
|
|
|
typedef struct netdev_tap {
|
|
|
|
netdev_t netdev; /**< netdev internal member */
|
2015-05-19 09:50:29 +02:00
|
|
|
char tap_name[IFNAMSIZ]; /**< host dev file name */
|
|
|
|
int tap_fd; /**< host file descriptor for the TAP */
|
2015-08-07 07:39:02 +02:00
|
|
|
uint8_t addr[ETHERNET_ADDR_LEN]; /**< The MAC address of the TAP */
|
2022-02-25 17:20:17 +01:00
|
|
|
bool promiscuous; /**< Flag for promiscuous mode */
|
|
|
|
bool wired; /**< Flag for wired mode */
|
2017-02-15 13:07:34 +01:00
|
|
|
} netdev_tap_t;
|
2015-05-19 09:50:29 +02:00
|
|
|
|
2016-03-27 21:36:00 +02:00
|
|
|
/**
|
|
|
|
* @brief tap interface initialization parameters
|
|
|
|
*/
|
|
|
|
typedef struct {
|
|
|
|
char **tap_name; /**< Name of the host system's tap
|
2019-10-23 21:13:53 +02:00
|
|
|
interface to bind to. */
|
2022-02-25 17:20:17 +01:00
|
|
|
bool wired; /**< Interface should behave like a
|
|
|
|
wired interface. */
|
2017-02-15 13:07:34 +01:00
|
|
|
} netdev_tap_params_t;
|
2016-03-27 21:36:00 +02:00
|
|
|
|
2015-05-19 09:50:29 +02:00
|
|
|
/**
|
2017-02-15 13:07:34 +01:00
|
|
|
* @brief Setup netdev_tap_t structure.
|
2015-05-19 09:50:29 +02:00
|
|
|
*
|
2017-02-15 13:07:34 +01:00
|
|
|
* @param dev the preallocated netdev_tap device handle to setup
|
2016-03-27 21:36:00 +02:00
|
|
|
* @param params initialization parameters
|
2022-02-10 18:16:43 +01:00
|
|
|
* @param index Index of @p params in a global parameter struct array.
|
|
|
|
* If initialized manually, pass a unique identifier instead.
|
2015-05-19 09:50:29 +02:00
|
|
|
*/
|
2022-02-10 18:16:43 +01:00
|
|
|
void netdev_tap_setup(netdev_tap_t *dev, const netdev_tap_params_t *params, int index);
|
2015-05-19 09:50:29 +02:00
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
/** @} */
|
2017-02-15 13:07:34 +01:00
|
|
|
#endif /* NETDEV_TAP_H */
|