From e230719ad3cc9e70511d7baa6338bb77cd038139 Mon Sep 17 00:00:00 2001 From: Coleen Phillimore Date: Wed, 17 Aug 2022 12:18:05 +0000 Subject: [PATCH] 8292448: Convert BitMapFragmentTable to ResourceHashtable Reviewed-by: iklam, rehn --- src/hotspot/share/utilities/hashtable.cpp | 1 - src/hotspot/share/utilities/objectBitSet.hpp | 38 +++--------- .../share/utilities/objectBitSet.inline.hpp | 59 ++----------------- 3 files changed, 13 insertions(+), 85 deletions(-) diff --git a/src/hotspot/share/utilities/hashtable.cpp b/src/hotspot/share/utilities/hashtable.cpp index cd8fa94629c..7ac9ccffdc2 100644 --- a/src/hotspot/share/utilities/hashtable.cpp +++ b/src/hotspot/share/utilities/hashtable.cpp @@ -278,7 +278,6 @@ template class BasicHashtable; template class BasicHashtable; template class BasicHashtable; template class BasicHashtable; -template class BasicHashtable; template class BasicHashtable; template class BasicHashtable; diff --git a/src/hotspot/share/utilities/objectBitSet.hpp b/src/hotspot/share/utilities/objectBitSet.hpp index aa884683ea1..bca809f28bb 100644 --- a/src/hotspot/share/utilities/objectBitSet.hpp +++ b/src/hotspot/share/utilities/objectBitSet.hpp @@ -29,7 +29,7 @@ #include "oops/oop.hpp" #include "oops/oopsHierarchy.hpp" #include "utilities/bitMap.hpp" -#include "utilities/hashtable.hpp" +#include "utilities/resizeableResourceHash.hpp" class MemRegion; @@ -47,37 +47,13 @@ class ObjectBitSet : public CHeapObj { class BitMapFragment; - class BitMapFragmentTable : public BasicHashtable { - class Entry : public BasicHashtableEntry { - public: - uintptr_t _key; - CHeapBitMap* _value; + static unsigned hash_segment(const uintptr_t& key) { + unsigned hash = (unsigned)key; + return hash ^ (hash >> 3); + } - Entry* next() { - return (Entry*)BasicHashtableEntry::next(); - } - }; - - protected: - Entry* bucket(int i) const; - - Entry* new_entry(unsigned int hashValue, uintptr_t key, CHeapBitMap* value); - - unsigned hash_segment(uintptr_t key) { - unsigned hash = (unsigned)key; - return hash ^ (hash >> 3); - } - - unsigned hash_to_index(unsigned hash) { - return hash & (BasicHashtable::table_size() - 1); - } - - public: - BitMapFragmentTable(int table_size) : BasicHashtable(table_size, sizeof(Entry)) {} - ~BitMapFragmentTable(); - void add(uintptr_t key, CHeapBitMap* value); - CHeapBitMap** lookup(uintptr_t key); - }; + typedef ResizeableResourceHashtable BitMapFragmentTable; CHeapBitMap* get_fragment_bits(uintptr_t addr); diff --git a/src/hotspot/share/utilities/objectBitSet.inline.hpp b/src/hotspot/share/utilities/objectBitSet.inline.hpp index e03f243c722..e7ddfee83a9 100644 --- a/src/hotspot/share/utilities/objectBitSet.inline.hpp +++ b/src/hotspot/share/utilities/objectBitSet.inline.hpp @@ -29,7 +29,6 @@ #include "memory/memRegion.hpp" #include "utilities/bitMap.inline.hpp" -#include "utilities/hashtable.inline.hpp" template ObjectBitSet::BitMapFragment::BitMapFragment(uintptr_t granule, BitMapFragment* next) : @@ -39,7 +38,7 @@ ObjectBitSet::BitMapFragment::BitMapFragment(uintptr_t granule, BitMapFragmen template ObjectBitSet::ObjectBitSet() : - _bitmap_fragments(32), + _bitmap_fragments(32, 8*K), _fragment_list(NULL), _last_fragment_bits(NULL), _last_fragment_granule(UINTPTR_MAX) { @@ -53,52 +52,8 @@ ObjectBitSet::~ObjectBitSet() { delete current; current = next; } -} - -template -ObjectBitSet::BitMapFragmentTable::~BitMapFragmentTable() { - for (int index = 0; index < BasicHashtable::table_size(); index ++) { - Entry* e = bucket(index); - while (e != nullptr) { - Entry* tmp = e; - e = e->next(); - BasicHashtable::free_entry(tmp); - } - } -} - -template -inline typename ObjectBitSet::BitMapFragmentTable::Entry* ObjectBitSet::BitMapFragmentTable::bucket(int i) const { - return (Entry*)BasicHashtable::bucket(i); -} - -template -inline typename ObjectBitSet::BitMapFragmentTable::Entry* - ObjectBitSet::BitMapFragmentTable::new_entry(unsigned int hash, uintptr_t key, CHeapBitMap* value) { - - Entry* entry = (Entry*)BasicHashtable::new_entry(hash); - entry->_key = key; - entry->_value = value; - return entry; -} - -template -inline void ObjectBitSet::BitMapFragmentTable::add(uintptr_t key, CHeapBitMap* value) { - unsigned hash = hash_segment(key); - Entry* entry = new_entry(hash, key, value); - BasicHashtable::add_entry(hash_to_index(hash), entry); -} - -template -inline CHeapBitMap** ObjectBitSet::BitMapFragmentTable::lookup(uintptr_t key) { - unsigned hash = hash_segment(key); - int index = hash_to_index(hash); - for (Entry* e = bucket(index); e != NULL; e = e->next()) { - if (e->hash() == hash && e->_key == key) { - return &(e->_value); - } - } - return NULL; + // destructors for ResourceHashtable base deletes nodes, and + // ResizeableResourceHashtableStorage deletes the table. } template @@ -114,17 +69,15 @@ inline CHeapBitMap* ObjectBitSet::get_fragment_bits(uintptr_t addr) { } CHeapBitMap* bits = NULL; - CHeapBitMap** found = _bitmap_fragments.lookup(granule); + CHeapBitMap** found = _bitmap_fragments.get(granule); if (found != NULL) { bits = *found; } else { BitMapFragment* fragment = new BitMapFragment(granule, _fragment_list); bits = fragment->bits(); _fragment_list = fragment; - if (_bitmap_fragments.number_of_entries() * 100 / _bitmap_fragments.table_size() > 25) { - _bitmap_fragments.resize(_bitmap_fragments.table_size() * 2); - } - _bitmap_fragments.add(granule, bits); + _bitmap_fragments.put(granule, bits); + _bitmap_fragments.maybe_grow(); } _last_fragment_bits = bits;