From 07c5fb2a028dbb97e3c28d267c49131aaba4facb Mon Sep 17 00:00:00 2001 From: rubidium Date: Fri, 9 Jan 2009 15:00:22 +0000 Subject: (svn r14934) -Fix: in (extreme) cases CanAllocateItem could return true when there's not enough space. --- src/oldpool_func.h | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/src/oldpool_func.h b/src/oldpool_func.h index fc08bf9ee..3fbed16a7 100644 --- a/src/oldpool_func.h +++ b/src/oldpool_func.h @@ -44,6 +44,7 @@ template *Tpool> T *PoolItem *Tpool> bool PoolItem::CanAllocateItem(uint count) { uint last_minus_one = Tpool->GetSize() - 1; + uint orig_count = count; for (T *t = Tpool->Get(Tpool->first_free_index); count > 0 && t != NULL; t = ((uint)t->index < last_minus_one) ? Tpool->Get(t->index + 1U) : NULL) { if (!t->IsValid()) count--; @@ -52,7 +53,7 @@ template *Tpool> bool PoolItemAddBlockToPool()) return CanAllocateItem(count); + if (Tpool->AddBlockToPool()) return CanAllocateItem(orig_count); return false; } -- cgit v1.2.3-70-g09d2