2017-05-16 13:23:54 +02:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2017 Freie Universität Berlin
|
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
2017-11-16 18:06:46 +01:00
|
|
|
* @ingroup net_gnrc_netif
|
2017-05-16 13:23:54 +02:00
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
2017-11-16 18:06:46 +01:00
|
|
|
* @brief Flag definitions for @ref net_gnrc_netif
|
2017-05-16 13:23:54 +02:00
|
|
|
*
|
|
|
|
* @author Martine Lenders <m.lenders@fu-berlin.de>
|
|
|
|
*/
|
2017-11-16 18:06:46 +01:00
|
|
|
#ifndef NET_GNRC_NETIF_FLAGS_H
|
|
|
|
#define NET_GNRC_NETIF_FLAGS_H
|
2017-05-16 13:23:54 +02:00
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Auto-address configuration modes
|
2017-11-16 18:06:46 +01:00
|
|
|
* @anchor net_gnrc_netif_aac
|
2017-05-16 13:23:54 +02:00
|
|
|
*/
|
|
|
|
enum {
|
2021-06-29 15:33:08 +02:00
|
|
|
GNRC_NETIF_AAC_NONE = 0x00, /**< no configuration */
|
|
|
|
GNRC_NETIF_AAC_AUTO = 0x01, /**< Use some automatic bootstrapping (e.g. SLAAC with IPv6) */
|
|
|
|
GNRC_NETIF_AAC_DHCP = 0x02, /**< Use DHCP(v6) */
|
2017-05-16 13:23:54 +02:00
|
|
|
/* extend if needed */
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @name Network interface flags
|
2017-11-16 18:06:46 +01:00
|
|
|
* @anchor net_gnrc_netif_flags
|
2017-05-16 13:23:54 +02:00
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
/**
|
|
|
|
* @brief Network interface has link-layer address
|
|
|
|
*
|
|
|
|
* There are link-layers (e.g. SLIP) that do not have (nor require) link-layer
|
|
|
|
* addresses. This flag signifies this fact to upper layers by leaving it unset.
|
|
|
|
*/
|
2017-11-16 18:06:46 +01:00
|
|
|
#define GNRC_NETIF_FLAGS_HAS_L2ADDR (0x00000001U)
|
2017-05-16 13:23:54 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Network interface is enabled for IPv6 forwarding
|
|
|
|
*/
|
2017-11-16 18:06:46 +01:00
|
|
|
#define GNRC_NETIF_FLAGS_IPV6_FORWARDING (0x00000002U)
|
2017-05-16 13:23:54 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Network interface advertises itself as an IPv6 router
|
2017-11-16 18:06:46 +01:00
|
|
|
* (implies @ref GNRC_NETIF_FLAGS_IPV6_FORWARDING to be set)
|
2017-05-16 13:23:54 +02:00
|
|
|
*/
|
2017-11-16 18:06:46 +01:00
|
|
|
#define GNRC_NETIF_FLAGS_IPV6_RTR_ADV (0x00000004U)
|
2017-05-16 13:23:54 +02:00
|
|
|
|
|
|
|
/**
|
2017-11-16 18:06:46 +01:00
|
|
|
* @brief This interface advertises its gnrc_netif_t::mtu to other nodes
|
|
|
|
* (implies @ref GNRC_NETIF_FLAGS_IPV6_RTR_ADV to be set)
|
2017-05-16 13:23:54 +02:00
|
|
|
*/
|
2017-11-16 18:06:46 +01:00
|
|
|
#define GNRC_NETIF_FLAGS_IPV6_ADV_MTU (0x00000008U)
|
2017-05-16 13:23:54 +02:00
|
|
|
|
|
|
|
/**
|
2017-11-16 18:06:46 +01:00
|
|
|
* @brief This interface advertises its gnrc_netif_t::cur_hl to other nodes
|
|
|
|
* (implies @ref GNRC_NETIF_FLAGS_IPV6_RTR_ADV to be set)
|
2017-05-16 13:23:54 +02:00
|
|
|
*/
|
2017-11-16 18:06:46 +01:00
|
|
|
#define GNRC_NETIF_FLAGS_IPV6_ADV_CUR_HL (0x00000010U)
|
2017-05-16 13:23:54 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief This interface advertises its reachable time to other nodes
|
2017-11-16 18:06:46 +01:00
|
|
|
* (implies @ref GNRC_NETIF_FLAGS_IPV6_RTR_ADV to be set)
|
2017-05-16 13:23:54 +02:00
|
|
|
*/
|
2017-11-16 18:06:46 +01:00
|
|
|
#define GNRC_NETIF_FLAGS_IPV6_ADV_REACH_TIME (0x00000020U)
|
2017-05-16 13:23:54 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief This interface advertises its retransmission timer to other nodes
|
2017-11-16 18:06:46 +01:00
|
|
|
* (implies @ref GNRC_NETIF_FLAGS_IPV6_RTR_ADV to be set)
|
2017-05-16 13:23:54 +02:00
|
|
|
*/
|
2017-11-16 18:06:46 +01:00
|
|
|
#define GNRC_NETIF_FLAGS_IPV6_ADV_RETRANS_TIMER (0x00000040U)
|
2017-05-16 13:23:54 +02:00
|
|
|
|
|
|
|
/**
|
2021-06-29 15:33:08 +02:00
|
|
|
* @brief If gnrc_netif_t::ipv6::aac_mode & GNRC_NETIF_AAC_DHCP then this
|
2017-05-16 13:23:54 +02:00
|
|
|
* flag indicates that other configuration information is available via
|
|
|
|
* DHCPv6 (e.g. DNS-related information)
|
|
|
|
*
|
|
|
|
* @see [RFC 4861, section 4.2](https://tools.ietf.org/html/rfc4861#section-4.2)
|
|
|
|
*/
|
2017-11-16 18:06:46 +01:00
|
|
|
#define GNRC_NETIF_FLAGS_IPV6_ADV_O_FLAG (0x00000080U)
|
2017-05-16 13:23:54 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief This interface uses 6Lo header compression
|
|
|
|
*
|
|
|
|
* @see [RFC 6282](https://tools.ietf.org/html/rfc6282)
|
|
|
|
*/
|
2017-11-16 18:06:46 +01:00
|
|
|
#define GNRC_NETIF_FLAGS_6LO_HC (0x00000100U)
|
2017-05-16 13:23:54 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief This interface acts as a 6Lo border router to the LLN
|
|
|
|
*/
|
2017-11-16 18:06:46 +01:00
|
|
|
#define GNRC_NETIF_FLAGS_6LO_ABR (0x00000200U)
|
2017-05-16 13:23:54 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief This interface acts as a mesh-under node (route-over topology when
|
|
|
|
* unset)
|
|
|
|
*/
|
2017-11-16 18:06:46 +01:00
|
|
|
#define GNRC_NETIF_FLAGS_6LO_MESH (0x00000400U)
|
2017-05-16 13:23:54 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Interface supports 6LoWPAN general header compression
|
|
|
|
*
|
|
|
|
* @attention 6CIO (which propagates this flag throughout) not implemented yet
|
|
|
|
* @see [RFC 7400, section 3.3](https://tools.ietf.org/html/rfc7400#section-3.3)
|
|
|
|
* @see [draft-ietf-6lo-rfc6775-update-09, section 6.3]
|
|
|
|
* (https://tools.ietf.org/html/draft-ietf-6lo-rfc6775-update-09#section-6.3)
|
|
|
|
*/
|
2017-11-16 18:06:46 +01:00
|
|
|
#define GNRC_NETIF_FLAGS_6LO_BACKBONE (0x00000800U)
|
2017-05-16 13:23:54 +02:00
|
|
|
|
2018-11-28 16:25:00 +01:00
|
|
|
/**
|
|
|
|
* @brief This interface represents a 6Lo node (6LN) according to RFC 6775
|
|
|
|
*
|
|
|
|
* @see [RFC 6775, section 2](https://tools.ietf.org/html/rfc6775#section-2)
|
|
|
|
*/
|
|
|
|
#define GNRC_NETIF_FLAGS_6LN (0x00001000U)
|
|
|
|
|
2018-12-27 21:07:40 +01:00
|
|
|
/**
|
|
|
|
* @brief 6Lo is activated for this interface
|
|
|
|
*
|
|
|
|
* @note Most devices supporting 6Lo actually *require* 6Lo so this flag
|
|
|
|
* should not be configurable for them. As a consequence, this flag
|
|
|
|
* **must** only be changed by a @ref NETOPT_6LO message to the
|
|
|
|
* interface.
|
|
|
|
*/
|
|
|
|
#define GNRC_NETIF_FLAGS_6LO (0x00002000U)
|
|
|
|
|
2018-10-03 20:59:03 +02:00
|
|
|
/**
|
|
|
|
* @brief Network interface is configured in raw mode
|
|
|
|
*/
|
|
|
|
#define GNRC_NETIF_FLAGS_RAWMODE (0x00010000U)
|
|
|
|
/** @} */
|
|
|
|
|
2017-05-16 13:23:54 +02:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2017-11-16 18:06:46 +01:00
|
|
|
#endif /* NET_GNRC_NETIF_FLAGS_H */
|
2017-05-16 13:23:54 +02:00
|
|
|
/** @} */
|