summaryrefslogtreecommitdiff
path: root/src/libstddjb/bitarray_firstclear.c
blob: 80b6fbb9da4ad352fc0ae29df0cb45f1ed126eda (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
/* ISC license. */

#include <skalibs/bitarray.h>

unsigned int bitarray_firstclear (register unsigned char const *s, unsigned int max)
{
  unsigned int n = bitarray_div8(max) ;
  register unsigned int i = 0 ;
  for (; i < n ; i++) if (s[i] != 0xffU) break ;
  if (i == n) return max ;
  i <<= 3 ;
  while ((i < max) && bitarray_peek(s, i)) i++ ;
  return i ;
}