* Cleaned up debug output.
* _AllocateInGroup(): Fixed incorrect checks. The allocation group counts the free, not the used blocks. * _AllocateInBitmapBlock(): Fixed allocation loop. It was neither incrementing the array pointer, nor resetting the bit offset. git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@37656 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
parent
1e7497da42
commit
8cb1303cfa
@ -85,12 +85,14 @@ BlockAllocator::Initialize(Transaction& transaction)
|
|||||||
fTotalBlocks);
|
fTotalBlocks);
|
||||||
if (error != B_OK)
|
if (error != B_OK)
|
||||||
return error;
|
return error;
|
||||||
dprintf("fTotalBlocks: %llu\n", fTotalBlocks);
|
|
||||||
dprintf("fFreeBlocks: %llu\n", fFreeBlocks);
|
PRINT("BlockAllocator::Initialize():\n");
|
||||||
dprintf("fAllocationGroupBlock: %llu\n", fAllocationGroupBlock);
|
PRINT(" fTotalBlocks: %" B_PRIu64 "\n", fTotalBlocks);
|
||||||
dprintf("fAllocationGroupCount: %llu\n", fAllocationGroupCount);
|
PRINT(" fFreeBlocks: %" B_PRIu64 "\n", fFreeBlocks);
|
||||||
dprintf("fBitmapBlock: %llu\n", fBitmapBlock);
|
PRINT(" fAllocationGroupBlock: %" B_PRIu64 "\n", fAllocationGroupBlock);
|
||||||
dprintf("fBitmapBlockCount: %llu\n", fBitmapBlockCount);
|
PRINT(" fAllocationGroupCount: %" B_PRIu64 "\n", fAllocationGroupCount);
|
||||||
|
PRINT(" fBitmapBlock: %" B_PRIu64 "\n", fBitmapBlock);
|
||||||
|
PRINT(" fBitmapBlockCount: %" B_PRIu64 "\n", fBitmapBlockCount);
|
||||||
|
|
||||||
// clear the block bitmap
|
// clear the block bitmap
|
||||||
for (uint64 i = 0; i < fBitmapBlockCount; i++) {
|
for (uint64 i = 0; i < fBitmapBlockCount; i++) {
|
||||||
@ -151,12 +153,8 @@ dprintf("fBitmapBlockCount: %llu\n", fBitmapBlockCount);
|
|||||||
if (error != B_OK)
|
if (error != B_OK)
|
||||||
return error;
|
return error;
|
||||||
|
|
||||||
dprintf("fTotalBlocks: %llu\n", fTotalBlocks);
|
PRINT("BlockAllocator::Initialize() done:\n");
|
||||||
dprintf("fFreeBlocks: %llu\n", fFreeBlocks);
|
PRINT(" fFreeBlocks: %" B_PRIu64 "\n", fFreeBlocks);
|
||||||
dprintf("fAllocationGroupBlock: %llu\n", fAllocationGroupBlock);
|
|
||||||
dprintf("fAllocationGroupCount: %llu\n", fAllocationGroupCount);
|
|
||||||
dprintf("fBitmapBlock: %llu\n", fBitmapBlock);
|
|
||||||
dprintf("fBitmapBlockCount: %llu\n", fBitmapBlockCount);
|
|
||||||
|
|
||||||
return B_OK;
|
return B_OK;
|
||||||
}
|
}
|
||||||
@ -167,7 +165,9 @@ BlockAllocator::Allocate(uint64 baseHint, uint64 count,
|
|||||||
Transaction& transaction, uint64& _allocatedBase, uint64& _allocatedCount)
|
Transaction& transaction, uint64& _allocatedBase, uint64& _allocatedCount)
|
||||||
{
|
{
|
||||||
MutexLocker locker(fLock);
|
MutexLocker locker(fLock);
|
||||||
dprintf("BlockAllocator::Allocate(%llu, %llu)\n", baseHint, count);
|
|
||||||
|
PRINT("BlockAllocator::Allocate(%" B_PRIu64 ", %" B_PRIu64 ")\n", baseHint,
|
||||||
|
count);
|
||||||
|
|
||||||
if (fFreeBlocks == 0)
|
if (fFreeBlocks == 0)
|
||||||
return B_DEVICE_FULL;
|
return B_DEVICE_FULL;
|
||||||
@ -198,7 +198,9 @@ BlockAllocator::AllocateExactly(uint64 base, uint64 count,
|
|||||||
Transaction& transaction)
|
Transaction& transaction)
|
||||||
{
|
{
|
||||||
MutexLocker locker(fLock);
|
MutexLocker locker(fLock);
|
||||||
dprintf("BlockAllocator::AllocateExactly(%llu, %llu)\n", base, count);
|
|
||||||
|
PRINT("BlockAllocator::AllocateExactly(%" B_PRIu64 ", %" B_PRIu64 ")\n",
|
||||||
|
base, count);
|
||||||
|
|
||||||
uint64 allocated;
|
uint64 allocated;
|
||||||
status_t error = _Allocate(base, fTotalBlocks, count, transaction, NULL,
|
status_t error = _Allocate(base, fTotalBlocks, count, transaction, NULL,
|
||||||
@ -261,7 +263,7 @@ BlockAllocator::_Allocate(uint64 base, uint64 searchEnd, uint64 count,
|
|||||||
ASSERT(searchEnd <= fTotalBlocks);
|
ASSERT(searchEnd <= fTotalBlocks);
|
||||||
|
|
||||||
if (base >= searchEnd || fFreeBlocks == 0)
|
if (base >= searchEnd || fFreeBlocks == 0)
|
||||||
return B_BUSY;
|
RETURN_ERROR(B_BUSY);
|
||||||
|
|
||||||
uint64 groupOffset = base % kBlocksPerGroup;
|
uint64 groupOffset = base % kBlocksPerGroup;
|
||||||
uint64 remaining = count;
|
uint64 remaining = count;
|
||||||
@ -321,7 +323,7 @@ BlockAllocator::_Allocate(uint64 base, uint64 searchEnd, uint64 count,
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (remaining == count)
|
if (remaining == count)
|
||||||
return B_BUSY;
|
RETURN_ERROR(B_BUSY);
|
||||||
|
|
||||||
_allocatedCount = count - remaining;
|
_allocatedCount = count - remaining;
|
||||||
return B_OK;
|
return B_OK;
|
||||||
@ -353,17 +355,19 @@ status_t
|
|||||||
BlockAllocator::_AllocateInGroup(uint64 base, uint64 searchEnd, uint32 count,
|
BlockAllocator::_AllocateInGroup(uint64 base, uint64 searchEnd, uint32 count,
|
||||||
Transaction& transaction, uint64* _allocatedBase, uint32& _allocatedCount)
|
Transaction& transaction, uint64* _allocatedBase, uint32& _allocatedCount)
|
||||||
{
|
{
|
||||||
dprintf("BlockAllocator::_AllocateInGroup(%llu, %lu)\n", base, count);
|
PRINT("BlockAllocator::_AllocateInGroup(%" B_PRIu64 ", %" B_PRIu32 ")\n",
|
||||||
|
base, count);
|
||||||
|
|
||||||
ASSERT(count <= kBlocksPerGroup);
|
ASSERT(count <= kBlocksPerGroup);
|
||||||
ASSERT(base % kBlocksPerGroup + count <= kBlocksPerGroup);
|
ASSERT(base % kBlocksPerGroup + count <= kBlocksPerGroup);
|
||||||
|
|
||||||
if (base >= searchEnd)
|
if (base >= searchEnd)
|
||||||
return B_BUSY;
|
RETURN_ERROR(B_BUSY);
|
||||||
|
|
||||||
Block block;
|
Block block;
|
||||||
if (!block.GetWritable(fVolume,
|
if (!block.GetWritable(fVolume,
|
||||||
fAllocationGroupBlock + base / kBlocksPerGroup, transaction)) {
|
fAllocationGroupBlock + base / kBlocksPerGroup, transaction)) {
|
||||||
return B_ERROR;
|
RETURN_ERROR(B_ERROR);
|
||||||
}
|
}
|
||||||
|
|
||||||
uint16* counts = (uint16*)block.Data();
|
uint16* counts = (uint16*)block.Data();
|
||||||
@ -376,10 +380,12 @@ dprintf("BlockAllocator::_AllocateInGroup(%llu, %lu)\n", base, count);
|
|||||||
if (_allocatedBase != NULL) {
|
if (_allocatedBase != NULL) {
|
||||||
// check partial block
|
// check partial block
|
||||||
if (inBlockOffset != 0) {
|
if (inBlockOffset != 0) {
|
||||||
if (counts[blockIndex] < kBlocksPerBitmapBlock) {
|
if (counts[blockIndex] > 0) {
|
||||||
uint32 allocated;
|
uint32 allocated;
|
||||||
if (_AllocateInBitmapBlock(base, count, transaction,
|
if (_AllocateInBitmapBlock(base, count, transaction,
|
||||||
_allocatedBase, allocated) == B_OK) {
|
_allocatedBase, allocated) == B_OK) {
|
||||||
|
counts[blockIndex] -= allocated;
|
||||||
|
|
||||||
if (inBlockOffset + allocated < kBlocksPerBitmapBlock
|
if (inBlockOffset + allocated < kBlocksPerBitmapBlock
|
||||||
|| allocated == remaining) {
|
|| allocated == remaining) {
|
||||||
_allocatedCount = allocated;
|
_allocatedCount = allocated;
|
||||||
@ -402,7 +408,7 @@ dprintf("BlockAllocator::_AllocateInGroup(%llu, %lu)\n", base, count);
|
|||||||
// skip completely used blocks
|
// skip completely used blocks
|
||||||
if (_allocatedBase != NULL) {
|
if (_allocatedBase != NULL) {
|
||||||
while (blockIndex < kBitmapBlocksPerGroup && base < searchEnd) {
|
while (blockIndex < kBitmapBlocksPerGroup && base < searchEnd) {
|
||||||
if (counts[blockIndex] < kBlocksPerBitmapBlock)
|
if (counts[blockIndex] > 0)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
base += kBlocksPerBitmapBlock;
|
base += kBlocksPerBitmapBlock;
|
||||||
@ -424,7 +430,7 @@ dprintf("BlockAllocator::_AllocateInGroup(%llu, %lu)\n", base, count);
|
|||||||
|
|
||||||
// Allocate as many of the requested blocks as we can.
|
// Allocate as many of the requested blocks as we can.
|
||||||
while (remaining > 0 && base < searchEnd) {
|
while (remaining > 0 && base < searchEnd) {
|
||||||
if (counts[blockIndex] >= kBlocksPerBitmapBlock)
|
if (counts[blockIndex] == 0)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
uint32 toAllocate = std::min(remaining,
|
uint32 toAllocate = std::min(remaining,
|
||||||
@ -479,14 +485,16 @@ status_t
|
|||||||
BlockAllocator::_AllocateInBitmapBlock(uint64 base, uint32 count,
|
BlockAllocator::_AllocateInBitmapBlock(uint64 base, uint32 count,
|
||||||
Transaction& transaction, uint64* _allocatedBase, uint32& _allocatedCount)
|
Transaction& transaction, uint64* _allocatedBase, uint32& _allocatedCount)
|
||||||
{
|
{
|
||||||
dprintf("BlockAllocator::_AllocateInBitmapBlock(%llu, %lu)\n", base, count);
|
PRINT("BlockAllocator::_AllocateInBitmapBlock(%" B_PRIu64 "u, %" B_PRIu32
|
||||||
|
")\n", base, count);
|
||||||
|
|
||||||
ASSERT(count <= kBlocksPerBitmapBlock);
|
ASSERT(count <= kBlocksPerBitmapBlock);
|
||||||
ASSERT(base % kBlocksPerBitmapBlock + count <= kBlocksPerBitmapBlock);
|
ASSERT(base % kBlocksPerBitmapBlock + count <= kBlocksPerBitmapBlock);
|
||||||
|
|
||||||
Block block;
|
Block block;
|
||||||
if (!block.GetWritable(fVolume,
|
if (!block.GetWritable(fVolume,
|
||||||
fBitmapBlock + base / kBlocksPerBitmapBlock, transaction)) {
|
fBitmapBlock + base / kBlocksPerBitmapBlock, transaction)) {
|
||||||
return B_ERROR;
|
RETURN_ERROR(B_ERROR);
|
||||||
}
|
}
|
||||||
|
|
||||||
uint32* bits = (uint32*)block.Data()
|
uint32* bits = (uint32*)block.Data()
|
||||||
@ -545,6 +553,10 @@ dprintf("BlockAllocator::_AllocateInBitmapBlock(%llu, %lu)\n", base, count);
|
|||||||
uint32 remaining = count;
|
uint32 remaining = count;
|
||||||
|
|
||||||
while (remaining > 0 & bits < bitsEnd) {
|
while (remaining > 0 & bits < bitsEnd) {
|
||||||
|
PRINT(" remaining: %" B_PRIu32 ", index: %" B_PRIu32 ".%" B_PRIu32
|
||||||
|
", bits: %#" B_PRIx32 "\n", remaining,
|
||||||
|
kBlocksPerBitmapBlock - (bitsEnd - bits), bitOffset, *bits);
|
||||||
|
|
||||||
// TODO: Not particularly efficient for large allocations.
|
// TODO: Not particularly efficient for large allocations.
|
||||||
uint32 endOffset = std::min(bitOffset + remaining, (uint32)32);
|
uint32 endOffset = std::min(bitOffset + remaining, (uint32)32);
|
||||||
for (; bitOffset < endOffset; bitOffset++) {
|
for (; bitOffset < endOffset; bitOffset++) {
|
||||||
@ -556,10 +568,13 @@ dprintf("BlockAllocator::_AllocateInBitmapBlock(%llu, %lu)\n", base, count);
|
|||||||
*bits |= (uint32)1 << bitOffset;
|
*bits |= (uint32)1 << bitOffset;
|
||||||
remaining--;
|
remaining--;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bits++;
|
||||||
|
bitOffset = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (remaining == count)
|
if (remaining == count)
|
||||||
return B_BUSY;
|
RETURN_ERROR(B_BUSY);
|
||||||
|
|
||||||
_allocatedCount = count - remaining;
|
_allocatedCount = count - remaining;
|
||||||
if (_allocatedBase != NULL)
|
if (_allocatedBase != NULL)
|
||||||
@ -575,7 +590,7 @@ BlockAllocator::_Free(uint64 base, uint64 count, Transaction& transaction)
|
|||||||
if (count == 0)
|
if (count == 0)
|
||||||
return B_OK;
|
return B_OK;
|
||||||
|
|
||||||
dprintf("BlockAllocator::_Free(%llu, %llu)\n", base, count);
|
PRINT("BlockAllocator::_Free(%" B_PRIu64 ", %" B_PRIu64 ")\n", base, count);
|
||||||
|
|
||||||
ASSERT(count <= fTotalBlocks - fFreeBlocks);
|
ASSERT(count <= fTotalBlocks - fFreeBlocks);
|
||||||
ASSERT(base < fTotalBlocks && fTotalBlocks - base >= count);
|
ASSERT(base < fTotalBlocks && fTotalBlocks - base >= count);
|
||||||
@ -606,7 +621,9 @@ BlockAllocator::_FreeInGroup(uint64 base, uint32 count,
|
|||||||
if (count == 0)
|
if (count == 0)
|
||||||
return B_OK;
|
return B_OK;
|
||||||
|
|
||||||
dprintf("BlockAllocator::_FreeInGroup(%llu, %lu)\n", base, count);
|
PRINT("BlockAllocator::_FreeInGroup(%" B_PRIu64 ", %" B_PRIu32 ")\n",
|
||||||
|
base, count);
|
||||||
|
|
||||||
ASSERT(count <= kBlocksPerGroup);
|
ASSERT(count <= kBlocksPerGroup);
|
||||||
ASSERT(base % kBlocksPerGroup + count <= kBlocksPerGroup);
|
ASSERT(base % kBlocksPerGroup + count <= kBlocksPerGroup);
|
||||||
|
|
||||||
@ -648,7 +665,9 @@ status_t
|
|||||||
BlockAllocator::_FreeInBitmapBlock(uint64 base, uint32 count,
|
BlockAllocator::_FreeInBitmapBlock(uint64 base, uint32 count,
|
||||||
Transaction& transaction)
|
Transaction& transaction)
|
||||||
{
|
{
|
||||||
dprintf("BlockAllocator::_FreeInBitmapBlock(%llu, %lu)\n", base, count);
|
PRINT("BlockAllocator::_FreeInBitmapBlock(%" B_PRIu64 ", %" B_PRIu32 ")\n",
|
||||||
|
base, count);
|
||||||
|
|
||||||
ASSERT(count <= kBlocksPerBitmapBlock);
|
ASSERT(count <= kBlocksPerBitmapBlock);
|
||||||
ASSERT(base % kBlocksPerBitmapBlock + count <= kBlocksPerBitmapBlock);
|
ASSERT(base % kBlocksPerBitmapBlock + count <= kBlocksPerBitmapBlock);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user