Don't call sink recv function for zero-size packets, since these most likely are link estimate probes or keepalive packets. Explicitly set eseqno to zero when opening a new connection.

This commit is contained in:
adamdunkels 2010-10-07 15:52:28 +00:00
parent f78fd63fd7
commit 0cabe483c3

View file

@ -33,7 +33,7 @@
* *
* This file is part of the Contiki operating system. * This file is part of the Contiki operating system.
* *
* $Id: collect.c,v 1.58 2010/10/05 20:06:47 adamdunkels Exp $ * $Id: collect.c,v 1.59 2010/10/07 15:52:28 adamdunkels Exp $
*/ */
/** /**
@ -919,7 +919,7 @@ node_packet_received(struct unicast_conn *c, const rimeaddr_t *from)
packetbuf_hdrreduce(sizeof(struct data_msg_hdr)); packetbuf_hdrreduce(sizeof(struct data_msg_hdr));
/* Call receive function. */ /* Call receive function. */
if(tc->cb->recv != NULL) { if(packetbuf_datalen() > 0 && tc->cb->recv != NULL) {
tc->cb->recv(packetbuf_addr(PACKETBUF_ADDR_ESENDER), tc->cb->recv(packetbuf_addr(PACKETBUF_ADDR_ESENDER),
packetbuf_attr(PACKETBUF_ATTR_EPACKET_ID), packetbuf_attr(PACKETBUF_ATTR_EPACKET_ID),
packetbuf_attr(PACKETBUF_ATTR_HOPS)); packetbuf_attr(PACKETBUF_ATTR_HOPS));
@ -1177,6 +1177,7 @@ collect_open(struct collect_conn *tc, uint16_t channels,
tc->cb = cb; tc->cb = cb;
tc->is_router = is_router; tc->is_router = is_router;
tc->seqno = 10; tc->seqno = 10;
tc->eseqno = 0;
LIST_STRUCT_INIT(tc, send_queue_list); LIST_STRUCT_INIT(tc, send_queue_list);
collect_neighbor_list_new(&tc->neighbor_list); collect_neighbor_list_new(&tc->neighbor_list);
tc->send_queue.list = &(tc->send_queue_list); tc->send_queue.list = &(tc->send_queue_list);