2010-12-13 14:19:28 +03:00
/*
2012-01-01 03:41:38 +04:00
* Copyright ( C ) 2007 - 2012 B . A . T . M . A . N . contributors :
2010-12-13 14:19:28 +03:00
*
* Marek Lindner , Simon Wunderlich
*
* This program is free software ; you can redistribute it and / or
* modify it under the terms of version 2 of the GNU General Public
* License as published by the Free Software Foundation .
*
* This program 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 .
*
* You should have received a copy of the GNU General Public License
* along with this program ; if not , write to the Free Software
* Foundation , Inc . , 51 Franklin Street , Fifth Floor , Boston , MA
* 02110 - 1301 , USA
*
*/
# ifndef _NET_BATMAN_ADV_MAIN_H_
# define _NET_BATMAN_ADV_MAIN_H_
# define DRIVER_AUTHOR "Marek Lindner <lindner_marek@yahoo.de>, " \
" Simon Wunderlich <siwu@hrz.tu-chemnitz.de> "
# define DRIVER_DESC "B.A.T.M.A.N. advanced"
# define DRIVER_DEVICE "batman-adv"
2011-07-05 12:42:51 +04:00
# ifndef SOURCE_VERSION
2012-06-17 15:26:37 +04:00
# define SOURCE_VERSION "2012.3.0"
2011-07-05 12:42:51 +04:00
# endif
2010-12-13 14:19:28 +03:00
/* B.A.T.M.A.N. parameters */
# define TQ_MAX_VALUE 255
# define JITTER 20
2011-05-08 14:45:45 +04:00
/* Time To Live of broadcast messages */
# define TTL 50
/* purge originators after time in seconds if no valid packet comes in
* - > TODO : check influence on TQ_LOCAL_WINDOW_SIZE */
2011-12-20 15:30:40 +04:00
# define PURGE_TIMEOUT 200000 /* 200 seconds */
# define TT_LOCAL_TIMEOUT 3600000 /* in miliseconds */
# define TT_CLIENT_ROAM_TIMEOUT 600000 /* in miliseconds */
2011-07-09 19:52:13 +04:00
/* sliding packet range of received originator messages in sequence numbers
2011-05-08 14:45:45 +04:00
* ( should be a multiple of our word size ) */
# define TQ_LOCAL_WINDOW_SIZE 64
2011-12-20 15:30:40 +04:00
# define TT_REQUEST_TIMEOUT 3000 / * miliseconds we have to keep
* pending tt_req */
2011-04-27 16:27:44 +04:00
2010-12-13 14:19:28 +03:00
# define TQ_GLOBAL_WINDOW_SIZE 5
# define TQ_LOCAL_BIDRECT_SEND_MINIMUM 1
# define TQ_LOCAL_BIDRECT_RECV_MINIMUM 1
# define TQ_TOTAL_BIDRECT_LIMIT 1
2011-04-27 16:27:44 +04:00
# define TT_OGM_APPEND_MAX 3 /* number of OGMs sent with the last tt diff */
2011-12-20 15:30:40 +04:00
# define ROAMING_MAX_TIME 20000 / * Time in which a client can roam at most
* ROAMING_MAX_COUNT times in miliseconds */
2011-04-27 16:27:57 +04:00
# define ROAMING_MAX_COUNT 5
2011-06-09 19:13:09 +04:00
# define NO_FLAGS 0
2011-07-07 17:35:35 +04:00
# define NULL_IFINDEX 0 /* dummy ifindex used to avoid iface checks */
2012-02-04 20:34:52 +04:00
# define NUM_WORDS BITS_TO_LONGS(TQ_LOCAL_WINDOW_SIZE)
2010-12-13 14:19:28 +03:00
# define LOG_BUF_LEN 8192 /* has to be a power of 2 */
# define VIS_INTERVAL 5000 /* 5 seconds */
2011-05-08 14:45:45 +04:00
/* how much worse secondary interfaces may be to be considered as bonding
* candidates */
2010-12-13 14:19:28 +03:00
# define BONDING_TQ_THRESHOLD 50
2011-05-08 14:45:45 +04:00
/* should not be bigger than 512 bytes or change the size of
* forw_packet - > direct_link_flags */
# define MAX_AGGREGATION_BYTES 512
2010-12-13 14:19:28 +03:00
# define MAX_AGGREGATION_MS 100
2012-01-22 23:00:19 +04:00
# define BLA_PERIOD_LENGTH 10000 /* 10 seconds */
# define BLA_BACKBONE_TIMEOUT (BLA_PERIOD_LENGTH * 3)
# define BLA_CLAIM_TIMEOUT (BLA_PERIOD_LENGTH * 10)
2012-01-22 23:00:24 +04:00
# define DUPLIST_SIZE 16
# define DUPLIST_TIMEOUT 500 /* 500 ms */
2011-05-08 14:45:45 +04:00
/* don't reset again within 30 seconds */
2010-12-13 14:19:28 +03:00
# define RESET_PROTECTION_MS 30000
# define EXPECTED_SEQNO_RANGE 65536
2011-06-04 13:26:00 +04:00
enum mesh_state {
MESH_INACTIVE ,
MESH_ACTIVE ,
MESH_DEACTIVATING
} ;
2010-12-13 14:19:28 +03:00
# define BCAST_QUEUE_LEN 256
# define BATMAN_QUEUE_LEN 256
2011-04-26 20:26:01 +04:00
enum uev_action {
UEV_ADD = 0 ,
UEV_DEL ,
UEV_CHANGE
} ;
enum uev_type {
UEV_GW = 0
} ;
2011-04-26 23:31:45 +04:00
# define GW_THRESHOLD 50
2012-03-07 12:07:46 +04:00
/* Debug Messages */
2010-12-13 14:19:28 +03:00
# ifdef pr_fmt
# undef pr_fmt
# endif
2011-05-08 14:45:45 +04:00
/* Append 'batman-adv: ' before kernel messages */
# define pr_fmt(fmt) KBUILD_MODNAME ": " fmt
2010-12-13 14:19:28 +03:00
2011-05-08 14:45:45 +04:00
/* all messages related to routing / flooding / broadcasting / etc */
2011-06-04 13:26:00 +04:00
enum dbg_level {
DBG_BATMAN = 1 < < 0 ,
DBG_ROUTES = 1 < < 1 , /* route added / changed / deleted */
2011-04-27 16:27:44 +04:00
DBG_TT = 1 < < 2 , /* translation table operations */
2012-01-22 23:00:19 +04:00
DBG_BLA = 1 < < 3 , /* bridge loop avoidance */
DBG_ALL = 15
2011-06-04 13:26:00 +04:00
} ;
2010-12-13 14:19:28 +03:00
2012-03-07 12:07:46 +04:00
/* Kernel headers */
2010-12-13 14:19:28 +03:00
# include <linux/mutex.h> /* mutex */
# include <linux/module.h> /* needed by all modules */
# include <linux/netdevice.h> /* netdevice */
2011-07-09 19:52:13 +04:00
# include <linux/etherdevice.h> /* ethernet address classification */
2010-12-13 14:19:28 +03:00
# include <linux/if_ether.h> /* ethernet header */
# include <linux/poll.h> /* poll_table */
# include <linux/kthread.h> /* kernel threads */
# include <linux/pkt_sched.h> /* schedule types */
# include <linux/workqueue.h> /* workqueue */
2012-04-20 19:02:45 +04:00
# include <linux/percpu.h>
2010-12-13 14:19:28 +03:00
# include <linux/slab.h>
# include <net/sock.h> /* struct sock */
# include <linux/jiffies.h>
# include <linux/seq_file.h>
# include "types.h"
2011-11-28 13:40:17 +04:00
extern char bat_routing_algo [ ] ;
2011-02-18 15:33:19 +03:00
extern struct list_head hardif_list ;
2010-12-13 14:19:28 +03:00
extern unsigned char broadcast_addr [ ] ;
extern struct workqueue_struct * bat_event_workqueue ;
int mesh_init ( struct net_device * soft_iface ) ;
void mesh_free ( struct net_device * soft_iface ) ;
void inc_module_count ( void ) ;
void dec_module_count ( void ) ;
2011-05-15 01:14:50 +04:00
int is_my_mac ( const uint8_t * addr ) ;
2012-03-01 11:35:17 +04:00
int batman_skb_recv ( struct sk_buff * skb , struct net_device * dev ,
struct packet_type * ptype , struct net_device * orig_dev ) ;
int recv_handler_register ( uint8_t packet_type ,
int ( * recv_handler ) ( struct sk_buff * ,
struct hard_iface * ) ) ;
void recv_handler_unregister ( uint8_t packet_type ) ;
2011-11-28 13:40:17 +04:00
int bat_algo_register ( struct bat_algo_ops * bat_algo_ops ) ;
int bat_algo_select ( struct bat_priv * bat_priv , char * name ) ;
int bat_algo_seq_print_text ( struct seq_file * seq , void * offset ) ;
2010-12-13 14:19:28 +03:00
# ifdef CONFIG_BATMAN_ADV_DEBUG
2011-05-15 01:14:50 +04:00
int debug_log ( struct bat_priv * bat_priv , const char * fmt , . . . ) __printf ( 2 , 3 ) ;
2010-12-13 14:19:28 +03:00
# define bat_dbg(type, bat_priv, fmt, arg...) \
do { \
if ( atomic_read ( & bat_priv - > log_level ) & type ) \
debug_log ( bat_priv , fmt , # # arg ) ; \
} \
while ( 0 )
# else /* !CONFIG_BATMAN_ADV_DEBUG */
2011-05-15 01:14:46 +04:00
__printf ( 3 , 4 )
2011-06-15 11:41:37 +04:00
static inline void bat_dbg ( int type __always_unused ,
2011-01-15 17:39:43 +03:00
struct bat_priv * bat_priv __always_unused ,
2011-05-15 01:14:50 +04:00
const char * fmt __always_unused , . . . )
2010-12-13 14:19:28 +03:00
{
}
# endif
# define bat_info(net_dev, fmt, arg...) \
do { \
struct net_device * _netdev = ( net_dev ) ; \
struct bat_priv * _batpriv = netdev_priv ( _netdev ) ; \
bat_dbg ( DBG_ALL , _batpriv , fmt , # # arg ) ; \
pr_info ( " %s: " fmt , _netdev - > name , # # arg ) ; \
} while ( 0 )
# define bat_err(net_dev, fmt, arg...) \
do { \
struct net_device * _netdev = ( net_dev ) ; \
struct bat_priv * _batpriv = netdev_priv ( _netdev ) ; \
bat_dbg ( DBG_ALL , _batpriv , fmt , # # arg ) ; \
pr_err ( " %s: " fmt , _netdev - > name , # # arg ) ; \
} while ( 0 )
2011-02-18 15:28:08 +03:00
/**
* returns 1 if they are the same ethernet addr
*
* note : can ' t use compare_ether_addr ( ) as it requires aligned memory
*/
2011-05-15 01:14:50 +04:00
static inline int compare_eth ( const void * data1 , const void * data2 )
2011-02-18 15:28:08 +03:00
{
return ( memcmp ( data1 , data2 , ETH_ALEN ) = = 0 ? 1 : 0 ) ;
}
2011-12-08 16:32:41 +04:00
/**
* has_timed_out - compares current time ( jiffies ) and timestamp + timeout
* @ timestamp : base value to compare with ( in jiffies )
* @ timeout : added to base value before comparing ( in milliseconds )
*
* Returns true if current time is after timestamp + timeout
*/
static inline bool has_timed_out ( unsigned long timestamp , unsigned int timeout )
{
return time_is_before_jiffies ( timestamp + msecs_to_jiffies ( timeout ) ) ;
}
2011-05-15 01:14:50 +04:00
2011-04-20 11:52:56 +04:00
# define atomic_dec_not_zero(v) atomic_add_unless((v), -1, 0)
2011-05-18 11:20:50 +04:00
/* Returns the smallest signed integer in two's complement with the sizeof x */
# define smallest_signed_int(x) (1u << (7u + 8u * (sizeof(x) - 1u)))
/* Checks if a sequence number x is a predecessor/successor of y.
* they handle overflows / underflows and can correctly check for a
* predecessor / successor unless the variable sequence number has grown by
* more then 2 * * ( bitwidth ( x ) - 1 ) - 1.
* This means that for a uint8_t with the maximum value 255 , it would think :
* - when adding nothing - it is neither a predecessor nor a successor
* - before adding more than 127 to the starting value - it is a predecessor ,
* - when adding 128 - it is neither a predecessor nor a successor ,
* - after adding more than 127 to the starting value - it is a successor */
2011-05-19 23:43:08 +04:00
# define seq_before(x, y) ({typeof(x) _d1 = (x); \
typeof ( y ) _d2 = ( y ) ; \
typeof ( x ) _dummy = ( _d1 - _d2 ) ; \
( void ) ( & _d1 = = & _d2 ) ; \
_dummy > smallest_signed_int ( _dummy ) ; } )
2011-05-18 11:20:50 +04:00
# define seq_after(x, y) seq_before(y, x)
2012-04-20 19:02:45 +04:00
/* Stop preemption on local cpu while incrementing the counter */
static inline void batadv_add_counter ( struct bat_priv * bat_priv , size_t idx ,
size_t count )
{
int cpu = get_cpu ( ) ;
per_cpu_ptr ( bat_priv - > bat_counters , cpu ) [ idx ] + = count ;
put_cpu ( ) ;
}
# define batadv_inc_counter(b, i) batadv_add_counter(b, i, 1)
/* Sum and return the cpu-local counters for index 'idx' */
static inline uint64_t batadv_sum_counter ( struct bat_priv * bat_priv , size_t idx )
{
uint64_t * counters ;
int cpu ;
int sum = 0 ;
for_each_possible_cpu ( cpu ) {
counters = per_cpu_ptr ( bat_priv - > bat_counters , cpu ) ;
sum + = counters [ idx ] ;
}
return sum ;
}
2010-12-13 14:19:28 +03:00
# endif /* _NET_BATMAN_ADV_MAIN_H_ */