Simplify NIIT configuration to boolean
[olsrd.git] / src / mid_set.h
index 6881771..3069e36 100644 (file)
@@ -1,75 +1,97 @@
+
 /*
- * OLSR ad-hoc routing table management protocol
- * Copyright (C) 2003 Andreas Tønnesen (andreto@ifi.uio.no)
+ * The olsr.org Optimized Link-State Routing daemon(olsrd)
+ * Copyright (c) 2004, Andreas Tonnesen(andreto@olsr.org)
+ * All rights reserved.
  *
- * This file is part of olsrd-unik.
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
  *
- * olsrd-unik 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.
+ * * Redistributions of source code must retain the above copyright
+ *   notice, this list of conditions and the following disclaimer.
+ * * Redistributions in binary form must reproduce the above copyright
+ *   notice, this list of conditions and the following disclaimer in
+ *   the documentation and/or other materials provided with the
+ *   distribution.
+ * * Neither the name of olsr.org, olsrd nor the names of its
+ *   contributors may be used to endorse or promote products derived
+ *   from this software without specific prior written permission.
  *
- * olsrd-unik 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.
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+ * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+ * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
+ * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
+ * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
+ * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
+ * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
+ * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
+ * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
+ * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
+ * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
+ * POSSIBILITY OF SUCH DAMAGE.
  *
- * You should have received a copy of the GNU General Public License
- * along with olsrd-unik; if not, write to the Free Software
- * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
+ * Visit http://www.olsr.org for more information.
+ *
+ * If you find this software useful feel free to make a donation
+ * to the project. For more information see the website or contact
+ * the copyright holders.
  *
  */
 
-/*
- *Andreas Tønnesen
- */
-
-
 #ifndef _OLSR_MID
 #define _OLSR_MID
 
+#include "olsr_types.h"
 #include "hashing.h"
+#include "mantissa.h"
+
+struct mid_address {
+  union olsr_ip_addr alias;
+  struct mid_entry *main_entry;
+  struct mid_address *next_alias;
+  uint32_t vtime;
+
+  /* These are for the reverse list */
+  struct mid_address *prev;
+  struct mid_address *next;
+};
 
 /*
- *Contains the main addr of a node and a list of aliases
+ * Contains the main addr of a node and a list of aliases
  */
-struct mid_entry
-{
+struct mid_entry {
   union olsr_ip_addr main_addr;
-  struct addresses *aliases;
+  struct mid_address *aliases;
   struct mid_entry *prev;
   struct mid_entry *next;
-  struct timeval ass_timer;  
+  struct timer_entry *mid_timer;
 };
 
+#define OLSR_MID_JITTER 5       /* percent */
 
-struct mid_entry mid_set[HASHSIZE];
-
-int
-olsr_init_mid_set();
+extern struct mid_entry mid_set[HASHSIZE];
+extern struct mid_address reverse_mid_set[HASHSIZE];
 
-void 
-insert_mid_tuple(union olsr_ip_addr *, struct addresses *, float);
+struct mid_alias;
 
-void
-insert_mid_alias(union olsr_ip_addr *, union olsr_ip_addr *, float);
-
-union olsr_ip_addr *
-mid_lookup_main_addr(union olsr_ip_addr *);
-
-struct addresses *
-mid_lookup_aliases(union olsr_ip_addr *);
-
-void
-olsr_print_mid_set();
-
-void
-olsr_time_out_mid_set();
-
-int
-olsr_update_mid_table(union olsr_ip_addr *, float);
-
-int
-mid_delete_node(struct mid_entry *);
+int olsr_init_mid_set(void);
+void olsr_delete_all_mid_entries(void);
+void olsr_cleanup_mid(union olsr_ip_addr *);
+void insert_mid_alias(union olsr_ip_addr *, const union olsr_ip_addr *, olsr_reltime);
+union olsr_ip_addr *mid_lookup_main_addr(const union olsr_ip_addr *);
+struct mid_address *mid_lookup_aliases(const union olsr_ip_addr *);
+struct mid_entry *mid_lookup_entry_bymain(const union olsr_ip_addr *);
+void olsr_print_mid_set(void);
+int olsr_update_mid_table(const union olsr_ip_addr *, olsr_reltime);
+void olsr_delete_mid_entry(struct mid_entry *);
+bool olsr_input_mid(union olsr_message *, struct interface *, union olsr_ip_addr *);
 
 #endif
+
+/*
+ * Local Variables:
+ * c-basic-offset: 2
+ * indent-tabs-mode: nil
+ * End:
+ */