6loWPAN: Change ordering of some operations so that the IOB is available at the time that headr compression is perfomed.

This commit is contained in:
Gregory Nutt 2017-04-01 18:24:21 -06:00
parent 6464ebbc7f
commit 5a56d3cce7
4 changed files with 78 additions and 89 deletions

View File

@ -101,7 +101,7 @@
* *
* Input Parameters: * Input Parameters:
* ieee - Pointer to IEEE802.15.4 MAC driver structure. * ieee - Pointer to IEEE802.15.4 MAC driver structure.
* ipv6 - Pointer to the IPv6 header to "compress" * destip - Pointer to the IPv6 header to "compress"
* *
* Returned Value: * Returned Value:
* None * None
@ -109,7 +109,7 @@
****************************************************************************/ ****************************************************************************/
static void sixlowpan_compress_ipv6hdr(FAR struct ieee802154_driver_s *ieee, static void sixlowpan_compress_ipv6hdr(FAR struct ieee802154_driver_s *ieee,
FAR const struct ipv6_hdr_s *ipv6) FAR const struct ipv6_hdr_s *destip)
{ {
/* Indicate the IPv6 dispatch and length */ /* Indicate the IPv6 dispatch and length */
@ -118,7 +118,7 @@ static void sixlowpan_compress_ipv6hdr(FAR struct ieee802154_driver_s *ieee,
/* Copy the IPv6 header and adjust pointers */ /* Copy the IPv6 header and adjust pointers */
memcpy(g_rimeptr + g_rime_hdrlen, ipv6, IPv6_HDRLEN); memcpy(g_rimeptr + g_rime_hdrlen, destip, IPv6_HDRLEN);
g_rime_hdrlen += IPv6_HDRLEN; g_rime_hdrlen += IPv6_HDRLEN;
g_uncomp_hdrlen += IPv6_HDRLEN; g_uncomp_hdrlen += IPv6_HDRLEN;
} }
@ -166,7 +166,7 @@ int sixlowpan_queue_frames(FAR struct ieee802154_driver_s *ieee,
{ {
FAR struct iob_s *iob; FAR struct iob_s *iob;
int framer_hdrlen; int framer_hdrlen;
struct rimeaddr_s dest; struct rimeaddr_s bcastmac;
uint16_t outlen = 0; uint16_t outlen = 0;
/* Initialize global data. Locking the network guarantees that we have /* Initialize global data. Locking the network guarantees that we have
@ -211,13 +211,24 @@ int sixlowpan_queue_frames(FAR struct ieee802154_driver_s *ieee,
if (destmac == NULL) if (destmac == NULL)
{ {
memset(&dest, 0, sizeof(struct rimeaddr_s)); memset(&bcastmac, 0, sizeof(struct rimeaddr_s));
} destmac = &bcastmac;
else
{
rimeaddr_copy(&dest, (FAR const struct rimeaddr_s *)destmac);
} }
/* Pre-allocate the IOB to hold frame or the first fragment, waiting if
* necessary.
*/
iob = iob_alloc(false);
DEBUGASSERT(iob != NULL);
/* Initialize the IOB */
iob->io_flink = NULL;
iob->io_len = 0;
iob->io_offset = 0;
iob->io_pktlen = 0;
ninfo("Sending packet len %d\n", len); ninfo("Sending packet len %d\n", len);
#ifndef CONFIG_NET_6LOWPAN_COMPRESSION_IPv6 #ifndef CONFIG_NET_6LOWPAN_COMPRESSION_IPv6
@ -226,9 +237,9 @@ int sixlowpan_queue_frames(FAR struct ieee802154_driver_s *ieee,
/* Try to compress the headers */ /* Try to compress the headers */
#if defined(CONFIG_NET_6LOWPAN_COMPRESSION_HC1) #if defined(CONFIG_NET_6LOWPAN_COMPRESSION_HC1)
sixlowpan_compresshdr_hc1(ieee, &dest); sixlowpan_compresshdr_hc1(ieee, destip, destmac, iob);
#elif defined(CONFIG_NET_6LOWPAN_COMPRESSION_HC06) #elif defined(CONFIG_NET_6LOWPAN_COMPRESSION_HC06)
sixlowpan_compresshdr_hc06(ieee, &dest); sixlowpan_compresshdr_hc06(ieee, destip, destmac, iob);
#else #else
# error No compression specified # error No compression specified
#endif #endif
@ -243,7 +254,7 @@ int sixlowpan_queue_frames(FAR struct ieee802154_driver_s *ieee,
ninfo("Header of len %d\n", g_rime_hdrlen); ninfo("Header of len %d\n", g_rime_hdrlen);
rimeaddr_copy(&g_pktaddrs[PACKETBUF_ADDR_RECEIVER], &dest); rimeaddr_copy(&g_pktaddrs[PACKETBUF_ADDR_RECEIVER], destmac);
/* Pre-calculate frame header length. */ /* Pre-calculate frame header length. */
@ -279,20 +290,8 @@ int sixlowpan_queue_frames(FAR struct ieee802154_driver_s *ieee,
ninfo("Fragmentation sending packet len %d\n", len); ninfo("Fragmentation sending packet len %d\n", len);
/* Allocate an IOB to hold the first fragment, waiting if necessary. */
iob = iob_alloc(false);
DEBUGASSERT(iob != NULL);
/* Initialize the IOB */
iob->io_flink = NULL;
iob->io_len = 0;
iob->io_offset = 0;
iob->io_pktlen = 0;
/* Create 1st Fragment */ /* Create 1st Fragment */
/* Add the frame header */ /* Add the frame header using the pre-allocated IOB. */
verify = sixlowpan_framecreate(ieee, iob, ieee->i_panid); verify = sixlowpan_framecreate(ieee, iob, ieee->i_panid);
DEBUGASSERT(verify == framer_hdrlen); DEBUGASSERT(verify == framer_hdrlen);
@ -434,19 +433,7 @@ int sixlowpan_queue_frames(FAR struct ieee802154_driver_s *ieee,
* and send in one frame. * and send in one frame.
*/ */
/* Allocate an IOB to hold the frame, waiting if necessary. */ /* Add the frame header to the prealloated IOB. */
iob = iob_alloc(false);
DEBUGASSERT(iob != NULL);
/* Initialize the IOB */
iob->io_flink = NULL;
iob->io_len = 0;
iob->io_offset = 0;
iob->io_pktlen = 0;
/* Add the frame header */
verify = sixlowpan_framecreate(ieee, iob, ieee->i_panid); verify = sixlowpan_framecreate(ieee, iob, ieee->i_panid);
DEBUGASSERT(vreify == framer_hdrlen); DEBUGASSERT(vreify == framer_hdrlen);

View File

@ -203,8 +203,8 @@ void sixlowpan_hc06_initialize(void)
* *
* Input Parameters: * Input Parameters:
* ieee - A reference to the IEE802.15.4 network device state * ieee - A reference to the IEE802.15.4 network device state
* ipv6 - The IPv6 header to be compressed * destip - The IPv6 header to be compressed
* destaddr - L2 destination address, needed to compress the IP * destmac - L2 destination address, needed to compress the IP
* destination field * destination field
* iob - The IOB into which the compressed header should be saved. * iob - The IOB into which the compressed header should be saved.
* *
@ -214,7 +214,9 @@ void sixlowpan_hc06_initialize(void)
****************************************************************************/ ****************************************************************************/
void sixlowpan_compresshdr_hc06(FAR struct ieee802154_driver_s *ieee, void sixlowpan_compresshdr_hc06(FAR struct ieee802154_driver_s *ieee,
FAR struct rimeaddr_s *destaddr) FAR const struct ipv6_hdr_s *destip,
FAR const struct rimeaddr_s *destmac,
FAR struct iob_s *iob)
{ {
/* REVISIT: To be provided */ /* REVISIT: To be provided */
} }

View File

@ -114,8 +114,8 @@
* *
* Input Parmeters: * Input Parmeters:
* ieee - A reference to the IEE802.15.4 network device state * ieee - A reference to the IEE802.15.4 network device state
* ipv6 - The IPv6 header to be compressed * destip - The IPv6 header to be compressed
* destaddr - L2 destination address, needed to compress the IP * destmac - L2 destination address, needed to compress the IP
* destination field * destination field
* iob - The IOB into which the compressed header should be saved. * iob - The IOB into which the compressed header should be saved.
* *
@ -125,21 +125,21 @@
****************************************************************************/ ****************************************************************************/
void sixlowpan_compresshdr_hc1(FAR struct ieee802154_driver_s *ieee, void sixlowpan_compresshdr_hc1(FAR struct ieee802154_driver_s *ieee,
FAR const struct ipv6_hdr_s *ipv6, FAR const struct ipv6_hdr_s *destip,
FAR const struct rimeaddr_s *destaddr, FAR const struct rimeaddr_s *destmac,
FAR struct iob_s *iob) FAR struct iob_s *iob)
{ {
FAR uint8_t *hc1 = RIME_HC1_PTR; FAR uint8_t *hc1 = RIME_HC1_PTR;
/* Check if all the assumptions for full compression are valid */ /* Check if all the assumptions for full compression are valid */
if (ipv6->vtc != 0x60 || ipv6->tcflow != 0 || ipv6->flow != 0 || if (destip->vtc != 0x60 || destip->tcflow != 0 || destip->flow != 0 ||
!sixlowpan_islinklocal(&ipv6->srcipaddr) || !sixlowpan_islinklocal(&destip->srcipaddr) ||
!sixlowpan_ismacbased(&ipv6->srcipaddr, &ieee->i_rimeaddr) || !sixlowpan_ismacbased(&destip->srcipaddr, &ieee->i_rimeaddr) ||
!sixlowpan_islinklocal(&ipv6->destipaddr) || !sixlowpan_islinklocal(&destip->destipaddr) ||
!sixlowpan_ismacbased(&ipv6->destipaddr, destaddr) || !sixlowpan_ismacbased(&destip->destipaddr, destmac) ||
(ipv6->proto != IP_PROTO_ICMP6 && ipv6->proto != IP_PROTO_UDP && (destip->proto != IP_PROTO_ICMP6 && destip->proto != IP_PROTO_UDP &&
ipv6->proto != IP_PROTO_TCP)) destip->proto != IP_PROTO_TCP))
{ {
/* IPV6 DISPATCH /* IPV6 DISPATCH
* Something cannot be compressed, use IPV6 DISPATCH, * Something cannot be compressed, use IPV6 DISPATCH,
@ -148,7 +148,7 @@ void sixlowpan_compresshdr_hc1(FAR struct ieee802154_driver_s *ieee,
*g_rimeptr = SIXLOWPAN_DISPATCH_IPV6; *g_rimeptr = SIXLOWPAN_DISPATCH_IPV6;
g_rime_hdrlen += SIXLOWPAN_IPV6_HDR_LEN; g_rime_hdrlen += SIXLOWPAN_IPV6_HDR_LEN;
memcpy(g_rimeptr + g_rime_hdrlen, ipv6, IPv6_HDRLEN); memcpy(g_rimeptr + g_rime_hdrlen, destip, IPv6_HDRLEN);
g_rime_hdrlen += IPv6_HDRLEN; g_rime_hdrlen += IPv6_HDRLEN;
g_uncomp_hdrlen += IPv6_HDRLEN; g_uncomp_hdrlen += IPv6_HDRLEN;
} }
@ -161,13 +161,13 @@ void sixlowpan_compresshdr_hc1(FAR struct ieee802154_driver_s *ieee,
hc1[RIME_HC1_DISPATCH] = SIXLOWPAN_DISPATCH_HC1; hc1[RIME_HC1_DISPATCH] = SIXLOWPAN_DISPATCH_HC1;
g_uncomp_hdrlen += IPv6_HDRLEN; g_uncomp_hdrlen += IPv6_HDRLEN;
switch (ipv6->proto) switch (destip->proto)
{ {
case IP_PROTO_ICMP6: case IP_PROTO_ICMP6:
/* HC1 encoding and ttl */ /* HC1 encoding and ttl */
hc1[RIME_HC1_ENCODING] = 0xfc; hc1[RIME_HC1_ENCODING] = 0xfc;
hc1[RIME_HC1_TTL] = ipv6->ttl; hc1[RIME_HC1_TTL] = destip->ttl;
g_rime_hdrlen += SIXLOWPAN_HC1_HDR_LEN; g_rime_hdrlen += SIXLOWPAN_HC1_HDR_LEN;
break; break;
@ -176,7 +176,7 @@ void sixlowpan_compresshdr_hc1(FAR struct ieee802154_driver_s *ieee,
/* HC1 encoding and ttl */ /* HC1 encoding and ttl */
hc1[RIME_HC1_ENCODING] = 0xfe; hc1[RIME_HC1_ENCODING] = 0xfe;
hc1[RIME_HC1_TTL] = ipv6->ttl; hc1[RIME_HC1_TTL] = destip->ttl;
g_rime_hdrlen += SIXLOWPAN_HC1_HDR_LEN; g_rime_hdrlen += SIXLOWPAN_HC1_HDR_LEN;
break; break;
#endif /* CONFIG_NET_TCP */ #endif /* CONFIG_NET_TCP */
@ -206,7 +206,7 @@ void sixlowpan_compresshdr_hc1(FAR struct ieee802154_driver_s *ieee,
/* HC_UDP encoding, ttl, src and dest ports, checksum */ /* HC_UDP encoding, ttl, src and dest ports, checksum */
hcudp[RIME_HC1_HC_UDP_UDP_ENCODING] = 0xe0; hcudp[RIME_HC1_HC_UDP_UDP_ENCODING] = 0xe0;
hcudp[RIME_HC1_HC_UDP_TTL] = ipv6->ttl; hcudp[RIME_HC1_HC_UDP_TTL] = destip->ttl;
hcudp[RIME_HC1_HC_UDP_PORTS] = hcudp[RIME_HC1_HC_UDP_PORTS] =
(uint8_t)((htons(udp->srcport) - SIXLOWPAN_UDP_PORT_MIN) << 4) + (uint8_t)((htons(udp->srcport) - SIXLOWPAN_UDP_PORT_MIN) << 4) +
(uint8_t)((htons(udp->destport) - SIXLOWPAN_UDP_PORT_MIN)); (uint8_t)((htons(udp->destport) - SIXLOWPAN_UDP_PORT_MIN));
@ -221,7 +221,7 @@ void sixlowpan_compresshdr_hc1(FAR struct ieee802154_driver_s *ieee,
/* HC1 encoding and ttl */ /* HC1 encoding and ttl */
hc1[RIME_HC1_ENCODING] = 0xfa; hc1[RIME_HC1_ENCODING] = 0xfa;
hc1[RIME_HC1_TTL] = ipv6->ttl; hc1[RIME_HC1_TTL] = destip->ttl;
g_rime_hdrlen += SIXLOWPAN_HC1_HDR_LEN; g_rime_hdrlen += SIXLOWPAN_HC1_HDR_LEN;
} }
break; break;
@ -257,24 +257,24 @@ void sixlowpan_compresshdr_hc1(FAR struct ieee802154_driver_s *ieee,
int sixlowpan_uncompresshdr_hc1(FAR struct ieee802154_driver_s *ieee, int sixlowpan_uncompresshdr_hc1(FAR struct ieee802154_driver_s *ieee,
uint16_t iplen) uint16_t iplen)
{ {
FAR struct ipv6_hdr_s *ipv6 = IPv6BUF(&ieee->i_dev); FAR struct ipv6_hdr_s *destip = IPv6BUF(&ieee->i_dev);
FAR uint8_t *hc1 = RIME_HC1_PTR; FAR uint8_t *hc1 = RIME_HC1_PTR;
/* Format the IPv6 header in the device d_buf */ /* Format the IPv6 header in the device d_buf */
/* Set version, traffic clase, and flow label */ /* Set version, traffic clase, and flow label */
ipv6->vtc = 0x60; /* Bits 0-3: version, bits 4-7: traffic class (MS) */ destip->vtc = 0x60; /* Bits 0-3: version, bits 4-7: traffic class (MS) */
ipv6->tcf = 0; /* Bits 0-3: traffic class (LS), 4-bits: flow label (MS) */ destip->tcf = 0; /* Bits 0-3: traffic class (LS), 4-bits: flow label (MS) */
ipv6->flow = 0; /* 16-bit flow label (LS) */ destip->flow = 0; /* 16-bit flow label (LS) */
/* Use stateless auto-configuration to set source and destination IP /* Use stateless auto-configuration to set source and destination IP
* addresses. * addresses.
*/ */
sixlowpan_ipfromrime(&g_pktaddrs[PACKETBUF_ADDR_SENDER], sixlowpan_ipfromrime(&g_pktaddrs[PACKETBUF_ADDR_SENDER],
&ipv6->srcipaddr); &destip->srcipaddr);
sixlowpan_ipfromrime(&g_pktaddrs[PACKETBUF_ADDR_RECEIVER], sixlowpan_ipfromrime(&g_pktaddrs[PACKETBUF_ADDR_RECEIVER],
&ipv6->destipaddr); &destip->destipaddr);
g_uncomp_hdrlen += IPv6_HDRLEN; g_uncomp_hdrlen += IPv6_HDRLEN;
/* len[], proto, and ttl depend on the encoding */ /* len[], proto, and ttl depend on the encoding */
@ -282,15 +282,15 @@ int sixlowpan_uncompresshdr_hc1(FAR struct ieee802154_driver_s *ieee,
switch (hc1[RIME_HC1_ENCODING] & 0x06) switch (hc1[RIME_HC1_ENCODING] & 0x06)
{ {
case SIXLOWPAN_HC1_NH_ICMP6: case SIXLOWPAN_HC1_NH_ICMP6:
ipv6->proto = IP_PROTO_ICMP6; destip->proto = IP_PROTO_ICMP6;
ipv6->ttl = hc1[RIME_HC1_TTL]; destip->ttl = hc1[RIME_HC1_TTL];
g_rime_hdrlen += SIXLOWPAN_HC1_HDR_LEN; g_rime_hdrlen += SIXLOWPAN_HC1_HDR_LEN;
break; break;
#if CONFIG_NET_TCP #if CONFIG_NET_TCP
case SIXLOWPAN_HC1_NH_TCP: case SIXLOWPAN_HC1_NH_TCP:
ipv6->proto = IP_PROTO_TCP; destip->proto = IP_PROTO_TCP;
ipv6->ttl = hc1[RIME_HC1_TTL]; destip->ttl = hc1[RIME_HC1_TTL];
g_rime_hdrlen += SIXLOWPAN_HC1_HDR_LEN; g_rime_hdrlen += SIXLOWPAN_HC1_HDR_LEN;
break; break;
#endif /* CONFIG_NET_TCP */ #endif /* CONFIG_NET_TCP */
@ -301,7 +301,7 @@ int sixlowpan_uncompresshdr_hc1(FAR struct ieee802154_driver_s *ieee,
FAR struct udp_hdr_s *udp = UDPIPv6BUF(&ieee->i_dev); FAR struct udp_hdr_s *udp = UDPIPv6BUF(&ieee->i_dev);
FAR uint8_t *hcudp = RIME_HC1_HC_UDP_PTR; FAR uint8_t *hcudp = RIME_HC1_HC_UDP_PTR;
ipv6->proto = IP_PROTO_UDP; destip->proto = IP_PROTO_UDP;
if ((hcudp[RIME_HC1_HC_UDP_HC1_ENCODING] & 0x01) != 0) if ((hcudp[RIME_HC1_HC_UDP_HC1_ENCODING] & 0x01) != 0)
{ {
/* UDP header is compressed with HC_UDP */ /* UDP header is compressed with HC_UDP */
@ -315,7 +315,7 @@ int sixlowpan_uncompresshdr_hc1(FAR struct ieee802154_driver_s *ieee,
/* IP TTL */ /* IP TTL */
ipv6->ttl = hcudp[RIME_HC1_HC_UDP_TTL]; destip->ttl = hcudp[RIME_HC1_HC_UDP_TTL];
/* UDP ports, len, checksum */ /* UDP ports, len, checksum */
@ -347,25 +347,25 @@ int sixlowpan_uncompresshdr_hc1(FAR struct ieee802154_driver_s *ieee,
{ {
/* This is not a fragmented packet */ /* This is not a fragmented packet */
ipv6->len[0] = 0; destip->len[0] = 0;
ipv6->len[1] = ieee->i_dev.d_len - g_rime_hdrlen + /* REVISIT */ destip->len[1] = ieee->i_dev.d_len - g_rime_hdrlen + /* REVISIT */
g_uncomp_hdrlen - IPv6_HDRLEN; g_uncomp_hdrlen - IPv6_HDRLEN;
} }
else else
{ {
/* This is a 1st fragment */ /* This is a 1st fragment */
ipv6->len[0] = (iplen - IPv6_HDRLEN) >> 8; destip->len[0] = (iplen - IPv6_HDRLEN) >> 8;
ipv6->len[1] = (iplen - IPv6_HDRLEN) & 0x00FF; destip->len[1] = (iplen - IPv6_HDRLEN) & 0x00FF;
} }
/* length field in UDP header */ /* length field in UDP header */
#if CONFIG_NET_UDP #if CONFIG_NET_UDP
if (ipv6->proto == IP_PROTO_UDP) if (destip->proto == IP_PROTO_UDP)
{ {
FAR struct udp_hdr_s *udp = UDPIPv6BUF(&ieee->i_dev); FAR struct udp_hdr_s *udp = UDPIPv6BUF(&ieee->i_dev);
memcpy(&udp->udplen, &ipv6->len[0], 2); memcpy(&udp->udplen, &destip->len[0], 2);
} }
#endif #endif

View File

@ -416,7 +416,7 @@ struct iob_s; /* Forward reference */
* *
* Input Parameters: * Input Parameters:
* dev - The IEEE802.15.4 MAC network driver interface. * dev - The IEEE802.15.4 MAC network driver interface.
* ipv6 - IPv6 plus TCP or UDP headers. * destip - IPv6 plus TCP or UDP headers.
* buf - Data to send * buf - Data to send
* len - Length of data to send * len - Length of data to send
* raddr - The MAC address of the destination * raddr - The MAC address of the destination
@ -434,7 +434,7 @@ struct iob_s; /* Forward reference */
****************************************************************************/ ****************************************************************************/
int sixlowpan_send(FAR struct net_driver_s *dev, int sixlowpan_send(FAR struct net_driver_s *dev,
FAR const struct ipv6_hdr_s *ipv6, FAR const void *buf, FAR const struct ipv6_hdr_s *destip, FAR const void *buf,
size_t len, FAR const struct rimeaddr_s *raddr, size_t len, FAR const struct rimeaddr_s *raddr,
uint16_t timeout); uint16_t timeout);
@ -560,8 +560,8 @@ void sixlowpan_hc06_initialize(void);
* *
* Input Parameters: * Input Parameters:
* ieee - A reference to the IEE802.15.4 network device state * ieee - A reference to the IEE802.15.4 network device state
* ipv6 - The IPv6 header to be compressed * destip - The IPv6 header to be compressed
* destaddr - L2 destination address, needed to compress the IP * destmac - L2 destination address, needed to compress the IP
* destination field * destination field
* iob - The IOB into which the compressed header should be saved. * iob - The IOB into which the compressed header should be saved.
* *
@ -572,8 +572,8 @@ void sixlowpan_hc06_initialize(void);
#ifdef CONFIG_NET_6LOWPAN_COMPRESSION_HC06 #ifdef CONFIG_NET_6LOWPAN_COMPRESSION_HC06
void sixlowpan_compresshdr_hc06(FAR struct ieee802154_driver_s *ieee, void sixlowpan_compresshdr_hc06(FAR struct ieee802154_driver_s *ieee,
FAR const struct ipv6_hdr_s *ipv6, FAR const struct ipv6_hdr_s *destip,
FAR const struct rimeaddr_s *destaddr, FAR const struct rimeaddr_s *destmac,
FAR struct iob_s *iob); FAR struct iob_s *iob);
#endif #endif
@ -618,8 +618,8 @@ void sixlowpan_uncompresshdr_hc06(FAR struct ieee802154_driver_s *ieee,
* *
* Input Parmeters: * Input Parmeters:
* ieee - A reference to the IEE802.15.4 network device state * ieee - A reference to the IEE802.15.4 network device state
* ipv6 - The IPv6 header to be compressed * destip - The IPv6 header to be compressed
* destaddr - L2 destination address, needed to compress the IP * destmac - L2 destination address, needed to compress the IP
* destination field * destination field
* iob - The IOB into which the compressed header should be saved. * iob - The IOB into which the compressed header should be saved.
* *
@ -630,8 +630,8 @@ void sixlowpan_uncompresshdr_hc06(FAR struct ieee802154_driver_s *ieee,
#ifdef CONFIG_NET_6LOWPAN_COMPRESSION_HC1 #ifdef CONFIG_NET_6LOWPAN_COMPRESSION_HC1
void sixlowpan_compresshdr_hc1(FAR struct ieee802154_driver_s *ieee, void sixlowpan_compresshdr_hc1(FAR struct ieee802154_driver_s *ieee,
FAR const struct ipv6_hdr_s *ipv6, FAR const struct ipv6_hdr_s *destip,
FAR const struct rimeaddr_s *destaddr, FAR const struct rimeaddr_s *destmac,
FAR struct iob_s *iob); FAR struct iob_s *iob);
#endif #endif