+
/*
* The olsr.org Optimized Link-State Routing daemon(olsrd)
- * Copyright (c) 2004, Andreas TΓΈnnesen(andreto@olsr.org)
+ * Copyright (c) 2004, Andreas Tonnesen(andreto@olsr.org)
* All rights reserved.
*
- * Redistribution and use in source and binary forms, with or without
- * modification, are permitted provided that the following conditions
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
* are met:
*
- * * Redistributions of source code must retain the above copyright
+ * * 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
+ * * 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
+ * * 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.
*
- * 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
+ * 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.
*
* Visit http://www.olsr.org for more information.
* to the project. For more information see the website or contact
* the copyright holders.
*
- * $Id: olsr.h,v 1.16 2005/01/17 17:19:55 tlopatic Exp $
*/
-
#ifndef _OLSR_FUNCTIONS
#define _OLSR_FUNCTIONS
#include "olsr_protocol.h"
#include "interfaces.h"
-#include <sys/time.h>
-
-/**
- * Process changes functions
- */
-
-struct pcf
-{
- int (*function)(int, int, int);
- struct pcf *next;
-};
-
-struct pcf *pcf_list;
+extern bool changes_topology;
+extern bool changes_neighborhood;
+extern bool changes_hna;
+extern bool changes_force;
+extern union olsr_ip_addr all_zero;
-olsr_bool changes_topology;
-olsr_bool changes_neighborhood;
-olsr_bool changes_hna;
+void olsr_startup_sleep(int);
+void olsr_do_startup_sleep(void);
-olsr_u16_t message_seqno;
+void register_pcf(int (*)(int, int, int));
-/* Provides a timestamp s1 milliseconds in the future
- according to system ticks returned by times(2) */
-#define GET_TIMESTAMP(s1) \
- now_times + ((s1) / system_tick_divider)
+void olsr_process_changes(void);
-#define TIMED_OUT(s1) \
- ((s1) - now_times < 0)
+void init_msg_seqno(void);
+uint16_t get_msg_seqno(void);
-/*
- * Queueing macros
- */
+bool olsr_is_bad_duplicate_msg_seqno(uint16_t seqno);
-/* First "argument" is NOT a pointer! */
+int olsr_forward_message(union olsr_message *, struct interface *, union olsr_ip_addr *);
-#define QUEUE_ELEM(pre, new) \
- pre.next->prev = new; \
- new->next = pre.next; \
- new->prev = ⪯ \
- pre.next = new
+void set_buffer_timer(struct interface *);
-#define DEQUEUE_ELEM(elem) \
- elem->prev->next = elem->next; \
- elem->next->prev = elem->prev
+void olsr_init_tables(void);
+void olsr_init_willingness(void);
-void
-register_pcf(int (*)(int, int, int));
+void olsr_update_willingness(void *);
-void
-olsr_process_changes(void);
+uint8_t olsr_calculate_willingness(void);
-inline void
-olsr_init_timer(olsr_u32_t, struct timeval *);
+const char *olsr_msgtype_to_string(uint8_t);
-inline void
-olsr_get_timestamp(olsr_u32_t, struct timeval *);
+const char *olsr_link_to_string(uint8_t);
-void
-init_msg_seqno(void);
+const char *olsr_status_to_string(uint8_t);
-inline olsr_u16_t
-get_msg_seqno(void);
+void olsr_exit(const char *, int) __attribute__((noreturn));
-int
-olsr_forward_message(union olsr_message *,
- union olsr_ip_addr *,
- olsr_u16_t,
- struct interface *,
- union olsr_ip_addr *);
+void *olsr_malloc(size_t, const char *);
-void
-set_buffer_timer(struct interface *);
+int olsr_printf(int, const char *, ...) __attribute__ ((format(printf, 2, 3)));
-void
-olsr_init_tables(void);
+void olsr_trigger_forced_update(void *);
-void
-olsr_init_willingness(void);
+#endif /* _OLSR_FUNCTIONS */
-void
-olsr_update_willingness(void *);
-
-olsr_u8_t
-olsr_calculate_willingness(void);
-
-void
-olsr_exit(const char *, int);
-
-void *
-olsr_malloc(size_t, const char *);
-
-inline int
-olsr_printf(int, char *, ...);
-
-#endif
+/*
+ * Local Variables:
+ * c-basic-offset: 2
+ * indent-tabs-mode: nil
+ * End:
+ */