8214377: ZGC: Don't use memset to initialize array of ZForwardingTableEntry
Reviewed-by: rkennke, eosterlund
This commit is contained in:
parent
8fc0c2f645
commit
fff6e05c96
@ -38,11 +38,18 @@ void ZForwardingTable::setup(size_t live_objects) {
|
|||||||
_size = ZUtils::round_up_power_of_2(live_objects * 2);
|
_size = ZUtils::round_up_power_of_2(live_objects * 2);
|
||||||
_table = MallocArrayAllocator<ZForwardingTableEntry>::allocate(_size, mtGC);
|
_table = MallocArrayAllocator<ZForwardingTableEntry>::allocate(_size, mtGC);
|
||||||
|
|
||||||
// Clear table
|
// Construct table entries
|
||||||
memset(_table, ZForwardingTableEntry::empty(), _size * sizeof(ZForwardingTableEntry));
|
for (size_t i = 0; i < _size; i++) {
|
||||||
|
::new (_table + i) ZForwardingTableEntry();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void ZForwardingTable::reset() {
|
void ZForwardingTable::reset() {
|
||||||
|
// Destruct table entries
|
||||||
|
for (size_t i = 0; i < _size; i++) {
|
||||||
|
(_table + i)->~ZForwardingTableEntry();
|
||||||
|
}
|
||||||
|
|
||||||
// Free table
|
// Free table
|
||||||
MallocArrayAllocator<ZForwardingTableEntry>::free(_table);
|
MallocArrayAllocator<ZForwardingTableEntry>::free(_table);
|
||||||
_table = NULL;
|
_table = NULL;
|
||||||
|
@ -52,6 +52,10 @@ private:
|
|||||||
|
|
||||||
uint64_t _entry;
|
uint64_t _entry;
|
||||||
|
|
||||||
|
static uintptr_t empty() {
|
||||||
|
return (uintptr_t)-1;
|
||||||
|
}
|
||||||
|
|
||||||
public:
|
public:
|
||||||
ZForwardingTableEntry() :
|
ZForwardingTableEntry() :
|
||||||
_entry(empty()) {}
|
_entry(empty()) {}
|
||||||
@ -60,10 +64,6 @@ public:
|
|||||||
_entry(field_from_index::encode(from_index) |
|
_entry(field_from_index::encode(from_index) |
|
||||||
field_to_offset::encode(to_offset)) {}
|
field_to_offset::encode(to_offset)) {}
|
||||||
|
|
||||||
static uintptr_t empty() {
|
|
||||||
return (uintptr_t)-1;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool is_empty() const {
|
bool is_empty() const {
|
||||||
return _entry == empty();
|
return _entry == empty();
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user