mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-18 12:52:44 +01:00
169 lines
5.0 KiB
C
169 lines
5.0 KiB
C
|
/*
|
||
|
* Copyright (C) 2018 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_dhcpv6_client DHCPv6 client
|
||
|
* @ingroup net_dhcpv6
|
||
|
* @brief DHCPv6 client implementation
|
||
|
* @{
|
||
|
*
|
||
|
* @file
|
||
|
* @brief DHCPv6 client definitions
|
||
|
*
|
||
|
* @author Martine Lenders <m.lenders@fu-berlin.de>
|
||
|
*/
|
||
|
#ifndef NET_DHCPV6_CLIENT_H
|
||
|
#define NET_DHCPV6_CLIENT_H
|
||
|
|
||
|
#include "byteorder.h"
|
||
|
#include "event.h"
|
||
|
#include "net/ipv6/addr.h"
|
||
|
#include "thread.h"
|
||
|
|
||
|
#ifdef __cplusplus
|
||
|
extern "C" {
|
||
|
#endif
|
||
|
|
||
|
/**
|
||
|
* @name Auto-initialization parameters
|
||
|
*/
|
||
|
#ifndef DHCPV6_CLIENT_STACK_SIZE
|
||
|
#define DHCPV6_CLIENT_STACK_SIZE (THREAD_STACKSIZE_DEFAULT) /**< stack size */
|
||
|
#endif
|
||
|
|
||
|
#ifndef DHCPV6_CLIENT_PRIORITY
|
||
|
#define DHCPV6_CLIENT_PRIORITY (THREAD_PRIORITY_MAIN - 2) /**< priority */
|
||
|
#endif
|
||
|
/** @} */
|
||
|
|
||
|
/**
|
||
|
* @brief Static length of the DUID
|
||
|
*/
|
||
|
#define DHCPV6_CLIENT_DUID_LEN (sizeof(dhcpv6_duid_l2_t) + 8U)
|
||
|
#define DHCPV6_CLIENT_BUFLEN (256) /**< length for send and receive buffer */
|
||
|
#ifndef DHCPV6_CLIENT_SERVER_MAX
|
||
|
#define DHCPV6_CLIENT_SERVER_MAX (1U) /**< maximum number of servers to store */
|
||
|
#endif
|
||
|
#ifndef DHCPV6_CLIENT_PFX_LEASE_MAX
|
||
|
#define DHCPV6_CLIENT_PFX_LEASE_MAX (1U) /**< maximum number of prefix leases to store */
|
||
|
#endif
|
||
|
|
||
|
/**
|
||
|
* @name DHCPv6 unique identifier (DUID) definitions
|
||
|
* @see [RFC 8415, section 11](https://tools.ietf.org/html/rfc8415#section-11)
|
||
|
* @{
|
||
|
*/
|
||
|
/**
|
||
|
* @brief DUID based on link-layer address plus time
|
||
|
*/
|
||
|
typedef struct __attribute__((packed)) {
|
||
|
network_uint16_t type; /**< @ref DHCPV6_DUID_TYPE_L2 */
|
||
|
network_uint16_t l2type; /**< [hardware type](@ref net_arp_hwtype)) */
|
||
|
/* link-layer address follows this header */
|
||
|
} dhcpv6_duid_l2_t;
|
||
|
|
||
|
#if defined(MODULE_AUTO_INIT_DHCPV6_CLIENT) || defined(DOXYGEN)
|
||
|
/**
|
||
|
* @brief Auto-initializes the client in its own thread
|
||
|
*
|
||
|
* @note Only available with (and called by) the `dhcpv6_client_auto_init`
|
||
|
* module.
|
||
|
*/
|
||
|
void dhcpv6_client_auto_init(void);
|
||
|
#endif /* MODULE_DHCPV6_CLIENT_AUTO_INIT */
|
||
|
|
||
|
/**
|
||
|
* @brief Initializes the client
|
||
|
*
|
||
|
* @pre `event_queue->waiter != NULL`
|
||
|
*
|
||
|
* @param[in] event_queue Event queue to use with the client. Needs to be
|
||
|
* initialized in the handler thread.
|
||
|
* @param[in] netif The network interface the client should listen on.
|
||
|
* SOCK_ADDR_ANY_NETIF for any interface
|
||
|
*/
|
||
|
void dhcpv6_client_init(event_queue_t *event_queue, uint16_t netif);
|
||
|
|
||
|
/**
|
||
|
* @brief Let the server start listening
|
||
|
*
|
||
|
* This needs to be called *after* all desired [configuration functions]
|
||
|
* (@ref net_dhcpv6_client_conf) where called.
|
||
|
*/
|
||
|
void dhcpv6_client_start(void);
|
||
|
|
||
|
/**
|
||
|
* @name Configuration functions
|
||
|
* @anchor net_dhcpv6_client_conf
|
||
|
* @{
|
||
|
*/
|
||
|
/**
|
||
|
* @brief Configures the client to request prefix delegation for a network
|
||
|
* interface from a server
|
||
|
*
|
||
|
* @pre `pfx_len <= 128`
|
||
|
*
|
||
|
* @param[in] netif The interface to request the prefix delegation for.
|
||
|
* @param[in] pfx_len The desired length of the prefix (note that the server
|
||
|
* might not consider this request). Must be <= 128
|
||
|
*/
|
||
|
void dhcpv6_client_req_ia_pd(unsigned netif, unsigned pfx_len);
|
||
|
/** @} */
|
||
|
|
||
|
/**
|
||
|
* @name Stack-specific functions
|
||
|
*
|
||
|
* These functions need to be provided by the network-stack implementation.
|
||
|
* @{
|
||
|
*/
|
||
|
/**
|
||
|
* @brief Get the link-layer address DUID for the client
|
||
|
*
|
||
|
* @param[in] netif The network interface the client is bound to. May be
|
||
|
* SOCK_ADDR_ANY_NETIF for any interface.
|
||
|
* @param[out] duid The resulting DUID.
|
||
|
*
|
||
|
* @return length of the @p duid on success.
|
||
|
* @return 0, on error.
|
||
|
*/
|
||
|
unsigned dhcpv6_client_get_duid_l2(unsigned netif, dhcpv6_duid_l2_t *duid);
|
||
|
|
||
|
/**
|
||
|
* @brief Configures a prefix delegation lease that is provided by the server.
|
||
|
*
|
||
|
* @param[in] netif Network interface the prefix delegation was for.
|
||
|
* @param[in] pfx Prefix for the prefix delegation.
|
||
|
* @param[in] pfx_len Length of @p pfx in bits.
|
||
|
* @param[in] valid Valid lifetime of the prefix delegation.
|
||
|
* @param[in] pref Preferred lifetime of the prefix delegation.
|
||
|
*/
|
||
|
void dhcpv6_client_conf_prefix(unsigned netif, const ipv6_addr_t *pfx,
|
||
|
unsigned pfx_len, uint32_t valid,
|
||
|
uint32_t pref);
|
||
|
|
||
|
/**
|
||
|
* @brief Determines how long the prefix delegation lease is still valid.
|
||
|
*
|
||
|
* @param[in] netif Network interface the prefix delegation was for.
|
||
|
* @param[in] pfx Prefix of the prefix delegation
|
||
|
* @param[in] pfx_len Length of @p pfx in bits.
|
||
|
*
|
||
|
* @return Remaining valid lifetime of the prefix delegation lease in seconds.
|
||
|
*/
|
||
|
uint32_t dhcpv6_client_prefix_valid_until(unsigned netif,
|
||
|
const ipv6_addr_t *pfx,
|
||
|
unsigned pfx_len);
|
||
|
/** @} */
|
||
|
|
||
|
#ifdef __cplusplus
|
||
|
}
|
||
|
#endif
|
||
|
|
||
|
#endif /* NET_DHCPV6_CLIENT_H */
|
||
|
/** @} */
|