From 8aa6e7538c876c62f06dd1359c77782bcd8e0b90 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Per=20Lid=C3=A9n?= Date: Mon, 18 Mar 2019 11:50:40 +0100 Subject: [PATCH] 8220596: ZGC: Convert ZNMethodData to use ZAttachedArray Reviewed-by: stefank, eosterlund --- src/hotspot/share/gc/z/zNMethodData.cpp | 24 +++++++----------------- src/hotspot/share/gc/z/zNMethodData.hpp | 13 +++++++------ 2 files changed, 14 insertions(+), 23 deletions(-) diff --git a/src/hotspot/share/gc/z/zNMethodData.cpp b/src/hotspot/share/gc/z/zNMethodData.cpp index 2b22d202b13..a1b518e13ed 100644 --- a/src/hotspot/share/gc/z/zNMethodData.cpp +++ b/src/hotspot/share/gc/z/zNMethodData.cpp @@ -22,6 +22,7 @@ */ #include "precompiled.hpp" +#include "gc/z/zAttachedArray.inline.hpp" #include "gc/z/zLock.inline.hpp" #include "gc/z/zNMethodData.hpp" #include "memory/allocation.hpp" @@ -31,40 +32,29 @@ #include "utilities/debug.hpp" #include "utilities/growableArray.hpp" -size_t ZNMethodDataOops::header_size() { - const size_t size = sizeof(ZNMethodDataOops); - assert(is_aligned(size, sizeof(oop*)), "Header misaligned"); - return size; -} - ZNMethodDataOops* ZNMethodDataOops::create(const GrowableArray& immediates, bool has_non_immediates) { - // Allocate memory for the ZNMethodDataOops object - // plus the immediate oop* array that follows right after. - const size_t size = ZNMethodDataOops::header_size() + (sizeof(oop*) * immediates.length()); - void* const mem = NEW_C_HEAP_ARRAY(uint8_t, size, mtGC); - return ::new (mem) ZNMethodDataOops(immediates, has_non_immediates); + return ::new (AttachedArray::alloc(immediates.length())) ZNMethodDataOops(immediates, has_non_immediates); } void ZNMethodDataOops::destroy(ZNMethodDataOops* oops) { - FREE_C_HEAP_ARRAY(uint8_t, oops); + AttachedArray::free(oops); } ZNMethodDataOops::ZNMethodDataOops(const GrowableArray& immediates, bool has_non_immediates) : - _nimmediates(immediates.length()), + _immediates(immediates.length()), _has_non_immediates(has_non_immediates) { // Save all immediate oops - for (size_t i = 0; i < _nimmediates; i++) { + for (size_t i = 0; i < immediates_count(); i++) { immediates_begin()[i] = immediates.at(i); } } size_t ZNMethodDataOops::immediates_count() const { - return _nimmediates; + return _immediates.length(); } oop** ZNMethodDataOops::immediates_begin() const { - // The immediate oop* array starts immediately after this object - return (oop**)((uintptr_t)this + header_size()); + return _immediates(this); } oop** ZNMethodDataOops::immediates_end() const { diff --git a/src/hotspot/share/gc/z/zNMethodData.hpp b/src/hotspot/share/gc/z/zNMethodData.hpp index ed8b9ea6e00..7afd6010554 100644 --- a/src/hotspot/share/gc/z/zNMethodData.hpp +++ b/src/hotspot/share/gc/z/zNMethodData.hpp @@ -21,23 +21,24 @@ * questions. */ +#ifndef SHARE_GC_Z_ZNMETHODDATA_HPP +#define SHARE_GC_Z_ZNMETHODDATA_HPP + +#include "gc/z/zAttachedArray.hpp" #include "gc/z/zLock.hpp" #include "memory/allocation.hpp" #include "oops/oopsHierarchy.hpp" #include "utilities/globalDefinitions.hpp" -#ifndef SHARE_GC_Z_ZNMETHODDATA_HPP -#define SHARE_GC_Z_ZNMETHODDATA_HPP - class nmethod; template class GrowableArray; class ZNMethodDataOops { private: - const size_t _nimmediates; - bool _has_non_immediates; + typedef ZAttachedArray AttachedArray; - static size_t header_size(); + const AttachedArray _immediates; + const bool _has_non_immediates; ZNMethodDataOops(const GrowableArray& immediates, bool has_non_immediates);