The Pedigree Project  0.1
ExtensibleBitmap.h
1 /*
2  * Copyright (c) 2008-2014, Pedigree Developers
3  *
4  * Please see the CONTRIB file in the root of the source tree for a full
5  * list of contributors.
6  *
7  * Permission to use, copy, modify, and distribute this software for any
8  * purpose with or without fee is hereby granted, provided that the above
9  * copyright notice and this permission notice appear in all copies.
10  *
11  * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
12  * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
13  * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
14  * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
15  * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
16  * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
17  * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
18  */
19 
20 #ifndef EXTENSIBLE_BITMAP_H
21 #define EXTENSIBLE_BITMAP_H
22 
23 #include "pedigree/kernel/compiler.h"
24 #include "pedigree/kernel/processor/types.h"
25 
33 {
34  public:
38  ExtensibleBitmap(const ExtensibleBitmap &other);
41 
43  ExtensibleBitmap &operator=(const ExtensibleBitmap &other);
44 
45  //
46  // Public interface.
47  //
49  void set(size_t n);
51  void clear(size_t n);
53  bool test(size_t n) const;
55  inline size_t getFirstSet() const
56  {
57  return m_nFirstSetBit;
58  }
60  inline size_t getFirstClear()
61  {
62  while (test(m_nFirstClearBit))
63  {
64  m_nFirstClearBit++;
65  }
66  return m_nFirstClearBit;
67  }
69  inline size_t getLastSet() const
70  {
71  return m_nLastSetBit;
72  }
74  inline size_t getLastClear() const
75  {
76  return m_nLastClearBit;
77  }
78 
79  private:
82  uintptr_t m_StaticMap;
83 
85  uint8_t *m_pDynamicMap;
86 
89 
91  size_t m_nMaxBit;
92 
95  size_t m_nFirstClearBit;
96  size_t m_nLastSetBit;
97  size_t m_nLastClearBit;
98 };
99 
100 #endif
size_t getLastClear() const
size_t getFirstSet() const
size_t getLastSet() const
uint8_t * m_pDynamicMap