ext4_bitmap.h 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  1. /*
  2. * Copyright (c) 2013 Grzegorz Kostka (kostka.grzegorz@gmail.com)
  3. * All rights reserved.
  4. *
  5. * Redistribution and use in source and binary forms, with or without
  6. * modification, are permitted provided that the following conditions
  7. * are met:
  8. *
  9. * - Redistributions of source code must retain the above copyright
  10. * notice, this list of conditions and the following disclaimer.
  11. * - Redistributions in binary form must reproduce the above copyright
  12. * notice, this list of conditions and the following disclaimer in the
  13. * documentation and/or other materials provided with the distribution.
  14. * - The name of the author may not be used to endorse or promote products
  15. * derived from this software without specific prior written permission.
  16. *
  17. * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
  18. * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
  19. * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
  20. * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
  21. * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
  22. * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
  23. * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
  24. * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
  25. * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
  26. * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  27. */
  28. /** @addtogroup lwext4
  29. * @{
  30. */
  31. /**
  32. * @file ext4_bitmap.h
  33. * @brief Block/inode bitmap allocator.
  34. */
  35. #ifndef EXT4_BITMAP_H_
  36. #define EXT4_BITMAP_H_
  37. #ifdef __cplusplus
  38. extern "C" {
  39. #endif
  40. #include <ext4_config.h>
  41. #include <stdint.h>
  42. #include <stdbool.h>
  43. /**@brief Set bitmap bit.
  44. * @param bmap bitmap
  45. * @param bit bit to set*/
  46. static inline void ext4_bmap_bit_set(uint8_t *bmap, uint32_t bit)
  47. {
  48. *(bmap + (bit >> 3)) |= (1 << (bit & 7));
  49. }
  50. /**@brief Clear bitmap bit.
  51. * @param bmap bitmap buffer
  52. * @param bit bit to clear*/
  53. static inline void ext4_bmap_bit_clr(uint8_t *bmap, uint32_t bit)
  54. {
  55. *(bmap + (bit >> 3)) &= ~(1 << (bit & 7));
  56. }
  57. /**@brief Check if the bitmap bit is set.
  58. * @param bmap bitmap buffer
  59. * @param bit bit to check*/
  60. static inline bool ext4_bmap_is_bit_set(uint8_t *bmap, uint32_t bit)
  61. {
  62. return (*(bmap + (bit >> 3)) & (1 << (bit & 7)));
  63. }
  64. /**@brief Check if the bitmap bit is clear.
  65. * @param bmap bitmap buffer
  66. * @param bit bit to check*/
  67. static inline bool ext4_bmap_is_bit_clr(uint8_t *bmap, uint32_t bit)
  68. {
  69. return !ext4_bmap_is_bit_set(bmap, bit);
  70. }
  71. /**@brief Free range of bits in bitmap.
  72. * @param bmap bitmap buffer
  73. * @param sbit start bit
  74. * @param bcnt bit count*/
  75. void ext4_bmap_bits_free(uint8_t *bmap, uint32_t sbit, uint32_t bcnt);
  76. /**@brief Find first clear bit in bitmap.
  77. * @param sbit start bit of search
  78. * @param ebit end bit of search
  79. * @param bit_id output parameter (first free bit)
  80. * @return standard error code*/
  81. int ext4_bmap_bit_find_clr(uint8_t *bmap, uint32_t sbit, uint32_t ebit,
  82. uint32_t *bit_id);
  83. #ifdef __cplusplus
  84. }
  85. #endif
  86. #endif /* EXT4_BITMAP_H_ */
  87. /**
  88. * @}
  89. */