2020-05-12 16:54:17 -07:00
/* SPDX-License-Identifier: GPL-2.0 */
2005-04-16 15:20:36 -07:00
/*
2005-11-02 14:58:39 +11:00
* Copyright ( c ) 2000 , 2002 , 2005 Silicon Graphics , Inc .
* All Rights Reserved .
2005-04-16 15:20:36 -07:00
*/
# ifndef __XFS_BIT_H__
# define __XFS_BIT_H__
/*
* XFS bit manipulation routines .
*/
/*
2009-01-09 15:53:54 +11:00
* masks with n high / low bits set , 64 - bit values
2005-04-16 15:20:36 -07:00
*/
2017-06-16 11:00:05 -07:00
static inline uint64_t xfs_mask64hi ( int n )
2005-11-02 14:38:42 +11:00
{
2017-06-16 11:00:05 -07:00
return ( uint64_t ) - 1 < < ( 64 - ( n ) ) ;
2005-11-02 14:38:42 +11:00
}
2017-06-16 11:00:05 -07:00
static inline uint32_t xfs_mask32lo ( int n )
2005-11-02 14:38:42 +11:00
{
2017-06-16 11:00:05 -07:00
return ( ( uint32_t ) 1 < < ( n ) ) - 1 ;
2005-11-02 14:38:42 +11:00
}
2017-06-16 11:00:05 -07:00
static inline uint64_t xfs_mask64lo ( int n )
2005-11-02 14:38:42 +11:00
{
2017-06-16 11:00:05 -07:00
return ( ( uint64_t ) 1 < < ( n ) ) - 1 ;
2005-11-02 14:38:42 +11:00
}
2005-04-16 15:20:36 -07:00
/* Get high bit set out of 32-bit argument, -1 if none set */
2017-06-16 11:00:05 -07:00
static inline int xfs_highbit32 ( uint32_t v )
2008-08-13 15:41:12 +10:00
{
return fls ( v ) - 1 ;
}
/* Get high bit set out of 64-bit argument, -1 if none set */
2017-06-16 11:00:05 -07:00
static inline int xfs_highbit64 ( uint64_t v )
2008-08-13 15:41:12 +10:00
{
return fls64 ( v ) - 1 ;
}
/* Get low bit set out of 32-bit argument, -1 if none set */
2017-06-16 11:00:05 -07:00
static inline int xfs_lowbit32 ( uint32_t v )
2008-08-13 15:41:12 +10:00
{
2008-10-30 17:05:38 +11:00
return ffs ( v ) - 1 ;
2008-08-13 15:41:12 +10:00
}
2007-11-23 16:27:59 +11:00
/* Get low bit set out of 64-bit argument, -1 if none set */
2017-06-16 11:00:05 -07:00
static inline int xfs_lowbit64 ( uint64_t v )
2008-08-13 15:41:12 +10:00
{
2017-06-16 11:00:05 -07:00
uint32_t w = ( uint32_t ) v ;
2008-08-13 15:41:12 +10:00
int n = 0 ;
2008-02-26 17:00:22 +11:00
2008-08-13 15:41:12 +10:00
if ( w ) { /* lower bits */
n = ffs ( w ) ;
} else { /* upper bits */
2017-06-16 11:00:05 -07:00
w = ( uint32_t ) ( v > > 32 ) ;
2014-06-06 16:04:42 +10:00
if ( w ) {
n = ffs ( w ) ;
if ( n )
n + = 32 ;
}
2008-08-13 15:41:12 +10:00
}
return n - 1 ;
}
2005-04-16 15:20:36 -07:00
2007-06-28 16:43:30 +10:00
/* Return whether bitmap is empty (1 == empty) */
extern int xfs_bitmap_empty ( uint * map , uint size ) ;
2005-04-16 15:20:36 -07:00
/* Count continuous one bits in map starting with start_bit */
extern int xfs_contig_bits ( uint * map , uint size , uint start_bit ) ;
/* Find next set bit in map */
extern int xfs_next_bit ( uint * map , uint size , uint start_bit ) ;
# endif /* __XFS_BIT_H__ */