Added method to framer that returns the header length if the framer

would create a header with the current packet information.

This allows sicslowpan to calculate the max payload size without
consuming a sequence number or clearing/restoring the packet buffer.
This commit is contained in:
Niclas Finne 2014-04-11 17:03:23 +02:00
parent dbb8f3ec13
commit 68730566a3
5 changed files with 42 additions and 15 deletions

View File

@ -1434,19 +1434,12 @@ output(const uip_lladdr_t *localdest)
* needs to be fragmented or not. */ * needs to be fragmented or not. */
#define USE_FRAMER_HDRLEN 1 #define USE_FRAMER_HDRLEN 1
#if USE_FRAMER_HDRLEN #if USE_FRAMER_HDRLEN
packetbuf_clear();
packetbuf_set_addr(PACKETBUF_ADDR_RECEIVER, &dest); packetbuf_set_addr(PACKETBUF_ADDR_RECEIVER, &dest);
framer_hdrlen = NETSTACK_FRAMER.create(); framer_hdrlen = NETSTACK_FRAMER.length();
if(framer_hdrlen < 0) { if(framer_hdrlen < 0) {
/* Framing failed, we assume the maximum header length */ /* Framing failed, we assume the maximum header length */
framer_hdrlen = 21; framer_hdrlen = 21;
} }
packetbuf_clear();
/* We must set the max transmissions attribute again after clearing
the buffer. */
packetbuf_set_attr(PACKETBUF_ATTR_MAX_MAC_TRANSMISSIONS,
SICSLOWPAN_MAX_MAC_TRANSMISSIONS);
#else /* USE_FRAMER_HDRLEN */ #else /* USE_FRAMER_HDRLEN */
framer_hdrlen = 21; framer_hdrlen = 21;
#endif /* USE_FRAMER_HDRLEN */ #endif /* USE_FRAMER_HDRLEN */

View File

@ -87,7 +87,7 @@ is_broadcast_addr(uint8_t mode, uint8_t *addr)
} }
/*---------------------------------------------------------------------------*/ /*---------------------------------------------------------------------------*/
static int static int
create(void) create_frame(int type, int do_create)
{ {
frame802154_t params; frame802154_t params;
int len; int len;
@ -115,13 +115,17 @@ create(void)
params.fcf.frame_version = FRAME802154_IEEE802154_2003; params.fcf.frame_version = FRAME802154_IEEE802154_2003;
/* Increment and set the data sequence number. */ /* Increment and set the data sequence number. */
if(packetbuf_attr(PACKETBUF_ATTR_MAC_SEQNO)) { if(!do_create) {
/* Only length calculation - no sequence number is needed and
should not be consumed. */
} else if(packetbuf_attr(PACKETBUF_ATTR_MAC_SEQNO)) {
params.seq = packetbuf_attr(PACKETBUF_ATTR_MAC_SEQNO); params.seq = packetbuf_attr(PACKETBUF_ATTR_MAC_SEQNO);
} else { } else {
params.seq = mac_dsn++; params.seq = mac_dsn++;
packetbuf_set_attr(PACKETBUF_ATTR_MAC_SEQNO, params.seq); packetbuf_set_attr(PACKETBUF_ATTR_MAC_SEQNO, params.seq);
} }
/* params.seq = packetbuf_attr(PACKETBUF_ATTR_PACKET_ID); */
/* Complete the addressing fields. */ /* Complete the addressing fields. */
/** /**
@ -169,7 +173,11 @@ create(void)
params.payload = packetbuf_dataptr(); params.payload = packetbuf_dataptr();
params.payload_len = packetbuf_datalen(); params.payload_len = packetbuf_datalen();
len = frame802154_hdrlen(&params); len = frame802154_hdrlen(&params);
if(packetbuf_hdralloc(len)) { if(!do_create) {
/* Only calculate header length */
return len;
} else if(packetbuf_hdralloc(len)) {
frame802154_create(&params, packetbuf_hdrptr(), len); frame802154_create(&params, packetbuf_hdrptr(), len);
PRINTF("15.4-OUT: %2X", params.fcf.frame_type); PRINTF("15.4-OUT: %2X", params.fcf.frame_type);
@ -184,6 +192,18 @@ create(void)
} }
/*---------------------------------------------------------------------------*/ /*---------------------------------------------------------------------------*/
static int static int
hdr_length(void)
{
return create_frame(FRAME802154_DATAFRAME, 0);
}
/*---------------------------------------------------------------------------*/
static int
create(void)
{
return create_frame(FRAME802154_DATAFRAME, 1);
}
/*---------------------------------------------------------------------------*/
static int
parse(void) parse(void)
{ {
frame802154_t frame; frame802154_t frame;
@ -218,5 +238,5 @@ parse(void)
} }
/*---------------------------------------------------------------------------*/ /*---------------------------------------------------------------------------*/
const struct framer framer_802154 = { const struct framer framer_802154 = {
create, parse hdr_length, create, parse
}; };

View File

@ -55,6 +55,12 @@ struct nullmac_hdr {
linkaddr_t sender; linkaddr_t sender;
}; };
/*---------------------------------------------------------------------------*/
static int
hdr_length(void)
{
return sizeof(struct nullmac_hdr);
}
/*---------------------------------------------------------------------------*/ /*---------------------------------------------------------------------------*/
static int static int
create(void) create(void)
@ -91,5 +97,5 @@ parse(void)
} }
/*---------------------------------------------------------------------------*/ /*---------------------------------------------------------------------------*/
const struct framer framer_nullmac = { const struct framer framer_nullmac = {
create, parse hdr_length, create, parse
}; };

View File

@ -45,6 +45,7 @@
struct framer { struct framer {
int (* length)(void);
int (* create)(void); int (* create)(void);
int (* parse)(void); int (* parse)(void);

View File

@ -76,6 +76,13 @@ is_broadcast_addr(uint8_t mode, uint8_t *addr)
} }
/*---------------------------------------------------------------------------*/ /*---------------------------------------------------------------------------*/
static int static int
hdr_length(void)
{
/* never adds any header */
return 0;
}
/*---------------------------------------------------------------------------*/
static int
create(void) create(void)
{ {
/* nothing extra... */ /* nothing extra... */
@ -116,5 +123,5 @@ parse(void)
} }
/*---------------------------------------------------------------------------*/ /*---------------------------------------------------------------------------*/
const struct framer no_framer = { const struct framer no_framer = {
create, parse hdr_length, create, parse
}; };