2005-10-16 14:33:22 +00:00
/*
* Copyright ( C ) 2001 - 2004 Sistina Software , Inc . All rights reserved .
2007-08-21 16:26:07 +00:00
* Copyright ( C ) 2004 - 2006 Red Hat , Inc . All rights reserved .
2005-10-16 14:33:22 +00:00
*
* This file is part of the device - mapper userspace tools .
*
* This copyrighted material is made available to anyone wishing to use ,
* modify , copy , or redistribute it subject to the terms and conditions
2007-08-21 16:26:07 +00:00
* of the GNU Lesser General Public License v .2 .1 .
2005-10-16 14:33:22 +00:00
*
2007-08-21 16:26:07 +00:00
* You should have received a copy of the GNU Lesser General Public License
2005-10-16 14:33:22 +00:00
* along with this program ; if not , write to the Free Software Foundation ,
2016-01-21 11:49:46 +01:00
* Inc . , 51 Franklin Street , Fifth Floor , Boston , MA 02110 - 1301 USA
2005-10-16 14:33:22 +00:00
*/
2008-11-03 18:59:59 +00:00
# include "dmlib.h"
2005-10-16 14:33:22 +00:00
/* FIXME: calculate this. */
# define INT_SHIFT 5
2005-10-16 22:57:20 +00:00
dm_bitset_t dm_bitset_create ( struct dm_pool * mem , unsigned num_bits )
2005-10-16 14:33:22 +00:00
{
2005-10-16 22:57:20 +00:00
unsigned n = ( num_bits / DM_BITS_PER_INT ) + 2 ;
2005-10-16 14:33:22 +00:00
size_t size = sizeof ( int ) * n ;
2005-10-16 22:57:20 +00:00
dm_bitset_t bs ;
2005-10-16 14:33:22 +00:00
if ( mem )
2005-10-16 22:57:20 +00:00
bs = dm_pool_zalloc ( mem , size ) ;
2010-09-30 21:06:50 +00:00
else
bs = dm_zalloc ( size ) ;
2005-10-16 14:33:22 +00:00
if ( ! bs )
return NULL ;
* bs = num_bits ;
return bs ;
}
2005-10-16 22:57:20 +00:00
void dm_bitset_destroy ( dm_bitset_t bs )
2005-10-16 14:33:22 +00:00
{
2005-10-16 22:57:20 +00:00
dm_free ( bs ) ;
2005-10-16 14:33:22 +00:00
}
2010-04-20 13:58:22 +00:00
int dm_bitset_equal ( dm_bitset_t in1 , dm_bitset_t in2 )
{
int i ;
for ( i = ( in1 [ 0 ] / DM_BITS_PER_INT ) + 1 ; i ; i - - )
if ( in1 [ i ] ! = in2 [ i ] )
return 0 ;
return 1 ;
}
2010-04-19 21:23:01 +00:00
void dm_bit_and ( dm_bitset_t out , dm_bitset_t in1 , dm_bitset_t in2 )
{
int i ;
for ( i = ( in1 [ 0 ] / DM_BITS_PER_INT ) + 1 ; i ; i - - )
out [ i ] = in1 [ i ] & in2 [ i ] ;
}
2005-10-16 22:57:20 +00:00
void dm_bit_union ( dm_bitset_t out , dm_bitset_t in1 , dm_bitset_t in2 )
2005-10-16 14:33:22 +00:00
{
int i ;
2005-10-16 22:57:20 +00:00
for ( i = ( in1 [ 0 ] / DM_BITS_PER_INT ) + 1 ; i ; i - - )
2005-10-16 14:33:22 +00:00
out [ i ] = in1 [ i ] | in2 [ i ] ;
}
2010-04-19 17:17:55 +00:00
static int _test_word ( uint32_t test , int bit )
2005-10-16 14:33:22 +00:00
{
2010-07-08 12:16:16 +00:00
uint32_t tb = test > > bit ;
2005-10-16 14:33:22 +00:00
2010-07-08 12:16:16 +00:00
return ( tb ? ffs ( tb ) + bit - 1 : - 1 ) ;
2005-10-16 14:33:22 +00:00
}
2005-10-16 22:57:20 +00:00
int dm_bit_get_next ( dm_bitset_t bs , int last_bit )
2005-10-16 14:33:22 +00:00
{
int bit , word ;
uint32_t test ;
last_bit + + ; /* otherwise we'll return the same bit again */
2006-01-31 14:50:38 +00:00
/*
* bs [ 0 ] holds number of bits
*/
while ( last_bit < ( int ) bs [ 0 ] ) {
2005-10-16 14:33:22 +00:00
word = last_bit > > INT_SHIFT ;
test = bs [ word + 1 ] ;
2005-10-16 22:57:20 +00:00
bit = last_bit & ( DM_BITS_PER_INT - 1 ) ;
2005-10-16 14:33:22 +00:00
if ( ( bit = _test_word ( test , bit ) ) > = 0 )
2005-10-16 22:57:20 +00:00
return ( word * DM_BITS_PER_INT ) + bit ;
2005-10-16 14:33:22 +00:00
2005-10-16 22:57:20 +00:00
last_bit = last_bit - ( last_bit & ( DM_BITS_PER_INT - 1 ) ) +
DM_BITS_PER_INT ;
2005-10-16 14:33:22 +00:00
}
return - 1 ;
}
2005-10-16 22:57:20 +00:00
int dm_bit_get_first ( dm_bitset_t bs )
2005-10-16 14:33:22 +00:00
{
2005-10-16 22:57:20 +00:00
return dm_bit_get_next ( bs , - 1 ) ;
2005-10-16 14:33:22 +00:00
}