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.
|
|
|
|
*
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
#include "contiki.h"
|
|
|
|
#include "uip.h"
|
2017-12-08 12:38:30 +00:00
|
|
|
#include "net/ipv6/uipbuf.h"
|
|
|
|
#include <string.h>
|
2017-09-23 06:57:57 +00:00
|
|
|
|
2017-12-08 12:38:30 +00:00
|
|
|
/*---------------------------------------------------------------------------*/
|
|
|
|
|
|
|
|
static uint16_t uipbuf_attrs[UIPBUF_ATTR_MAX];
|
|
|
|
|
|
|
|
/*---------------------------------------------------------------------------*/
|
2017-09-23 06:57:57 +00:00
|
|
|
/* Get the next header given the buffer - start indicates that this is
|
|
|
|
start of the IPv6 header - needs to be set to 0 when in an ext hdr */
|
|
|
|
uint8_t*
|
|
|
|
uipbuf_get_next_header(uint8_t *buffer, uint16_t size, uint8_t *protocol, uint8_t start)
|
|
|
|
{
|
|
|
|
int ext_len = 0;
|
|
|
|
struct uip_ip_hdr *ipbuf = (struct uip_ip_hdr *) buffer;
|
|
|
|
struct uip_ext_hdr *ext = NULL;
|
|
|
|
|
|
|
|
if(start) {
|
|
|
|
/* protocol in the IP buffer */
|
|
|
|
*protocol = ipbuf->proto;
|
|
|
|
return buffer + UIP_IPH_LEN;
|
|
|
|
} else {
|
|
|
|
/* protocol in the Ext hdr */
|
|
|
|
ext = (struct uip_ext_hdr *) buffer;
|
|
|
|
*protocol = ext->next;
|
|
|
|
/* This is just an ext header */
|
|
|
|
ext_len = (ext->len << 3) + 8;
|
|
|
|
return buffer + ext_len;
|
|
|
|
}
|
|
|
|
}
|
2017-12-08 12:38:30 +00:00
|
|
|
/*---------------------------------------------------------------------------*/
|
2017-09-23 06:57:57 +00:00
|
|
|
/* Get the final header given the buffer - that is assumed to be at start
|
|
|
|
of an IPv6 header */
|
|
|
|
uint8_t*
|
|
|
|
uipbuf_get_last_header(uint8_t *buffer, uint16_t size, uint8_t *protocol)
|
|
|
|
{
|
|
|
|
uint8_t *nbuf;
|
|
|
|
|
|
|
|
nbuf = uipbuf_get_next_header(buffer, size, protocol, 1);
|
|
|
|
while(uip_is_proto_ext_hdr(*protocol)) {
|
|
|
|
/* send in and move beyond the ext hdr */
|
|
|
|
nbuf = uipbuf_get_next_header(nbuf, size - (nbuf - buffer), protocol, 0);
|
|
|
|
}
|
|
|
|
return nbuf;
|
|
|
|
}
|
2017-12-08 12:38:30 +00:00
|
|
|
/*---------------------------------------------------------------------------*/
|
|
|
|
/**
|
|
|
|
* Common functions for uipbuf (attributes, etc).
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
/*---------------------------------------------------------------------------*/
|
|
|
|
uint16_t
|
|
|
|
uipbuf_get_attr(uint8_t type)
|
|
|
|
{
|
|
|
|
if(type < UIPBUF_ATTR_MAX) {
|
|
|
|
return uipbuf_attrs[type];
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
/*---------------------------------------------------------------------------*/
|
|
|
|
int
|
|
|
|
uipbuf_set_attr(uint8_t type, uint16_t value)
|
|
|
|
{
|
|
|
|
if(type < UIPBUF_ATTR_MAX) {
|
|
|
|
uipbuf_attrs[type] = value;
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
/*---------------------------------------------------------------------------*/
|
|
|
|
void
|
|
|
|
uipbuf_clear_attr(void)
|
|
|
|
{
|
2017-12-09 09:21:49 +00:00
|
|
|
/* set everything to "zero" */
|
2017-12-08 12:38:30 +00:00
|
|
|
memset(uipbuf_attrs, 0, sizeof(uipbuf_attrs));
|
2017-12-09 09:21:49 +00:00
|
|
|
|
|
|
|
/* And initialize anything that should be initialized */
|
|
|
|
uipbuf_set_attr(UIPBUF_ATTR_MAX_MAC_TRANSMISSIONS,
|
|
|
|
UIP_MAX_MAC_TRANSMISSIONS_UNDEFINED);
|
2017-12-08 12:38:30 +00:00
|
|
|
}
|
|
|
|
/*---------------------------------------------------------------------------*/
|
|
|
|
void
|
|
|
|
uipbuf_set_attr_flag(uint16_t flag)
|
|
|
|
{
|
|
|
|
/* Assume only 16-bits for flags now */
|
|
|
|
uipbuf_attrs[UIPBUF_ATTR_FLAGS] |= flag;
|
|
|
|
}
|
|
|
|
/*---------------------------------------------------------------------------*/
|
|
|
|
void
|
|
|
|
uipbuf_clr_attr_flag(uint16_t flag)
|
|
|
|
{
|
|
|
|
uipbuf_attrs[UIPBUF_ATTR_FLAGS] &= ~flag;
|
|
|
|
}
|
|
|
|
/*---------------------------------------------------------------------------*/
|
|
|
|
uint16_t
|
|
|
|
uipbuf_is_attr_flag(uint16_t flag)
|
|
|
|
{
|
2017-12-10 19:34:50 +00:00
|
|
|
return (uipbuf_attrs[UIPBUF_ATTR_FLAGS] & flag) == flag;
|
2017-12-08 12:38:30 +00:00
|
|
|
}
|
|
|
|
/*---------------------------------------------------------------------------*/
|