-
Notifications
You must be signed in to change notification settings - Fork 46
/
seek_list.c
118 lines (99 loc) · 2.86 KB
/
seek_list.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
/*****************************************************************************
*
* Copyright (C) 2001 Uppsala University and Ericsson AB.
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*
* Authors: Erik Nordström, <[email protected]>
*
*
*****************************************************************************/
#include <stdlib.h>
#ifdef NS_PORT
#include "ns-2/aodv-uu.h"
#include "list.h"
#else
#include "seek_list.h"
#include "timer_queue.h"
#include "aodv_timeout.h"
#include "defs.h"
#include "params.h"
#include "debug.h"
#include "list.h"
#endif
#ifndef NS_PORT
/* The seek list is a linked list of destinations we are seeking
(with RREQ's). */
static LIST(seekhead);
#ifdef SEEK_LIST_DEBUG
void seek_list_print();
#endif
#endif /* NS_PORT */
seek_list_t *NS_CLASS seek_list_insert(struct in_addr dest_addr,
u_int32_t dest_seqno,
int ttl, u_int8_t flags,
struct ip_data *ipd)
{
seek_list_t *entry;
if ((entry = (seek_list_t *) malloc(sizeof(seek_list_t))) == NULL) {
fprintf(stderr, "Failed malloc\n");
exit(-1);
}
entry->dest_addr = dest_addr;
entry->dest_seqno = dest_seqno;
entry->flags = flags;
entry->reqs = 0;
entry->ttl = ttl;
entry->ipd = ipd;
timer_init(&entry->seek_timer, &NS_CLASS route_discovery_timeout, entry);
list_add(&seekhead, &entry->l);
#ifdef SEEK_LIST_DEBUG
seek_list_print();
#endif
return entry;
}
int NS_CLASS seek_list_remove(seek_list_t * entry)
{
if (!entry)
return 0;
list_detach(&entry->l);
/* Make sure any timers are removed */
timer_remove(&entry->seek_timer);
if (entry->ipd)
free(entry->ipd);
free(entry);
return 1;
}
seek_list_t *NS_CLASS seek_list_find(struct in_addr dest_addr)
{
list_t *pos;
list_foreach(pos, &seekhead) {
seek_list_t *entry = (seek_list_t *) pos;
if (entry->dest_addr.s_addr == dest_addr.s_addr)
return entry;
}
return NULL;
}
#ifdef SEEK_LIST_DEBUG
void NS_CLASS seek_list_print()
{
list_t *pos;
list_foreach(pos, &seekhead) {
seek_list_t *entry = (seek_list_t *) pos;
printf("%s %u %d %d\n", ip_to_str(entry->dest_addr),
entry->dest_seqno, entry->reqs, entry->ttl);
}
}
#endif