*/
bool* ctxids[TKM_CTX_MAX];
+ /**
+ * Per-kind context limits.
+ */
+ tkm_limits_t limits;
+
/**
* rwlocks for context id lists
*/
METHOD(tkm_id_manager_t, acquire_id, int,
private_tkm_id_manager_t * const this, const tkm_context_kind_t kind)
{
- int j, id = 0;
+ int id = 0;
+ uint64_t j;
if (!is_valid_kind(kind))
{
}
this->locks[kind]->write_lock(this->locks[kind]);
- for (j = 0; j < TKM_LIMIT; j++)
+ for (j = 0; j < this->limits[kind]; j++)
{
if (this->ctxids[kind][j])
{
tkm_id_manager_t *tkm_id_manager_create(const tkm_limits_t limits)
{
private_tkm_id_manager_t *this;
- int i, j;
+ int i;
+ uint64_t j;
INIT(this,
.public = {
for (i = 0; i < TKM_CTX_MAX; i++)
{
- this->ctxids[i] = malloc(TKM_LIMIT * sizeof(bool));
+ this->limits[i] = limits[i];
+ this->ctxids[i] = malloc(limits[i] * sizeof(bool));
this->locks[i] = rwlock_create(RWLOCK_TYPE_DEFAULT);
- for (j = 0; j < TKM_LIMIT; j++)
+ for (j = 0; j < limits[i]; j++)
{
/* available id slots are in true state (is_available) */
this->ctxids[i][j] = true;
}
+ DBG2(DBG_LIB, "%N initialized, %llu slot(s)",
+ tkm_context_kind_names, i, limits[i]);
}
return &this->public;