mbed-os/nanostack/net_6lowpan_parameter_api.h

125 lines
5.2 KiB
C

/*
* Copyright (c) 2014-2015, 2017, Pelion and affiliates.
* SPDX-License-Identifier: Apache-2.0
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#ifndef NET_6LOWPAN_PARAMETER_API_H_
#define NET_6LOWPAN_PARAMETER_API_H_
#include "ns_types.h"
#ifdef __cplusplus
extern "C" {
#endif
/**
* \file net_6lowpan_parameter_api.h
* \brief API for setting up 6LoWPAN network parameters
*
* \section tim-para-def 6LoWPAN Default timer values
* - Timer values are specified in ticks
* - Default 6LoWPAN ND Bootstrap tick is 1 tick = 100ms
*
* - Default Random value 0x1f = [0..3.1] seconds.
* - Default RS retry counter 3.
* - Default RS retry interval is 15 + random --> [1.5..4.6] seconds.
* - Default NS retry counter 5.
* - Default NS retry interval is 100 + random + backoff --> [10.0..13.1+10.0*retry] seconds.
* - Default NS retry linear backoff is 100.
*
* - Default RA transmit interval is 150, exponentially backed off --> 15.0, 30.0, 60.0 seconds.
* - Default RA transmit counter is 5.
*
* - Default NS forward timeout is 300 --> 30.0 seconds.
*
* \section Changing random and interval values
* - Random parameter + NS or RS minimum interval must sum to less than 0xFFFF.
* - Random maximums are manipulated as bit masks, so must be (2^n)-1.
*/
/*!
* \struct nd_parameters_s
* \brief 6LoWPAN Neighbor Discovery parameters
*/
typedef struct nd_parameters_s {
uint8_t rs_retry_max; /**< Define Bootstrap RS max retry count. */
uint8_t ns_retry_max; /**< Define Bootstrap NS max retry count. */
uint16_t timer_random_max; /**< Define Interval random in 6LoWPAN bootstrap timer ticks for RS, NS and starting NS - NA process. */
uint16_t rs_retry_interval_min; /**< Define Retry interval in 6LoWPAN bootstrap timer ticks waiting for RA. */
uint16_t ns_retry_interval_min; /**< Define Retry interval in 6LoWPAN bootstrap timer ticks waiting for NA. */
uint16_t ns_retry_linear_backoff; /**< Define Retry interval linear backoff in bootstrap timer ticks. */
bool multihop_dad; /**< Define whether to perform duplicate address detection with border router or locally. */
bool iids_map_to_mac; /**< Define whether IPv6 IIDs can be assumed to be based on MAC address (so no address resolution by routers). */
bool send_nud_probes; /**< Define whether IPv6 NUD probes are enabled (disabling may limit fault detection). */
uint16_t ra_interval_min; /**< Define initial transmission interval for Router Advertisements in standard timer ticks. */
uint8_t ra_transmits; /**< Define number of RA transmissions. */
uint8_t ra_cur_hop_limit; /**< Define the value of current hop limit in RAs. */
uint32_t ra_link_mtu; /**< Define the value of link MTU in RAs. */
uint32_t ra_reachable_time; /**< Define the value of reachable time in RAs (in milliseconds). */
uint32_t ra_retrans_timer; /**< Define the value of retrans timer in RAs (in milliseconds). */
uint16_t ns_forward_timeout; /**< Define timeout when forwarding NS messages - if reached, our own address discovery process is restarted. */
} nd_parameters_s;
/**
* \brief Function to change 6LoWPAN ND bootstrap parameters.
*
* Note: This function should be called after net_init_core() and definitely
* before creating any 6LoWPAN interface.
*
* For future compatibility, to support extensions to this structure, read
* the current parameters using net_6lowpan_timer_parameter_read(),
* modify known fields, then set.
*
* \param parameter_ptr Pointer for ND parameters.
*
* \return 0, Change OK.
* \return -1, Invalid values.
* \return -2, 6LoWPAN interface already active.
*
*/
extern int8_t net_6lowpan_nd_parameter_set(const nd_parameters_s *parameter_ptr);
/**
* \brief Function to change 6LoWPAN bootstrap base tick 100ms multiplier.
*
* Note: This function MUST be called after net_init_core(). Do not change this
* unless you really want 6LoWPAN bootstrap working slower than normally.
*
* This only affects the bootstrap timers.
*
* \param base_tick_x_100ms Tick resolution in 100ms units.
* Max value 10 --> 10 times slower functionality
*
* \return 0, Change OK.
* \return -1, Invalid value (<1 or >10).
*
*/
extern int8_t net_6lowpan_nd_timer_base_tick_set(uint8_t base_tick_x_100ms);
/**
* \brief Function to read 6LoWPAN ND bootstrap parameters.
*
* \param parameter_ptr Output pointer for ND parameters.
*
*/
extern void net_6lowpan_nd_parameter_read(nd_parameters_s *parameter_ptr);
#ifdef __cplusplus
}
#endif
#endif /* NET_6LOWPAN_DEFAULT_PARAMETER_API_H_ */