2017-09-23 06:57:57 +00:00
|
|
|
/*
|
2017-12-08 12:38:30 +00:00
|
|
|
* Copyright (c) 2017, RISE SICS, Yanzi Networks
|
2017-09-23 06:57:57 +00:00
|
|
|
* All rights reserved.
|
|
|
|
*
|
|
|
|
* Redistribution and use in source and binary forms, with or without
|
|
|
|
* modification, are permitted provided that the following conditions
|
|
|
|
* are met:
|
|
|
|
* 1. Redistributions of source code must retain the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer.
|
|
|
|
* 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer in the
|
|
|
|
* documentation and/or other materials provided with the distribution.
|
|
|
|
* 3. The name of the authors may not be used to endorse or promote
|
|
|
|
* products derived from this software without specific prior
|
|
|
|
* written permission.
|
|
|
|
*
|
|
|
|
* THIS SOFTWARE IS PROVIDED BY THE AUTHORS ``AS IS''
|
|
|
|
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
|
|
|
|
* TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A
|
|
|
|
* PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE
|
|
|
|
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
|
|
|
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT
|
|
|
|
* OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
|
|
|
|
* BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
|
|
|
|
* LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
|
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE
|
|
|
|
* USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH
|
|
|
|
* DAMAGE.
|
|
|
|
*
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2017-12-08 12:38:30 +00:00
|
|
|
#ifndef UIPBUF_H_
|
|
|
|
#define UIPBUF_H_
|
|
|
|
|
2017-09-23 06:57:57 +00:00
|
|
|
#include "contiki.h"
|
2018-10-18 09:20:34 +00:00
|
|
|
struct uip_ip_hdr;
|
2017-09-23 06:57:57 +00:00
|
|
|
|
2018-10-17 21:33:02 +00:00
|
|
|
/**
|
|
|
|
* \brief Resets uIP buffer
|
|
|
|
*/
|
|
|
|
void uipbuf_clear(void);
|
|
|
|
|
2018-10-17 16:09:40 +00:00
|
|
|
/**
|
|
|
|
* \brief Update uip buffer length for addition of an extension header
|
|
|
|
* \param len The length of the new extension header
|
|
|
|
* \retval true if the length fields were successfully set, false otherwise
|
|
|
|
*/
|
|
|
|
bool uipbuf_add_ext_hdr(int16_t len);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Set the length of the uIP buffer
|
|
|
|
* \param len The new length
|
|
|
|
* \retval true if the len was successfully set, false otherwise
|
|
|
|
*/
|
|
|
|
bool uipbuf_set_len(uint16_t len);
|
|
|
|
|
2018-10-18 09:20:34 +00:00
|
|
|
/**
|
|
|
|
* \brief Updates the length field in the uIP buffer
|
2018-10-18 09:31:06 +00:00
|
|
|
* \param buffer The IPv6 header
|
2018-10-18 09:20:34 +00:00
|
|
|
* \param len The new length value
|
|
|
|
*/
|
|
|
|
void uipbuf_set_len_field(struct uip_ip_hdr *hdr, uint16_t len);
|
|
|
|
|
2018-10-18 09:31:06 +00:00
|
|
|
/**
|
|
|
|
* \brief Returns the value of the length field in the uIP buffer
|
|
|
|
* \param buffer The IPv6 header
|
|
|
|
* \retvel The length value
|
|
|
|
*/
|
|
|
|
uint16_t uipbuf_get_len_field(struct uip_ip_hdr *hdr);
|
2017-09-23 06:57:57 +00:00
|
|
|
|
2017-12-10 19:34:50 +00:00
|
|
|
/**
|
|
|
|
* \brief Get the next IPv6 header.
|
|
|
|
* \param buffer A pointer to the buffer holding the IPv6 packet
|
|
|
|
* \param size The size of the data in the buffer
|
|
|
|
* \param protocol A pointer to a variable where the protocol of the header will be stored
|
|
|
|
* \param start A flag that indicates if this is expected to be the IPv6 packet header or a later header (Extension header)
|
2018-10-17 16:09:40 +00:00
|
|
|
* \retval returns address of the next header, or NULL in case of insufficient buffer space
|
2017-12-10 19:34:50 +00:00
|
|
|
*
|
|
|
|
* This function moves to the next header in a IPv6 packet.
|
|
|
|
*/
|
2018-10-17 16:09:40 +00:00
|
|
|
uint8_t *uipbuf_get_next_header(uint8_t *buffer, uint16_t size, uint8_t *protocol, bool start);
|
2017-12-10 19:34:50 +00:00
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Get the last IPv6 header.
|
|
|
|
* \param buffer A pointer to the buffer holding the IPv6 packet
|
|
|
|
* \param size The size of the data in the buffer
|
|
|
|
* \param protocol A pointer to a variable where the protocol of the header will be stored
|
2018-10-17 16:09:40 +00:00
|
|
|
* \retval returns address of the last header, or NULL in case of insufficient buffer space
|
2017-12-10 19:34:50 +00:00
|
|
|
*
|
|
|
|
* This function moves to the last header of the IPv6 packet.
|
|
|
|
*/
|
2018-10-17 16:09:40 +00:00
|
|
|
uint8_t *uipbuf_get_last_header(uint8_t *buffer, uint16_t size, uint8_t *protocol);
|
2017-12-08 12:38:30 +00:00
|
|
|
|
2018-10-17 16:09:40 +00:00
|
|
|
/**
|
|
|
|
* \brief Get an IPv6 header with a given protocol field.
|
|
|
|
* \param buffer A pointer to the buffer holding the IPv6 packet
|
|
|
|
* \param size The size of the data in the buffer
|
|
|
|
* \param protocol The protocol we are looking for
|
|
|
|
* \retval returns address of the header if found, else NULL
|
|
|
|
*
|
|
|
|
* This function moves to the last header of the IPv6 packet.
|
|
|
|
*/
|
|
|
|
uint8_t *uipbuf_search_header(uint8_t *buffer, uint16_t size, uint8_t protocol);
|
2017-12-10 19:34:50 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Get the value of the attribute
|
|
|
|
* \param type The attribute to get the value of
|
|
|
|
* \retval the value of the attribute
|
|
|
|
*
|
|
|
|
* This function gets the value of a specific uipbuf attribute.
|
|
|
|
*/
|
2017-12-08 12:38:30 +00:00
|
|
|
uint16_t uipbuf_get_attr(uint8_t type);
|
2017-12-10 19:34:50 +00:00
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Set the value of the attribute
|
|
|
|
* \param type The attribute to set the value of
|
|
|
|
* \param value The value to set
|
|
|
|
* \retval 0 - indicates failure of setting the value
|
|
|
|
* \retval 1 - indicates success of setting the value
|
|
|
|
*
|
|
|
|
* This function sets the value of a specific uipbuf attribute.
|
|
|
|
*/
|
2017-12-08 12:38:30 +00:00
|
|
|
int uipbuf_set_attr(uint8_t type, uint16_t value);
|
2017-12-10 19:34:50 +00:00
|
|
|
|
2018-10-20 20:25:55 +00:00
|
|
|
/**
|
|
|
|
* \brief Set the default value of the attribute
|
|
|
|
* \param type The attribute to set the default value of
|
|
|
|
* \param value The value to set
|
|
|
|
* \retval 0 - indicates failure of setting the value
|
|
|
|
* \retval 1 - indicates success of setting the value
|
|
|
|
*
|
|
|
|
* This function sets the default value of a uipbuf attribute.
|
|
|
|
*/
|
|
|
|
int uipbuf_set_default_attr(uint8_t type, uint16_t value);
|
|
|
|
|
2017-12-10 19:34:50 +00:00
|
|
|
/**
|
|
|
|
* \brief Set bits in the uipbuf attribute flags.
|
|
|
|
* \param flag_bits The bits to set in the flag.
|
|
|
|
*
|
|
|
|
* This function sets the uipbuf attributes flag of specified bits.
|
|
|
|
*/
|
|
|
|
void uipbuf_set_attr_flag(uint16_t flag_bits);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Clear bits in the uipbuf attribute flags.
|
|
|
|
* \param flag_bits The bits to clear in the flag.
|
|
|
|
*
|
|
|
|
* This function clears the uipbuf attributes flag of specified bits.
|
|
|
|
*/
|
|
|
|
void uipbuf_clr_attr_flag(uint16_t flag_bits);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Check if bits in the uipbuf attribute flag are set.
|
|
|
|
* \param flag_bits The bits to check in the flag.
|
|
|
|
*
|
|
|
|
* This function checks if the specified bits are set in the
|
|
|
|
* uipbuf attributes flag.
|
|
|
|
*/
|
|
|
|
uint16_t uipbuf_is_attr_flag(uint16_t flag_bits);
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Clear all attributes.
|
|
|
|
*
|
|
|
|
* This function clear all attributes in the uipbuf attributes
|
|
|
|
* including all flags.
|
|
|
|
*/
|
2017-12-08 12:38:30 +00:00
|
|
|
void uipbuf_clear_attr(void);
|
|
|
|
|
2018-10-20 20:25:55 +00:00
|
|
|
/**
|
|
|
|
* \brief Initialize uipbuf attributes.
|
|
|
|
*
|
|
|
|
* This function initialize all attributes in the uipbuf
|
|
|
|
* attributes including all flags.
|
|
|
|
*/
|
|
|
|
void uipbuf_init(void);
|
|
|
|
|
2017-12-10 19:34:50 +00:00
|
|
|
/**
|
|
|
|
* \brief The bits defined for uipbuf attributes flag.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
/* Avoid using NHC compression on the packet (6LoWPAN) */
|
2017-12-08 12:38:30 +00:00
|
|
|
#define UIPBUF_ATTR_FLAGS_6LOWPAN_NO_NHC_COMPRESSION 0x01
|
2017-12-10 19:34:50 +00:00
|
|
|
/* Avoid using prefix compression on the packet (6LoWPAN) */
|
2017-12-08 12:38:30 +00:00
|
|
|
#define UIPBUF_ATTR_FLAGS_6LOWPAN_NO_PREFIX_COMPRESSION 0x02
|
|
|
|
|
2018-10-20 20:25:55 +00:00
|
|
|
/* MAC will set the default for this packet */
|
|
|
|
#define UIPBUF_ATTR_LLSEC_LEVEL_MAC_DEFAULT 0xffff
|
|
|
|
|
2017-12-10 19:34:50 +00:00
|
|
|
/**
|
|
|
|
* \brief The attributes defined for uipbuf attributes function.
|
|
|
|
*
|
|
|
|
*/
|
2017-12-08 12:38:30 +00:00
|
|
|
enum {
|
2017-12-10 19:34:50 +00:00
|
|
|
UIPBUF_ATTR_LLSEC_LEVEL, /**< Control link layer security level. */
|
|
|
|
UIPBUF_ATTR_LLSEC_KEY_ID, /**< Control link layer security key ID. */
|
|
|
|
UIPBUF_ATTR_INTERFACE_ID, /**< The interface to output packet on */
|
|
|
|
UIPBUF_ATTR_PHYSICAL_NETWORK_ID, /**< Physical network ID (mapped to PAN ID)*/
|
|
|
|
UIPBUF_ATTR_MAX_MAC_TRANSMISSIONS, /**< MAX transmissions of the packet MAC */
|
|
|
|
UIPBUF_ATTR_FLAGS, /**< Flags that can control lower layers. see above. */
|
2017-12-08 12:38:30 +00:00
|
|
|
UIPBUF_ATTR_MAX
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif /* UIPBUF_H_ */
|