2015-06-03 16:12:09 +02:00
|
|
|
/*
|
|
|
|
* 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
|
2019-09-14 15:47:10 +02:00
|
|
|
* @brief Type definition of the IEEE EUI-64 identifier
|
2020-03-04 13:28:24 +01:00
|
|
|
* @see <a href="https://web.archive.org/web/20170730083229/http://standards.ieee.org:80/develop/regauth/tut/eui64.pdf">
|
2015-06-03 16:12:09 +02:00
|
|
|
* IEEE, "Guidelines for 64-bit Global Identifier (EUI-64)"
|
|
|
|
* </a>
|
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
* @brief EUI-64 data type definition
|
|
|
|
*
|
|
|
|
* @author Martine Lenders <mlenders@inf.fu-berlin.de>
|
|
|
|
* @author Oliver Hahm <oliver.hahm@inria.fr>
|
|
|
|
*/
|
2017-05-23 18:19:52 +02:00
|
|
|
#ifndef NET_EUI64_H
|
|
|
|
#define NET_EUI64_H
|
2015-06-03 16:12:09 +02:00
|
|
|
|
|
|
|
#include <stdint.h>
|
|
|
|
#include "byteorder.h"
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2019-11-04 17:33:36 +01:00
|
|
|
/**
|
|
|
|
* @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
|
|
|
|
/** @} */
|
|
|
|
|
2015-06-03 16:12:09 +02:00
|
|
|
/**
|
|
|
|
* @brief Data type to represent an EUI-64.
|
|
|
|
*/
|
|
|
|
typedef union {
|
|
|
|
network_uint64_t uint64; /**< represented as 64 bit value */
|
2020-03-01 18:37:51 +01:00
|
|
|
uint8_t uint8[8]; /**< split into 8 8-bit words. */
|
|
|
|
network_uint16_t uint16[4]; /**< split into 4 16-bit words. */
|
|
|
|
network_uint32_t uint32[2]; /**< split into 2 32-bit words. */
|
2015-06-03 16:12:09 +02:00
|
|
|
} eui64_t;
|
|
|
|
|
2019-11-04 17:33:36 +01:00
|
|
|
/**
|
|
|
|
* @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;
|
|
|
|
}
|
|
|
|
|
2015-06-03 16:12:09 +02:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2017-05-23 18:19:52 +02:00
|
|
|
#endif /* NET_EUI64_H */
|
2015-06-03 16:12:09 +02:00
|
|
|
/** @} */
|