Fixed the bug that caused the "vnode already exists with different cookie"

crash: bfs_inode::InitCheck() didn't check INODE_DELETED, and Inode::Remove()
didn't clear the INODE_IN_USE flag (as the original BFS, IIRC).
Some more debug output and checks.


git-svn-id: file:///srv/svn/repos/haiku/trunk/current@6416 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
Axel Dörfler 2004-01-29 22:14:07 +00:00
parent 55ba8e3830
commit 73e3e50c41

View File

@ -148,6 +148,8 @@ bfs_inode::InitCheck(Volume *volume)
// the other fields may not yet contain valid values // the other fields may not yet contain valid values
return B_BUSY; return B_BUSY;
} }
if (Flags() & INODE_DELETED)
return B_NOT_ALLOWED;
if (Magic1() != INODE_MAGIC1 if (Magic1() != INODE_MAGIC1
|| !(Flags() & INODE_IN_USE) || !(Flags() & INODE_IN_USE)
@ -1681,6 +1683,8 @@ Inode::Trim(Transaction *transaction)
status_t status_t
Inode::Free(Transaction *transaction) Inode::Free(Transaction *transaction)
{ {
FUNCTION();
// Perhaps there should be an implementation of Inode::ShrinkStream() that // Perhaps there should be an implementation of Inode::ShrinkStream() that
// just frees the data_stream, but doesn't change the inode (since it is // just frees the data_stream, but doesn't change the inode (since it is
// freed anyway) - that would make an undelete command possible // freed anyway) - that would make an undelete command possible
@ -1850,8 +1854,15 @@ Inode::Remove(Transaction *transaction, const char *name, off_t *_id, bool isDir
RETURN_ERROR(B_ERROR); RETURN_ERROR(B_ERROR);
} }
#ifdef DEBUG
if (tree->Find((uint8 *)name, (uint16)strlen(name), &id) == B_OK) {
DIE(("deleted entry still there"));
}
#endif
// update the inode, so that no one will ever doubt it's deleted :-) // update the inode, so that no one will ever doubt it's deleted :-)
inode->Node()->flags |= HOST_ENDIAN_TO_BFS_INT32(INODE_DELETED); inode->Node()->flags |= HOST_ENDIAN_TO_BFS_INT32(INODE_DELETED);
inode->Node()->flags &= ~HOST_ENDIAN_TO_BFS_INT32(INODE_IN_USE);
// In balance to the Inode::Create() method, the main indices // In balance to the Inode::Create() method, the main indices
// are updated here (name, size, & last_modified) // are updated here (name, size, & last_modified)
@ -1893,6 +1904,8 @@ status_t
Inode::Create(Transaction *transaction, Inode *parent, const char *name, int32 mode, Inode::Create(Transaction *transaction, Inode *parent, const char *name, int32 mode,
int omode, uint32 type, off_t *_id, Inode **_inode) int omode, uint32 type, off_t *_id, Inode **_inode)
{ {
FUNCTION();
block_run parentRun = parent ? parent->BlockRun() : block_run::Run(0, 0, 0); block_run parentRun = parent ? parent->BlockRun() : block_run::Run(0, 0, 0);
Volume *volume = transaction->GetVolume(); Volume *volume = transaction->GetVolume();
BPlusTree *tree = NULL; BPlusTree *tree = NULL;