8232116: ZGC: Remove redundant ZLock in ZNMethodTable

Reviewed-by: stefank, pliden
This commit is contained in:
Erik Österlund 2019-10-11 13:07:21 +00:00
parent 67ebe0d274
commit 1a0e073932
5 changed files with 50 additions and 22 deletions

View File

@ -80,12 +80,16 @@ inline bool ZReentrantLock::is_owned() const {
template <typename T> template <typename T>
inline ZLocker<T>::ZLocker(T* lock) : inline ZLocker<T>::ZLocker(T* lock) :
_lock(lock) { _lock(lock) {
_lock->lock(); if (_lock != NULL) {
_lock->lock();
}
} }
template <typename T> template <typename T>
inline ZLocker<T>::~ZLocker() { inline ZLocker<T>::~ZLocker() {
_lock->unlock(); if (_lock != NULL) {
_lock->unlock();
}
} }
#endif // SHARE_GC_Z_ZLOCK_INLINE_HPP #endif // SHARE_GC_Z_ZLOCK_INLINE_HPP

View File

@ -51,7 +51,7 @@ size_t ZNMethodTable::_size = 0;
size_t ZNMethodTable::_nregistered = 0; size_t ZNMethodTable::_nregistered = 0;
size_t ZNMethodTable::_nunregistered = 0; size_t ZNMethodTable::_nunregistered = 0;
ZNMethodTableIteration ZNMethodTable::_iteration; ZNMethodTableIteration ZNMethodTable::_iteration;
ZSafeDelete<ZNMethodTableEntry[]> ZNMethodTable::_safe_delete; ZSafeDeleteNoLock<ZNMethodTableEntry[]> ZNMethodTable::_safe_delete;
size_t ZNMethodTable::first_index(const nmethod* nm, size_t size) { size_t ZNMethodTable::first_index(const nmethod* nm, size_t size) {
assert(is_power_of_2(size), "Invalid size"); assert(is_power_of_2(size), "Invalid size");

View File

@ -35,12 +35,12 @@ class ZWorkers;
class ZNMethodTable : public AllStatic { class ZNMethodTable : public AllStatic {
private: private:
static ZNMethodTableEntry* _table; static ZNMethodTableEntry* _table;
static size_t _size; static size_t _size;
static size_t _nregistered; static size_t _nregistered;
static size_t _nunregistered; static size_t _nunregistered;
static ZNMethodTableIteration _iteration; static ZNMethodTableIteration _iteration;
static ZSafeDelete<ZNMethodTableEntry[]> _safe_delete; static ZSafeDeleteNoLock<ZNMethodTableEntry[]> _safe_delete;
static ZNMethodTableEntry* create(size_t size); static ZNMethodTableEntry* create(size_t size);
static void destroy(ZNMethodTableEntry* table); static void destroy(ZNMethodTableEntry* table);

View File

@ -29,11 +29,11 @@
#include "metaprogramming/removeExtent.hpp" #include "metaprogramming/removeExtent.hpp"
template <typename T> template <typename T>
class ZSafeDelete { class ZSafeDeleteImpl {
private: private:
typedef typename RemoveExtent<T>::type ItemT; typedef typename RemoveExtent<T>::type ItemT;
ZLock _lock; ZLock* _lock;
uint64_t _enabled; uint64_t _enabled;
ZArray<ItemT*> _deferred; ZArray<ItemT*> _deferred;
@ -41,7 +41,7 @@ private:
void immediate_delete(ItemT* item); void immediate_delete(ItemT* item);
public: public:
ZSafeDelete(); ZSafeDeleteImpl(ZLock* lock);
void enable_deferred_delete(); void enable_deferred_delete();
void disable_deferred_delete(); void disable_deferred_delete();
@ -49,4 +49,19 @@ public:
void operator()(ItemT* item); void operator()(ItemT* item);
}; };
template <typename T>
class ZSafeDelete : public ZSafeDeleteImpl<T> {
private:
ZLock _lock;
public:
ZSafeDelete();
};
template <typename T>
class ZSafeDeleteNoLock : public ZSafeDeleteImpl<T> {
public:
ZSafeDeleteNoLock();
};
#endif // SHARE_GC_Z_ZSAFEDELETE_HPP #endif // SHARE_GC_Z_ZSAFEDELETE_HPP

View File

@ -30,14 +30,14 @@
#include "utilities/debug.hpp" #include "utilities/debug.hpp"
template <typename T> template <typename T>
ZSafeDelete<T>::ZSafeDelete() : ZSafeDeleteImpl<T>::ZSafeDeleteImpl(ZLock* lock) :
_lock(), _lock(lock),
_enabled(0), _enabled(0),
_deferred() {} _deferred() {}
template <typename T> template <typename T>
bool ZSafeDelete<T>::deferred_delete(ItemT* item) { bool ZSafeDeleteImpl<T>::deferred_delete(ItemT* item) {
ZLocker<ZLock> locker(&_lock); ZLocker<ZLock> locker(_lock);
if (_enabled > 0) { if (_enabled > 0) {
_deferred.add(item); _deferred.add(item);
return true; return true;
@ -47,7 +47,7 @@ bool ZSafeDelete<T>::deferred_delete(ItemT* item) {
} }
template <typename T> template <typename T>
void ZSafeDelete<T>::immediate_delete(ItemT* item) { void ZSafeDeleteImpl<T>::immediate_delete(ItemT* item) {
if (IsArray<T>::value) { if (IsArray<T>::value) {
delete [] item; delete [] item;
} else { } else {
@ -56,17 +56,17 @@ void ZSafeDelete<T>::immediate_delete(ItemT* item) {
} }
template <typename T> template <typename T>
void ZSafeDelete<T>::enable_deferred_delete() { void ZSafeDeleteImpl<T>::enable_deferred_delete() {
ZLocker<ZLock> locker(&_lock); ZLocker<ZLock> locker(_lock);
_enabled++; _enabled++;
} }
template <typename T> template <typename T>
void ZSafeDelete<T>::disable_deferred_delete() { void ZSafeDeleteImpl<T>::disable_deferred_delete() {
ZArray<ItemT*> deferred; ZArray<ItemT*> deferred;
{ {
ZLocker<ZLock> locker(&_lock); ZLocker<ZLock> locker(_lock);
assert(_enabled > 0, "Invalid state"); assert(_enabled > 0, "Invalid state");
if (--_enabled == 0) { if (--_enabled == 0) {
deferred.transfer(&_deferred); deferred.transfer(&_deferred);
@ -80,10 +80,19 @@ void ZSafeDelete<T>::disable_deferred_delete() {
} }
template <typename T> template <typename T>
void ZSafeDelete<T>::operator()(ItemT* item) { void ZSafeDeleteImpl<T>::operator()(ItemT* item) {
if (!deferred_delete(item)) { if (!deferred_delete(item)) {
immediate_delete(item); immediate_delete(item);
} }
} }
template <typename T>
ZSafeDelete<T>::ZSafeDelete() :
ZSafeDeleteImpl<T>(&_lock),
_lock() {}
template <typename T>
ZSafeDeleteNoLock<T>::ZSafeDeleteNoLock() :
ZSafeDeleteImpl<T>(NULL) {}
#endif // SHARE_GC_Z_ZSAFEDELETE_INLINE_HPP #endif // SHARE_GC_Z_ZSAFEDELETE_INLINE_HPP