1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2024-12-29 04:50:03 +01:00
RIOT/sys/include/net/gnrc/rpl/srh.h

78 lines
2.4 KiB
C
Raw Normal View History

/*
* Copyright (C) 2015 Martine Lenders <mlenders@inf.fu-berlin.de>
*
* 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.
*/
/**
2016-06-05 23:05:59 +02:00
* @defgroup net_gnrc_rpl_srh RPL source routing header extension
* @ingroup net_gnrc_rpl
* @brief Implementation of RPL source routing extension headers
* @see <a href="https://tools.ietf.org/html/rfc6554">
* RFC 6554
* </a>
* @{
*
* @file
* @brief Definititions for RPL source routing extension headers
*
* @author Martine Lenders <mlenders@inf.fu-berlin.de>
*/
#ifndef NET_GNRC_RPL_SRH_H
#define NET_GNRC_RPL_SRH_H
#include "net/ipv6/hdr.h"
2015-08-10 00:26:36 +02:00
#include "net/ipv6/addr.h"
#ifdef __cplusplus
extern "C" {
#endif
/**
* @brief The RPL Source routing header.
*
* @see <a href="https://tools.ietf.org/html/rfc6554">
* RFC 6554
* </a>
*
* @extends ipv6_ext_rh_t
*/
typedef struct __attribute__((packed)) {
uint8_t nh; /**< next header */
uint8_t len; /**< length in 8 octets without first octet */
uint8_t type; /**< identifier of a particular routing header type */
uint8_t seg_left; /**< number of route segments remaining */
uint8_t compr; /**< number of prefix octets (comprI and comprE) */
uint8_t pad_resv; /**< padding and reserved */
uint16_t resv; /**< reserved */
} gnrc_rpl_srh_t;
/**
* @brief Process the RPL source routing header.
*
* @pre `rh->seq_left > 0`; The 0 case means the destination is reached and
* common among all routing headers, so it should be handled by an
* external routing header handler.
*
* @param[in, out] ipv6 The IPv6 header of the incoming packet.
* @param[in] rh A RPL source routing header.
* @param[out] err_ptr A pointer to an erroneous octet within @p rh when
* return value is @ref GNRC_IPV6_EXT_RH_ERROR. For any
* other return value than @ref GNRC_IPV6_EXT_RH_ERROR the
* value of `err_ptr` is not defined.
*
* @return @ref GNRC_IPV6_EXT_RH_AT_DST, on success
* @return @ref GNRC_IPV6_EXT_RH_FORWARDED, when @p pkt *should be* forwarded
* @return @ref GNRC_IPV6_EXT_RH_ERROR, on error
*/
int gnrc_rpl_srh_process(ipv6_hdr_t *ipv6, gnrc_rpl_srh_t *rh, void **err_ptr);
#ifdef __cplusplus
}
#endif
#endif /* NET_GNRC_RPL_SRH_H */
/** @} */