mirror of
https://github.com/openjdk/jdk.git
synced 2025-09-21 03:24:38 +02:00
6964458: Reimplement class meta-data storage to use native memory
Remove PermGen, allocate meta-data in metaspace linked to class loaders, rewrite GC walking, rewrite and rename metadata to be C++ classes Co-authored-by: Stefan Karlsson <stefan.karlsson@oracle.com> Co-authored-by: Mikael Gerdin <mikael.gerdin@oracle.com> Co-authored-by: Tom Rodriguez <tom.rodriguez@oracle.com> Reviewed-by: jmasa, stefank, never, coleenp, kvn, brutisso, mgerdin, dholmes, jrose, twisti, roland
This commit is contained in:
parent
36eee7c8c8
commit
5c58d27aac
853 changed files with 26124 additions and 82956 deletions
|
@ -1,5 +1,5 @@
|
|||
/*
|
||||
* Copyright (c) 2000, 2011, Oracle and/or its affiliates. All rights reserved.
|
||||
* Copyright (c) 2000, 2012, Oracle and/or its affiliates. All rights reserved.
|
||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||
*
|
||||
* This code is free software; you can redistribute it and/or modify it
|
||||
|
@ -98,16 +98,6 @@ bool BlockOffsetSharedArray::is_card_boundary(HeapWord* p) const {
|
|||
}
|
||||
|
||||
|
||||
void BlockOffsetSharedArray::serialize(SerializeOopClosure* soc,
|
||||
HeapWord* start, HeapWord* end) {
|
||||
assert(_offset_array[0] == 0, "objects can't cross covered areas");
|
||||
assert(start <= end, "bad address range");
|
||||
size_t start_index = index_for(start);
|
||||
size_t end_index = index_for(end-1)+1;
|
||||
soc->do_region(&_offset_array[start_index],
|
||||
(end_index - start_index) * sizeof(_offset_array[0]));
|
||||
}
|
||||
|
||||
//////////////////////////////////////////////////////////////////////
|
||||
// BlockOffsetArray
|
||||
//////////////////////////////////////////////////////////////////////
|
||||
|
@ -801,17 +791,6 @@ void BlockOffsetArrayContigSpace::zero_bottom_entry() {
|
|||
_array->set_offset_array(bottom_index, 0);
|
||||
}
|
||||
|
||||
|
||||
void BlockOffsetArrayContigSpace::serialize(SerializeOopClosure* soc) {
|
||||
if (soc->reading()) {
|
||||
// Null these values so that the serializer won't object to updating them.
|
||||
_next_offset_threshold = NULL;
|
||||
_next_offset_index = 0;
|
||||
}
|
||||
soc->do_ptr(&_next_offset_threshold);
|
||||
soc->do_size_t(&_next_offset_index);
|
||||
}
|
||||
|
||||
size_t BlockOffsetArrayContigSpace::last_active_index() const {
|
||||
size_t result = _next_offset_index - 1;
|
||||
return result >= 0 ? result : 0;
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue