From fff6e05c96afaafc20b836af02adbee46b3e338c Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Per=20Lid=C3=A9n?= Date: Mon, 3 Dec 2018 14:52:49 +0100 Subject: [PATCH] 8214377: ZGC: Don't use memset to initialize array of ZForwardingTableEntry Reviewed-by: rkennke, eosterlund --- src/hotspot/share/gc/z/zForwardingTable.cpp | 11 +++++++++-- src/hotspot/share/gc/z/zForwardingTableEntry.hpp | 8 ++++---- 2 files changed, 13 insertions(+), 6 deletions(-) diff --git a/src/hotspot/share/gc/z/zForwardingTable.cpp b/src/hotspot/share/gc/z/zForwardingTable.cpp index 1222630018d..a34143d45ec 100644 --- a/src/hotspot/share/gc/z/zForwardingTable.cpp +++ b/src/hotspot/share/gc/z/zForwardingTable.cpp @@ -38,11 +38,18 @@ void ZForwardingTable::setup(size_t live_objects) { _size = ZUtils::round_up_power_of_2(live_objects * 2); _table = MallocArrayAllocator::allocate(_size, mtGC); - // Clear table - memset(_table, ZForwardingTableEntry::empty(), _size * sizeof(ZForwardingTableEntry)); + // Construct table entries + for (size_t i = 0; i < _size; i++) { + ::new (_table + i) ZForwardingTableEntry(); + } } void ZForwardingTable::reset() { + // Destruct table entries + for (size_t i = 0; i < _size; i++) { + (_table + i)->~ZForwardingTableEntry(); + } + // Free table MallocArrayAllocator::free(_table); _table = NULL; diff --git a/src/hotspot/share/gc/z/zForwardingTableEntry.hpp b/src/hotspot/share/gc/z/zForwardingTableEntry.hpp index c92f8767c53..83cd32af23a 100644 --- a/src/hotspot/share/gc/z/zForwardingTableEntry.hpp +++ b/src/hotspot/share/gc/z/zForwardingTableEntry.hpp @@ -52,6 +52,10 @@ private: uint64_t _entry; + static uintptr_t empty() { + return (uintptr_t)-1; + } + public: ZForwardingTableEntry() : _entry(empty()) {} @@ -60,10 +64,6 @@ public: _entry(field_from_index::encode(from_index) | field_to_offset::encode(to_offset)) {} - static uintptr_t empty() { - return (uintptr_t)-1; - } - bool is_empty() const { return _entry == empty(); }