Files
mop3/kernel/id/id_alloc.c
kamkow1 e5ebd7f3ba
All checks were successful
Build ISO image / build-and-deploy (push) Successful in 2m21s
Build documentation / build-and-deploy (push) Successful in 54s
Use a big-lock for kernel sychronization instead of fine-grained locking
2026-04-27 18:06:02 +02:00

52 lines
983 B
C

#include <id/id_alloc.h>
#include <libk/bm.h>
#include <libk/std.h>
#include <mm/malloc.h>
#include <status.h>
#include <sync/spin_lock.h>
#include <sys/debug.h>
bool id_alloc_init(struct id_alloc* ida, size_t nbits) {
size_t buffer_size = (nbits + 7) / 8;
uint8_t* buffer = malloc(buffer_size);
if (buffer == NULL)
return false;
bm_init(&ida->bm, buffer, nbits);
return true;
}
void id_alloc_fini(struct id_alloc* ida) {
free(ida->bm.base);
ida->bm.base = NULL;
ida->bm.nbits = 0;
}
int id_alloc(struct id_alloc* ida) {
size_t start = ida->next_id;
size_t current = start;
do {
if (!bm_test(&ida->bm, current)) {
bm_set(&ida->bm, current);
ida->next_id = (current + 1) % ida->bm.nbits;
return (int)current;
}
current = (current + 1) % ida->bm.nbits;
} while (current != start);
return -ST_OOM_ERROR;
}
void id_free(struct id_alloc* ida, int id) {
if (id < 0)
return;
bm_clear(&ida->bm, (size_t)id);
}