2 * The olsr.org Optimized Link-State Routing daemon(olsrd)
3 * Copyright (c) 2004, Andreas Tønnesen(andreto@olsr.org)
6 * Redistribution and use in source and binary forms, with or without
7 * modification, are permitted provided that the following conditions
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
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.
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.
33 * Visit http://www.olsr.org for more information.
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.
45 #include "common/avl.h"
46 #include "olsr_types.h"
53 struct avl_node hna_tc_node; /* node in the per-tc hna tree */
54 struct olsr_ip_prefix hna_prefix; /* the prefix, key */
55 struct timer_entry *hna_net_timer; /* expiration timer */
56 struct tc_entry *hna_tc; /* backpointer to the owning tc entry */
59 AVLNODE2STRUCT(hna_tc_tree2hna, struct hna_net, hna_tc_node);
61 #define OLSR_HNA_NET_JITTER 5 /* percent */
63 #define OLSR_FOR_ALL_TC_HNA_ENTRIES(tc, hna_net) \
65 struct avl_node *hna_net_node, *next_hna_net_node; \
66 for (hna_net_node = avl_walk_first(&tc->hna_tree); \
67 hna_net_node; hna_net_node = next_hna_net_node) { \
68 next_hna_net_node = avl_walk_next(hna_net_node); \
69 hna_net = hna_tc_tree2hna(hna_net_node);
70 #define OLSR_FOR_ALL_TC_HNA_ENTRIES_END(tc, hna_net) }}
72 void olsr_init_hna_set(void);
73 void olsr_update_hna_entry(const union olsr_ip_addr *,
74 const union olsr_ip_addr *,
75 olsr_u8_t, olsr_reltime);
76 void olsr_print_hna_set(void);