8
0
mirror of https://github.com/FirebirdSQL/firebird.git synced 2025-01-25 04:43:03 +01:00

Fixed bug CORE-2184 : Bus error on SPARC

This commit is contained in:
hvlad 2010-01-19 08:24:26 +00:00
parent 652bef8300
commit 577a3b8e9a

View File

@ -37,6 +37,8 @@ using Firebird::TempFile;
// Static definitions/initializations // Static definitions/initializations
const size_t MIN_TEMP_BLOCK_SIZE = 64 * 1024;
Firebird::GlobalPtr<Firebird::Mutex> TempSpace::initMutex; Firebird::GlobalPtr<Firebird::Mutex> TempSpace::initMutex;
Firebird::TempDirectoryList* TempSpace::tempDirs = NULL; Firebird::TempDirectoryList* TempSpace::tempDirs = NULL;
size_t TempSpace::minBlockSize = 0; size_t TempSpace::minBlockSize = 0;
@ -149,6 +151,11 @@ TempSpace::TempSpace(MemoryPool& p, const Firebird::PathName& prefix)
MemoryPool& def_pool = *getDefaultMemoryPool(); MemoryPool& def_pool = *getDefaultMemoryPool();
tempDirs = FB_NEW(def_pool) Firebird::TempDirectoryList(def_pool); tempDirs = FB_NEW(def_pool) Firebird::TempDirectoryList(def_pool);
minBlockSize = Config::getTempBlockSize(); minBlockSize = Config::getTempBlockSize();
if (minBlockSize < MIN_TEMP_BLOCK_SIZE)
minBlockSize = MIN_TEMP_BLOCK_SIZE;
else
minBlockSize = FB_ALIGN(minBlockSize, MIN_TEMP_BLOCK_SIZE);
} }
} }
} }
@ -596,6 +603,7 @@ size_t TempSpace::allocateBatch(size_t count, size_t minSize, size_t maxSize, Se
freeMem = MIN(freeMem / count, maxSize); freeMem = MIN(freeMem / count, maxSize);
freeMem = MAX(freeMem, minSize); freeMem = MAX(freeMem, minSize);
freeMem = MIN(freeMem, minBlockSize); freeMem = MIN(freeMem, minBlockSize);
freeMem &= ~(FB_ALIGNMENT - 1);
Segment** prevSpace = &freeSegments; Segment** prevSpace = &freeSegments;
freeSpace = freeSegments; freeSpace = freeSegments;