Mark freed memory in stack arena with 0xdd. b=161283 sr=bzbarsky r=kin

This commit is contained in:
dbaron%fas.harvard.edu 2002-08-14 12:49:24 +00:00
Родитель 3ce29e8630
Коммит 22351decd5
2 изменённых файлов: 30 добавлений и 10 удалений

Просмотреть файл

@ -549,6 +549,20 @@ StackArena::Pop()
// pop off the mark // pop off the mark
NS_ASSERTION(mStackTop > 0, "Error Pop called 1 too many times"); NS_ASSERTION(mStackTop > 0, "Error Pop called 1 too many times");
mStackTop--; mStackTop--;
#ifdef DEBUG
// Mark the "freed" memory with 0xdd to help with debugging of memory
// allocation problems.
{
StackBlock *block = mMarks[mStackTop].mBlock, *block_end = mCurBlock;
size_t pos = mMarks[mStackTop].mPos;
for (; block != block_end; block = block->mNext, pos = 0) {
memset(block->mBlock + pos, 0xdd, sizeof(block->mBlock) - pos);
}
memset(block->mBlock + pos, 0xdd, mPos - pos);
}
#endif
mCurBlock = mMarks[mStackTop].mBlock; mCurBlock = mMarks[mStackTop].mBlock;
mPos = mMarks[mStackTop].mPos; mPos = mMarks[mStackTop].mPos;
@ -1870,11 +1884,7 @@ PresShell::PushStackMemory()
NS_IMETHODIMP NS_IMETHODIMP
PresShell::PopStackMemory() PresShell::PopStackMemory()
{ {
if (!mStackArena) { NS_ENSURE_TRUE(mStackArena, NS_ERROR_UNEXPECTED);
mStackArena = new StackArena();
if (!mStackArena)
return NS_ERROR_OUT_OF_MEMORY;
}
return mStackArena->Pop(); return mStackArena->Pop();
} }

Просмотреть файл

@ -549,6 +549,20 @@ StackArena::Pop()
// pop off the mark // pop off the mark
NS_ASSERTION(mStackTop > 0, "Error Pop called 1 too many times"); NS_ASSERTION(mStackTop > 0, "Error Pop called 1 too many times");
mStackTop--; mStackTop--;
#ifdef DEBUG
// Mark the "freed" memory with 0xdd to help with debugging of memory
// allocation problems.
{
StackBlock *block = mMarks[mStackTop].mBlock, *block_end = mCurBlock;
size_t pos = mMarks[mStackTop].mPos;
for (; block != block_end; block = block->mNext, pos = 0) {
memset(block->mBlock + pos, 0xdd, sizeof(block->mBlock) - pos);
}
memset(block->mBlock + pos, 0xdd, mPos - pos);
}
#endif
mCurBlock = mMarks[mStackTop].mBlock; mCurBlock = mMarks[mStackTop].mBlock;
mPos = mMarks[mStackTop].mPos; mPos = mMarks[mStackTop].mPos;
@ -1870,11 +1884,7 @@ PresShell::PushStackMemory()
NS_IMETHODIMP NS_IMETHODIMP
PresShell::PopStackMemory() PresShell::PopStackMemory()
{ {
if (!mStackArena) { NS_ENSURE_TRUE(mStackArena, NS_ERROR_UNEXPECTED);
mStackArena = new StackArena();
if (!mStackArena)
return NS_ERROR_OUT_OF_MEMORY;
}
return mStackArena->Pop(); return mStackArena->Pop();
} }