OpenCores
URL https://opencores.org/ocsvn/c0or1k/c0or1k/trunk

Subversion Repositories c0or1k

[/] [c0or1k/] [trunk/] [conts/] [posix/] [mm0/] [tests/] [idpool_test/] [idpool.c] - Rev 2

Compare with Previous | Blame | View Log

/*
 * Used for thread and space ids.
 *
 * Copyright (C) 2007 Bahadir Balban
 */
#include "idpool.h"
#include <stdio.h>
#include <stdlib.h>
 
struct id_pool *id_pool_new_init(int totalbits)
{
	int nwords = BITWISE_GETWORD(totalbits);
	struct id_pool *new = calloc(1, (nwords * SZ_WORD)
				      + sizeof(struct id_pool));
	new->nwords = nwords;
	return new;
}
 
int id_new(struct id_pool *pool)
{
	int id = find_and_set_first_free_bit(pool->bitmap,
					     pool->nwords * WORD_BITS);
	if (id < 0)
		printf("%s: Warning! New id alloc failed\n", __FUNCTION__);
	return id;
}
 
/* This finds n contiguous free ids, allocates and returns the first one */
int ids_new_contiguous(struct id_pool *pool, int numids)
{
	printf("%s: Enter\n", __FUNCTION__);
	int id = find_and_set_first_free_contig_bits(pool->bitmap,
						     pool->nwords *WORD_BITS,
						     numids);
	if (id < 0)
		printf("%s: Warning! New id alloc failed\n", __FUNCTION__);
	return id;
}
 
/* This deletes a list of contiguous ids given the first one and number of ids */
int ids_del_contiguous(struct id_pool *pool, int first, int numids)
{
	int ret;
	printf("bits: %d, first +nids: %d\n", pool->nwords *WORD_BITS, first+numids);
	if (pool->nwords * WORD_BITS < first + numids)
		return -1;
	if ((ret = check_and_clear_contig_bits(pool->bitmap, first, numids)))
		printf("Warning!!!\n");
	return ret;
}
 
int id_del(struct id_pool *pool, int id)
{
	int ret;
 
	if (pool->nwords * WORD_BITS < id)
		return -1;
 
	if ((ret = check_and_clear_bit(pool->bitmap, id) < 0))
		printf("Warning!!!\n");
	return ret;
}
 
 

Compare with Previous | Blame | View Log

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.