Packet queues fixed. They caused the trouble when resending keys.

This commit is contained in:
Guus Sliepen 2000-04-25 20:10:37 +00:00
parent 04db888b1a
commit 5b72422857
2 changed files with 57 additions and 22 deletions

View file

@ -152,7 +152,7 @@ cp
*/
void add_queue(packet_queue_t **q, void *packet, size_t s)
{
queue_element_t *e, *p;
queue_element_t *e;
cp
if(debug_lvl > 3)
syslog(LOG_DEBUG, "packet to queue: %d", s);
@ -160,21 +160,65 @@ cp
e = xmalloc(sizeof(queue_element_t));
e->packet = xmalloc(s);
memcpy(e->packet, packet, s);
if(!*q)
{
*q = xmalloc(sizeof(packet_queue_t));
(*q)->head = (*q)->tail = NULL;
}
e->next = NULL;
e->next = NULL; /* We insert at the tail */
if((*q)->tail != NULL)
if((*q)->tail) /* Do we have a tail? */
{
(*q)->tail->next = e;
e->prev = (*q)->tail;
}
else /* No tail -> no head too */
{
(*q)->head = e;
e->prev = NULL;
}
(*q)->tail = e;
cp
}
if((*q)->head == NULL)
(*q)->head = e;
/* Remove a queue element */
void del_queue(packet_queue_t **q, packet_element_t *e)
{
queue_element_t *p, *n;
cp
free(e->packet);
if(e->next) /* There is a successor, so we are not tail */
{
if(e->prev) /* There is a predecessor, so we are not head */
{
e->next->prev = e->prev;
e->prev->next = e->next;
}
else /* We are head */
{
e->next->prev = NULL;
(*q)->head = e->next;
}
}
else /* We are tail (or all alone!) */
{
if(e->prev) /* We are not alone :) */
{
e->prev->next = NULL;
(*q)->tail = e->prev;
}
else /* Adieu */
{
free(*q);
*q = NULL;
}
}
free(e);
cp
}
@ -183,27 +227,17 @@ cp
each packet, and removing it when that
returned a zero exit code
*/
void flush_queue(conn_list_t *cl, packet_queue_t *pq,
void flush_queue(conn_list_t *cl, packet_queue_t **pq,
int (*function)(conn_list_t*,void*))
{
queue_element_t *p, *prev = NULL, *next = NULL;
cp
for(p = pq->head; p != NULL; )
for(p = (*pq)->head; p != NULL; )
{
next = p->next;
if(!function(cl, p->packet))
{
if(prev)
prev->next = next;
else
pq->head = next;
free(p->packet);
free(p);
}
else
prev = p;
del_queue(pq, p);
p = next;
}
@ -226,7 +260,7 @@ cp
if(debug_lvl > 1)
syslog(LOG_DEBUG, "Flushing send queue for " IP_ADDR_S,
IP_ADDR_V(cl->vpn_ip));
flush_queue(cl, cl->sq, xsend);
flush_queue(cl, &(cl->sq), xsend);
}
if(cl->rq)
@ -234,7 +268,7 @@ cp
if(debug_lvl > 1)
syslog(LOG_DEBUG, "Flushing receive queue for " IP_ADDR_S,
IP_ADDR_V(cl->vpn_ip));
flush_queue(cl, cl->rq, xrecv);
flush_queue(cl, &(cl->rq), xrecv);
}
cp
}

View file

@ -83,6 +83,7 @@ typedef struct status_bits_t {
typedef struct queue_element_t {
void *packet;
struct queue_element_t *prev;
struct queue_element_t *next;
} queue_element_t;