2010-12-13 14:19:28 +03:00
/*
2012-01-01 03:41:38 +04:00
* Copyright ( C ) 2006 - 2012 B . A . T . M . A . N . contributors :
2010-12-13 14:19:28 +03:00
*
* Simon Wunderlich , Marek Lindner
*
* 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_BITARRAY_H_
# define _NET_BATMAN_ADV_BITARRAY_H_
# define WORD_BIT_SIZE (sizeof(unsigned long) * 8)
/* returns true if the corresponding bit in the given seq_bits indicates true
* and curr_seqno is within range of last_seqno */
2011-06-15 11:41:36 +04:00
int get_bit_status ( const unsigned long * seq_bits , uint32_t last_seqno ,
uint32_t curr_seqno ) ;
2010-12-13 14:19:28 +03:00
/* turn corresponding bit on, so we can remember that we got the packet */
void bit_mark ( unsigned long * seq_bits , int32_t n ) ;
/* receive and process one packet, returns 1 if received seq_num is considered
* new , 0 if old */
2011-06-15 11:41:37 +04:00
int bit_get_packet ( void * priv , unsigned long * seq_bits ,
int32_t seq_num_diff , int set_mark ) ;
2010-12-13 14:19:28 +03:00
/* count the hamming weight, how many good packets did we receive? */
2011-05-15 01:14:50 +04:00
int bit_packet_count ( const unsigned long * seq_bits ) ;
2010-12-13 14:19:28 +03:00
# endif /* _NET_BATMAN_ADV_BITARRAY_H_ */