956933f7ad8438d33164faa6670783192524f4d3
[olsrd.git] / src / mid_set.h
1 /*
2  * The olsr.org Optimized Link-State Routing daemon(olsrd)
3  * Copyright (c) 2004, Andreas T√łnnesen(andreto@olsr.org)
4  * All rights reserved.
5  *
6  * Redistribution and use in source and binary forms, with or without 
7  * modification, are permitted provided that the following conditions 
8  * are met:
9  *
10  * * Redistributions of source code must retain the above copyright 
11  *   notice, this list of conditions and the following disclaimer.
12  * * Redistributions in binary form must reproduce the above copyright 
13  *   notice, this list of conditions and the following disclaimer in 
14  *   the documentation and/or other materials provided with the 
15  *   distribution.
16  * * Neither the name of olsr.org, olsrd nor the names of its 
17  *   contributors may be used to endorse or promote products derived 
18  *   from this software without specific prior written permission.
19  *
20  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 
21  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 
22  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS 
23  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE 
24  * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, 
25  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, 
26  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; 
27  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER 
28  * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 
29  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN 
30  * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 
31  * POSSIBILITY OF SUCH DAMAGE.
32  *
33  * Visit http://www.olsr.org for more information.
34  *
35  * If you find this software useful feel free to make a donation
36  * to the project. For more information see the website or contact
37  * the copyright holders.
38  *
39  * $Id: mid_set.h,v 1.11 2005/02/19 17:43:28 kattemat Exp $
40  */
41
42
43
44 #ifndef _OLSR_MID
45 #define _OLSR_MID
46
47 #include "hashing.h"
48
49 struct mid_address
50 {
51   union olsr_ip_addr  alias;
52   struct mid_entry   *main_entry;
53
54   struct mid_address *next_alias;
55
56   /* These are for the reverse list */
57   struct mid_address *prev;
58   struct mid_address *next;
59 };
60
61 /*
62  *Contains the main addr of a node and a list of aliases
63  */
64 struct mid_entry
65 {
66   union olsr_ip_addr  main_addr;
67   struct mid_address *aliases;
68   struct mid_entry   *prev;
69   struct mid_entry   *next;
70   clock_t             ass_timer;  
71 };
72
73
74 #ifndef OLSR_PLUGIN
75
76 struct mid_entry mid_set[HASHSIZE];
77 struct mid_address reverse_mid_set[HASHSIZE];
78
79 int
80 olsr_init_mid_set(void);
81
82 void 
83 insert_mid_tuple(union olsr_ip_addr *, struct mid_address *, float);
84
85 void
86 insert_mid_alias(union olsr_ip_addr *, union olsr_ip_addr *, float);
87
88 union olsr_ip_addr *
89 mid_lookup_main_addr(union olsr_ip_addr *);
90
91 struct mid_address *
92 mid_lookup_aliases(union olsr_ip_addr *);
93
94 void
95 olsr_print_mid_set(void);
96
97 void
98 olsr_time_out_mid_set(void *);
99
100 int
101 olsr_update_mid_table(union olsr_ip_addr *, float);
102
103 int
104 mid_delete_node(struct mid_entry *);
105
106 #endif
107 #endif