2006-01-02 19:04:38 +01:00
/*
* net / tipc / node . h : Include file for TIPC node management routines
2007-02-09 23:25:21 +09:00
*
2006-01-11 19:14:19 +01:00
* Copyright ( c ) 2000 - 2006 , Ericsson AB
2011-02-25 18:42:52 -05:00
* Copyright ( c ) 2005 , 2010 - 2011 , Wind River Systems
2006-01-02 19:04:38 +01:00
* All rights reserved .
*
2006-01-11 13:30:43 +01:00
* Redistribution and use in source and binary forms , with or without
2006-01-02 19:04:38 +01:00
* modification , are permitted provided that the following conditions are met :
*
2006-01-11 13:30:43 +01:00
* 1. Redistributions of source code must retain the above copyright
* notice , this list of conditions and the following disclaimer .
* 2. 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 .
* 3. Neither the names of the copyright holders nor the names of its
* contributors may be used to endorse or promote products derived from
* this software without specific prior written permission .
2006-01-02 19:04:38 +01:00
*
2006-01-11 13:30:43 +01:00
* Alternatively , this software may be distributed under the terms of the
* GNU General Public License ( " GPL " ) version 2 as published by the Free
* Software Foundation .
*
* 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
2006-01-02 19:04:38 +01:00
* POSSIBILITY OF SUCH DAMAGE .
*/
# ifndef _TIPC_NODE_H
# define _TIPC_NODE_H
# include "node_subscr.h"
2010-12-31 18:59:19 +00:00
# include "addr.h"
# include "net.h"
2006-01-02 19:04:38 +01:00
# include "bearer.h"
/**
2008-09-02 23:38:32 -07:00
* struct tipc_node - TIPC node structure
2006-01-02 19:04:38 +01:00
* @ addr : network address of node
* @ lock : spinlock governing access to structure
2011-02-25 18:42:52 -05:00
* @ hash : links to adjacent nodes in unsorted hash chain
* @ list : links to adjacent nodes in sorted list of cluster ' s nodes
2006-01-02 19:04:38 +01:00
* @ nsub : list of " node down " subscriptions monitoring node
* @ active_links : pointers to active links to node
* @ links : pointers to all links to node
2006-06-25 23:52:50 -07:00
* @ working_links : number of working links to node ( both active and standby )
2010-08-17 11:00:16 +00:00
* @ cleanup_required : non - zero if cleaning up after a prior loss of contact
2006-01-02 19:04:38 +01:00
* @ link_cnt : number of links to node
* @ permit_changeover : non - zero if node has redundant links to this system
* @ bclink : broadcast - related info
* @ supported : non - zero if node supports TIPC b ' cast capability
* @ acked : sequence # of last outbound b ' cast message acknowledged by node
* @ last_in : sequence # of last in - sequence b ' cast message received from node
* @ gap_after : sequence # of last message not requiring a NAK request
* @ gap_to : sequence # of last message requiring a NAK request
* @ nack_sync : counter that determines when NAK requests should be sent
* @ deferred_head : oldest OOS b ' cast message received from node
* @ deferred_tail : newest OOS b ' cast message received from node
* @ defragm : list of partially reassembled b ' cast message fragments from node
*/
2007-02-09 23:25:21 +09:00
2008-09-02 23:38:32 -07:00
struct tipc_node {
2006-01-02 19:04:38 +01:00
u32 addr ;
spinlock_t lock ;
2011-02-25 18:42:52 -05:00
struct hlist_node hash ;
struct list_head list ;
2006-01-02 19:04:38 +01:00
struct list_head nsub ;
struct link * active_links [ 2 ] ;
struct link * links [ MAX_BEARERS ] ;
int link_cnt ;
2006-06-25 23:52:50 -07:00
int working_links ;
2010-08-17 11:00:16 +00:00
int cleanup_required ;
2006-01-02 19:04:38 +01:00
int permit_changeover ;
struct {
int supported ;
u32 acked ;
u32 last_in ;
2007-02-09 23:25:21 +09:00
u32 gap_after ;
u32 gap_to ;
2006-01-02 19:04:38 +01:00
u32 nack_sync ;
struct sk_buff * deferred_head ;
struct sk_buff * deferred_tail ;
struct sk_buff * defragm ;
} bclink ;
} ;
2011-02-25 18:42:52 -05:00
# define NODE_HTABLE_SIZE 512
extern struct list_head tipc_node_list ;
/*
* A trivial power - of - two bitmask technique is used for speed , since this
* operation is done for every incoming TIPC packet . The number of hash table
* entries has been chosen so that no hash chain exceeds 8 nodes and will
* usually be much smaller ( typically only a single node ) .
*/
static inline unsigned int tipc_hashfn ( u32 addr )
{
return addr & ( NODE_HTABLE_SIZE - 1 ) ;
}
2006-01-02 19:04:38 +01:00
extern u32 tipc_own_tag ;
2011-02-25 18:42:52 -05:00
struct tipc_node * tipc_node_find ( u32 addr ) ;
2008-09-02 23:38:32 -07:00
struct tipc_node * tipc_node_create ( u32 addr ) ;
void tipc_node_delete ( struct tipc_node * n_ptr ) ;
2011-02-28 11:32:27 -05:00
void tipc_node_attach_link ( struct tipc_node * n_ptr , struct link * l_ptr ) ;
2008-09-02 23:38:32 -07:00
void tipc_node_detach_link ( struct tipc_node * n_ptr , struct link * l_ptr ) ;
void tipc_node_link_down ( struct tipc_node * n_ptr , struct link * l_ptr ) ;
void tipc_node_link_up ( struct tipc_node * n_ptr , struct link * l_ptr ) ;
2011-02-28 11:36:21 -04:00
int tipc_node_active_links ( struct tipc_node * n_ptr ) ;
int tipc_node_redundant_links ( struct tipc_node * n_ptr ) ;
2008-09-02 23:38:32 -07:00
int tipc_node_is_up ( struct tipc_node * n_ptr ) ;
2006-01-18 00:38:21 +01:00
struct sk_buff * tipc_node_get_links ( const void * req_tlv_area , int req_tlv_space ) ;
struct sk_buff * tipc_node_get_nodes ( const void * req_tlv_area , int req_tlv_space ) ;
2006-01-02 19:04:38 +01:00
2008-09-02 23:38:32 -07:00
static inline void tipc_node_lock ( struct tipc_node * n_ptr )
2006-01-02 19:04:38 +01:00
{
spin_lock_bh ( & n_ptr - > lock ) ;
}
2008-09-02 23:38:32 -07:00
static inline void tipc_node_unlock ( struct tipc_node * n_ptr )
2006-01-02 19:04:38 +01:00
{
spin_unlock_bh ( & n_ptr - > lock ) ;
}
# endif