3 * The olsr.org Optimized Link-State Routing daemon(olsrd)
4 * Copyright (c) 2004, Andreas Tonnesen(andreto@olsr.org)
7 * Redistribution and use in source and binary forms, with or without
8 * modification, are permitted provided that the following conditions
11 * * Redistributions of source code must retain the above copyright
12 * notice, this list of conditions and the following disclaimer.
13 * * Redistributions in binary form must reproduce the above copyright
14 * notice, this list of conditions and the following disclaimer in
15 * the documentation and/or other materials provided with the
17 * * Neither the name of olsr.org, olsrd nor the names of its
18 * contributors may be used to endorse or promote products derived
19 * from this software without specific prior written permission.
21 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
22 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
23 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
24 * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
25 * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
26 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
27 * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
28 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
29 * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
30 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
31 * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
32 * POSSIBILITY OF SUCH DAMAGE.
34 * Visit http://www.olsr.org for more information.
36 * If you find this software useful feel free to make a donation
37 * to the project. For more information see the website or contact
38 * the copyright holders.
45 #include "olsr_types.h"
50 union olsr_ip_addr alias;
51 struct mid_entry *main_entry;
52 struct mid_address *next_alias;
55 /* These are for the reverse list */
56 struct mid_address *prev;
57 struct mid_address *next;
61 * Contains the main addr of a node and a list of aliases
64 union olsr_ip_addr main_addr;
65 struct mid_address *aliases;
66 struct mid_entry *prev;
67 struct mid_entry *next;
68 struct timer_entry *mid_timer;
71 #define OLSR_MID_JITTER 5 /* percent */
73 extern struct mid_entry mid_set[HASHSIZE];
74 extern struct mid_address reverse_mid_set[HASHSIZE];
78 int olsr_init_mid_set(void);
79 void olsr_delete_all_mid_entries(void);
80 void insert_mid_alias(union olsr_ip_addr *, const union olsr_ip_addr *, olsr_reltime);
81 union olsr_ip_addr *mid_lookup_main_addr(const union olsr_ip_addr *);
82 struct mid_address *mid_lookup_aliases(const union olsr_ip_addr *);
83 struct mid_entry *mid_lookup_entry_bymain(const union olsr_ip_addr *);
84 void olsr_print_mid_set(void);
85 int olsr_update_mid_table(const union olsr_ip_addr *, olsr_reltime);
86 void olsr_delete_mid_entry(struct mid_entry *);
87 bool olsr_input_mid(union olsr_message *, struct interface *, union olsr_ip_addr *);
94 * indent-tabs-mode: nil