forked from vitalif/vitastor
You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
19 lines
331 B
C++
19 lines
331 B
C++
#pragma once
|
|
|
|
#include <stdint.h>
|
|
|
|
// Hierarchical bitmap allocator
|
|
class allocator
|
|
{
|
|
uint64_t size;
|
|
uint64_t free;
|
|
uint64_t last_one_mask;
|
|
uint64_t *mask;
|
|
public:
|
|
allocator(uint64_t blocks);
|
|
~allocator();
|
|
void set(uint64_t addr, bool value);
|
|
uint64_t find_free();
|
|
uint64_t get_free_count();
|
|
};
|