ext2: migrate to BOpenHashTable.

This commit is contained in:
Adrien Destugues 2015-01-12 18:20:22 +01:00
parent f9defd4526
commit 63fdcb8e7e
2 changed files with 49 additions and 25 deletions

View File

@ -33,16 +33,16 @@ HashRevokeManager::~HashRevokeManager()
{
if (fHash != NULL) {
if (fRevokeCount != 0) {
RevokeElement *element =
(RevokeElement*)hash_remove_first(fHash, NULL);
RevokeElement *element = fHash->Clear(true);
while (element != NULL) {
RevokeElement* next = element->next;
delete element;
element = (RevokeElement*)hash_remove_first(fHash, NULL);
element = next;
}
}
hash_uninit(fHash);
delete fHash;
}
}
@ -50,13 +50,9 @@ HashRevokeManager::~HashRevokeManager()
status_t
HashRevokeManager::Init()
{
RevokeElement dummyElement;
fHash = hash_init(kInitialHashSize, offset_of_member(dummyElement, next),
&HashRevokeManager::Compare,
&HashRevokeManager::Hash);
fHash = new(std::nothrow) RevokeTable();
if (fHash == NULL)
if (fHash == NULL || fHash->Init(kInitialHashSize) != B_OK)
return B_NO_MEMORY;
return B_OK;
@ -66,20 +62,19 @@ HashRevokeManager::Init()
status_t
HashRevokeManager::Insert(uint32 block, uint32 commitID)
{
RevokeElement* element = (RevokeElement*)hash_lookup(fHash, &block);
RevokeElement* element = fHash->Lookup(block);
if (element != NULL) {
TRACE("HashRevokeManager::Insert(): Already has an element\n");
if (element->commitID < commitID) {
TRACE("HashRevokeManager::Insert(): Deleting previous element\n");
status_t retValue = hash_remove(fHash, element);
bool retValue = fHash->Remove(element);
if (retValue != B_OK)
return retValue;
if (!retValue)
return B_ERROR;
delete element;
}
else {
} else {
return B_OK;
// We already have a newer version of the block
}
@ -92,24 +87,24 @@ HashRevokeManager::Insert(uint32 block, uint32 commitID)
status_t
HashRevokeManager::Remove(uint32 block)
{
RevokeElement* element = (RevokeElement*)hash_lookup(fHash, &block);
RevokeElement* element = fHash->Lookup(block);
if (element == NULL)
return B_ERROR; // TODO: Perhaps we should just ignore?
status_t retValue = hash_remove(fHash, element);
bool retValue = fHash->Remove(element);
if (retValue == B_OK)
if (retValue)
delete element;
return retValue;
return B_ERROR;
}
bool
HashRevokeManager::Lookup(uint32 block, uint32 commitID)
{
RevokeElement* element = (RevokeElement*)hash_lookup(fHash, &block);
RevokeElement* element = fHash->Lookup(block);
if (element == NULL)
return false;
@ -157,7 +152,7 @@ HashRevokeManager::_ForceInsert(uint32 block, uint32 commitID)
element->block = block;
element->commitID = commitID;
status_t retValue = hash_insert_grow(fHash, element);
status_t retValue = fHash->Insert(element);
if (retValue == B_OK) {
fRevokeCount++;

View File

@ -8,7 +8,7 @@
#ifndef HASHREVOKEMANAGER_H
#define HASHREVOKEMANAGER_H
#include <util/khash.h>
#include <util/OpenHashTable.h>
#include "RevokeManager.h"
@ -20,6 +20,35 @@ struct RevokeElement {
};
struct RevokeHash {
typedef uint32 KeyType;
typedef RevokeElement ValueType;
size_t HashKey(KeyType key) const
{
return key;
}
size_t Hash(ValueType* value) const
{
return HashKey(value->block);
}
bool Compare(KeyType key, ValueType* value) const
{
return value->block == key;
}
ValueType*& GetLink(ValueType* value) const
{
return value->next;
}
};
typedef BOpenHashTable<RevokeHash> RevokeTable;
class HashRevokeManager : public RevokeManager {
public:
HashRevokeManager();
@ -30,7 +59,7 @@ public:
virtual status_t Insert(uint32 block, uint32 commitID);
virtual status_t Remove(uint32 block);
virtual bool Lookup(uint32 block, uint32 commitID);
static int Compare(void* element, const void* key);
static uint32 Hash(void* element, const void* key, uint32 range);
@ -38,7 +67,7 @@ protected:
status_t _ForceInsert(uint32 block, uint32 commitID);
private:
hash_table* fHash;
RevokeTable* fHash;
const int kInitialHashSize;
};