📄 neighbor_table.h
字号:
/* * The olsr.org Optimized Link-State Routing daemon(olsrd) * Copyright (c) 2004, Andreas T鴑nesen(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 * are met: * * * 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. * * 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. * * 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. * * $Id: neighbor_table.h,v 1.15 2007/08/02 21:57:06 bernd67 Exp $ */#ifndef _OLSR_NEIGH_TBL#define _OLSR_NEIGH_TBL#include "olsr_types.h"#include "hashing.h"struct neighbor_2_list_entry { struct neighbor_2_entry *neighbor_2; clock_t neighbor_2_timer; struct neighbor_2_list_entry *next; struct neighbor_2_list_entry *prev;};struct neighbor_entry{ union olsr_ip_addr neighbor_main_addr; olsr_u8_t status; olsr_u8_t willingness; olsr_bool is_mpr; olsr_bool was_mpr; /* Used to detect changes in MPR */ olsr_bool skip; int neighbor_2_nocov; int linkcount; struct neighbor_2_list_entry neighbor_2_list; struct neighbor_entry *next; struct neighbor_entry *prev;};/* * The neighbor table */extern struct neighbor_entry neighbortable[HASHSIZE];voidolsr_init_neighbor_table(void);intolsr_delete_neighbor_2_pointer(struct neighbor_entry *, union olsr_ip_addr *);struct neighbor_2_list_entry *olsr_lookup_my_neighbors(const struct neighbor_entry *, const union olsr_ip_addr *);intolsr_delete_neighbor_table(const union olsr_ip_addr *);struct neighbor_entry *olsr_insert_neighbor_table(const union olsr_ip_addr *);struct neighbor_entry *olsr_lookup_neighbor_table(const union olsr_ip_addr *);struct neighbor_entry *olsr_lookup_neighbor_table_alias(const union olsr_ip_addr *);voidolsr_time_out_two_hop_neighbors(struct neighbor_entry *);voidolsr_time_out_neighborhood_tables(void);voidolsr_print_neighbor_table(void);intupdate_neighbor_status(struct neighbor_entry *, int);#endif
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -