-
Notifications
You must be signed in to change notification settings - Fork 46
/
routing_table.h
116 lines (97 loc) · 3.85 KB
/
routing_table.h
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
/*****************************************************************************
*
* Copyright (C) 2001 Uppsala University & 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]>
*
*
*****************************************************************************/
#ifndef _ROUTING_TABLE_H
#define _ROUTING_TABLE_H
#ifndef NS_NO_GLOBALS
#include "defs.h"
#include "list.h"
typedef struct rt_table rt_table_t;
/* Neighbor struct for active routes in Route Table */
typedef struct precursor {
list_t l;
struct in_addr neighbor;
} precursor_t;
#define FIRST_PREC(h) ((precursor_t *)((h).next))
#define seqno_incr(s) ((s == 0) ? 0 : ((s == 0xFFFFFFFF) ? s = 1 : s++))
typedef u_int32_t hash_value; /* A hash value */
/* Route table entries */
struct rt_table {
list_t l;
struct in_addr dest_addr; /* IP address of the destination */
u_int32_t dest_seqno;
unsigned int ifindex; /* Network interface index... */
struct in_addr next_hop; /* IP address of the next hop to the dest */
u_int8_t hcnt; /* Distance (in hops) to the destination */
u_int16_t flags; /* Routing flags */
u_int8_t state; /* The state of this entry */
struct timer rt_timer; /* The timer associated with this entry */
struct timer ack_timer; /* RREP_ack timer for this destination */
struct timer hello_timer;
struct timeval last_hello_time;
u_int8_t hello_cnt;
hash_value hash;
int nprec; /* Number of precursors */
list_t precursors; /* List of neighbors using the route */
};
/* Route entry flags */
#define RT_UNIDIR 0x1
#define RT_REPAIR 0x2
#define RT_INV_SEQNO 0x4
#define RT_INET_DEST 0x8 /* Mark for Internet destinations (to be relayed
* through a Internet gateway. */
#define RT_GATEWAY 0x10
/* Route entry states */
#define INVALID 0
#define VALID 1
#define RT_TABLESIZE 64 /* Must be a power of 2 */
#define RT_TABLEMASK (RT_TABLESIZE - 1)
struct routing_table {
unsigned int num_entries;
unsigned int num_active;
list_t tbl[RT_TABLESIZE];
};
void precursor_list_destroy(rt_table_t * rt);
#endif /* NS_NO_GLOBALS */
#ifndef NS_NO_DECLARATIONS
struct routing_table rt_tbl;
void rt_table_init();
void rt_table_destroy();
rt_table_t *rt_table_insert(struct in_addr dest, struct in_addr next,
u_int8_t hops, u_int32_t seqno, u_int32_t life,
u_int8_t state, u_int16_t flags,
unsigned int ifindex);
rt_table_t *rt_table_update(rt_table_t * rt, struct in_addr next, u_int8_t hops,
u_int32_t seqno, u_int32_t lifetime, u_int8_t state,
u_int16_t flags);
NS_INLINE rt_table_t *rt_table_update_timeout(rt_table_t * rt,
u_int32_t lifetime);
void rt_table_update_route_timeouts(rt_table_t * fwd_rt, rt_table_t * rev_rt);
rt_table_t *rt_table_find(struct in_addr dest);
rt_table_t *rt_table_find_gateway();
int rt_table_update_inet_rt(rt_table_t * gw, u_int32_t life);
int rt_table_invalidate(rt_table_t * rt);
void rt_table_delete(rt_table_t * rt);
void precursor_add(rt_table_t * rt, struct in_addr addr);
void precursor_remove(rt_table_t * rt, struct in_addr addr);
#endif /* NS_NO_DECLARATIONS */
#endif /* ROUTING_TABLE_H */