2006-01-02 21:04:38 +03:00
/*
* net / tipc / bcast . h : Include file for TIPC broadcast code
2007-02-09 17:25:21 +03:00
*
2006-01-11 20:40:41 +03:00
* Copyright ( c ) 2003 - 2006 , Ericsson AB
2011-01-18 21:53:16 +03:00
* Copyright ( c ) 2005 , 2010 - 2011 , Wind River Systems
2006-01-02 21:04:38 +03:00
* All rights reserved .
*
2006-01-11 15:30:43 +03:00
* Redistribution and use in source and binary forms , with or without
2006-01-02 21:04:38 +03:00
* modification , are permitted provided that the following conditions are met :
*
2006-01-11 15:30:43 +03: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 21:04:38 +03:00
*
2006-01-11 15:30:43 +03: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 21:04:38 +03:00
* POSSIBILITY OF SUCH DAMAGE .
*/
# ifndef _TIPC_BCAST_H
# define _TIPC_BCAST_H
# define MAX_NODES 4096
# define WSIZE 32
/**
2008-09-03 10:38:32 +04:00
* struct tipc_node_map - set of node identifiers
2006-01-02 21:04:38 +03:00
* @ count : # of nodes in set
* @ map : bitmap of node identifiers that are in the set
*/
2008-09-03 10:38:32 +04:00
struct tipc_node_map {
2006-01-02 21:04:38 +03:00
u32 count ;
u32 map [ MAX_NODES / WSIZE ] ;
} ;
# define PLSIZE 32
/**
2011-12-30 05:33:30 +04:00
* struct tipc_port_list - set of node local destination ports
2006-01-02 21:04:38 +03:00
* @ count : # of ports in set ( only valid for first entry in list )
* @ next : pointer to next entry in list
* @ ports : array of port references
*/
2011-12-30 05:33:30 +04:00
struct tipc_port_list {
2006-01-02 21:04:38 +03:00
int count ;
2011-12-30 05:33:30 +04:00
struct tipc_port_list * next ;
2006-01-02 21:04:38 +03:00
u32 ports [ PLSIZE ] ;
} ;
2008-09-03 10:38:32 +04:00
struct tipc_node ;
2006-01-02 21:04:38 +03:00
2009-03-19 05:11:29 +03:00
extern const char tipc_bclink_name [ ] ;
2006-01-02 21:04:38 +03:00
2010-05-11 18:30:14 +04:00
void tipc_nmap_add ( struct tipc_node_map * nm_ptr , u32 node ) ;
void tipc_nmap_remove ( struct tipc_node_map * nm_ptr , u32 node ) ;
2006-01-02 21:04:38 +03:00
/**
2010-05-11 18:30:12 +04:00
* tipc_nmap_equal - test for equality of node maps
2006-01-02 21:04:38 +03:00
*/
2008-09-03 10:38:32 +04:00
static inline int tipc_nmap_equal ( struct tipc_node_map * nm_a , struct tipc_node_map * nm_b )
2006-01-02 21:04:38 +03:00
{
return ! memcmp ( nm_a , nm_b , sizeof ( * nm_a ) ) ;
}
2011-12-30 05:33:30 +04:00
void tipc_port_list_add ( struct tipc_port_list * pl_ptr , u32 port ) ;
void tipc_port_list_free ( struct tipc_port_list * pl_ptr ) ;
2006-01-02 21:04:38 +03:00
2011-10-24 18:29:26 +04:00
void tipc_bclink_init ( void ) ;
2006-01-18 02:38:21 +03:00
void tipc_bclink_stop ( void ) ;
2011-10-24 19:18:12 +04:00
void tipc_bclink_add_node ( u32 addr ) ;
void tipc_bclink_remove_node ( u32 addr ) ;
2011-01-18 21:53:16 +03:00
struct tipc_node * tipc_bclink_retransmit_to ( void ) ;
2008-09-03 10:38:32 +04:00
void tipc_bclink_acknowledge ( struct tipc_node * n_ptr , u32 acked ) ;
2006-01-18 02:38:21 +03:00
int tipc_bclink_send_msg ( struct sk_buff * buf ) ;
void tipc_bclink_recv_pkt ( struct sk_buff * buf ) ;
u32 tipc_bclink_get_last_sent ( void ) ;
2008-09-03 10:38:32 +04:00
u32 tipc_bclink_acks_missing ( struct tipc_node * n_ptr ) ;
void tipc_bclink_check_gap ( struct tipc_node * n_ptr , u32 seqno ) ;
2006-01-18 02:38:21 +03:00
int tipc_bclink_stats ( char * stats_buf , const u32 buf_size ) ;
int tipc_bclink_reset_stats ( void ) ;
int tipc_bclink_set_queue_limits ( u32 limit ) ;
void tipc_bcbearer_sort ( void ) ;
2006-01-02 21:04:38 +03:00
# endif