/* * Copyright (C) 2015 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. */ /** * @defgroup net_eui64 IEEE EUI-64 identifier * @ingroup net * @brief Type definition of the IEEE EUI-64 identifier * @see * IEEE, "Guidelines for 64-bit Global Identifier (EUI-64)" * * @{ * * @file * @brief EUI-64 data type definition * * @author Martine Lenders * @author Oliver Hahm */ #ifndef NET_EUI64_H #define NET_EUI64_H #include #include "byteorder.h" #ifdef __cplusplus extern "C" { #endif /** * @name EUI-64 bit flags contained in the first octet * * @see IEEE 802-2001 section 9.2 * @{ */ /** * @brief Locally administered address. */ #define EUI64_LOCAL_FLAG 0x02 /** * @brief Group type address. */ #define EUI64_GROUP_FLAG 0x01 /** @} */ /** * @brief Data type to represent an EUI-64. */ typedef union { network_uint64_t uint64; /**< represented as 64 bit value */ uint8_t uint8[8]; /**< split into 8 8-bit words. */ network_uint16_t uint16[4]; /**< split into 4 16-bit words. */ } eui64_t; /** * @brief Set the locally administrated bit in the EUI-64 address. * * @see IEEE 802-2001 section 9.2 * * @param addr eui64 address */ static inline void eui64_set_local(eui64_t *addr) { addr->uint8[0] |= EUI64_LOCAL_FLAG; } /** * @brief Clear the group address bit to signal the address as individual * address * * @see IEEE 802-2001 section 9.2 * * @param addr eui64 address */ static inline void eui64_clear_group(eui64_t *addr) { addr->uint8[0] &= ~EUI64_GROUP_FLAG; } #ifdef __cplusplus } #endif #endif /* NET_EUI64_H */ /** @} */