Blame view

RIOT/sys/bitfield/bitfield.c 930 Bytes
a752c7ab   elopes   add first test an...
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
  /*
   * Copyright (C) 2015 Kaspar Schleiser <kaspar@schleiser.de>
   *
   * This file is subject to the terms and conditions of the GNU Lesser
   * General Public License v2.1. See the file LICENSE in the top level
   * directory for more details.
   */
  
  /**
   * @ingroup     sys_util
   * @{
   *
   * @file
   * @brief       Bitfield auxillary functions
   *
   * @author      Kaspar Schleiser <kaspar@schleiser.de>
   *
   * @}
   */
  
  #include <stdint.h>
  #include "bitfield.h"
  #include "irq.h"
  
  int bf_get_unset(uint8_t field[], int size)
  {
      int result = -1;
      int nbytes = (size + 7) / 8;
      int i = 0;
  
      unsigned state = irq_disable();
  
      /* skip full bytes */
      for (int j = 0; (j < nbytes) && (field[j] == 255); j++) {
          i += 8;
      }
  
      for (; i < size; i++) {
          if (!bf_isset(field, i)) {
              bf_set(field, i);
              result = i;
              break;
          }
      }
  
      irq_restore(state);
      return(result);
  }