2007-12-01 00:00:00 +00:00
|
|
|
/*
|
2008-07-02 12:55:16 -07:00
|
|
|
* Copyright 2001-2008 Sun Microsystems, Inc. All Rights Reserved.
|
2007-12-01 00:00:00 +00:00
|
|
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
|
|
|
*
|
|
|
|
* This code is free software; you can redistribute it and/or modify it
|
|
|
|
* under the terms of the GNU General Public License version 2 only, as
|
|
|
|
* published by the Free Software Foundation.
|
|
|
|
*
|
|
|
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
|
|
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
|
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
|
|
|
* version 2 for more details (a copy is included in the LICENSE file that
|
|
|
|
* accompanied this code).
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License version
|
|
|
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
|
|
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
|
|
*
|
|
|
|
* Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
|
|
|
|
* CA 95054 USA or visit www.sun.com if you need additional information or
|
|
|
|
* have any questions.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
inline OopsInGenClosure::OopsInGenClosure(Generation* gen) :
|
|
|
|
OopClosure(gen->ref_processor()), _orig_gen(gen), _rs(NULL) {
|
|
|
|
set_generation(gen);
|
|
|
|
}
|
|
|
|
|
|
|
|
inline void OopsInGenClosure::set_generation(Generation* gen) {
|
|
|
|
_gen = gen;
|
|
|
|
_gen_boundary = _gen->reserved().start();
|
|
|
|
// Barrier set for the heap, must be set after heap is initialized
|
|
|
|
if (_rs == NULL) {
|
|
|
|
GenRemSet* rs = SharedHeap::heap()->rem_set();
|
|
|
|
assert(rs->rs_kind() == GenRemSet::CardTable, "Wrong rem set kind");
|
|
|
|
_rs = (CardTableRS*)rs;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
Compressed oops in instances, arrays, and headers. Code contributors are coleenp, phh, never, swamyv
Reviewed-by: jmasa, kamg, acorn, tbell, kvn, rasbold
2008-04-13 17:43:42 -04:00
|
|
|
template <class T> inline void OopsInGenClosure::do_barrier(T* p) {
|
2007-12-01 00:00:00 +00:00
|
|
|
assert(generation()->is_in_reserved(p), "expected ref in generation");
|
2009-07-14 15:40:39 -07:00
|
|
|
T heap_oop = oopDesc::load_heap_oop(p);
|
|
|
|
assert(!oopDesc::is_null(heap_oop), "expected non-null oop");
|
|
|
|
oop obj = oopDesc::decode_heap_oop_not_null(heap_oop);
|
2007-12-01 00:00:00 +00:00
|
|
|
// If p points to a younger generation, mark the card.
|
|
|
|
if ((HeapWord*)obj < _gen_boundary) {
|
|
|
|
_rs->inline_write_ref_field_gc(p, obj);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2009-07-14 15:40:39 -07:00
|
|
|
template <class T> inline void OopsInGenClosure::par_do_barrier(T* p) {
|
2008-06-05 15:57:56 -07:00
|
|
|
assert(generation()->is_in_reserved(p), "expected ref in generation");
|
2009-07-14 15:40:39 -07:00
|
|
|
T heap_oop = oopDesc::load_heap_oop(p);
|
|
|
|
assert(!oopDesc::is_null(heap_oop), "expected non-null oop");
|
|
|
|
oop obj = oopDesc::decode_heap_oop_not_null(heap_oop);
|
2008-06-05 15:57:56 -07:00
|
|
|
// If p points to a younger generation, mark the card.
|
|
|
|
if ((HeapWord*)obj < gen_boundary()) {
|
|
|
|
rs()->write_ref_field_gc_par(p, obj);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2007-12-01 00:00:00 +00:00
|
|
|
// NOTE! Any changes made here should also be made
|
6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
Compressed oops in instances, arrays, and headers. Code contributors are coleenp, phh, never, swamyv
Reviewed-by: jmasa, kamg, acorn, tbell, kvn, rasbold
2008-04-13 17:43:42 -04:00
|
|
|
// in FastScanClosure::do_oop_work()
|
|
|
|
template <class T> inline void ScanClosure::do_oop_work(T* p) {
|
|
|
|
T heap_oop = oopDesc::load_heap_oop(p);
|
2007-12-01 00:00:00 +00:00
|
|
|
// Should we copy the obj?
|
6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
Compressed oops in instances, arrays, and headers. Code contributors are coleenp, phh, never, swamyv
Reviewed-by: jmasa, kamg, acorn, tbell, kvn, rasbold
2008-04-13 17:43:42 -04:00
|
|
|
if (!oopDesc::is_null(heap_oop)) {
|
|
|
|
oop obj = oopDesc::decode_heap_oop_not_null(heap_oop);
|
2007-12-01 00:00:00 +00:00
|
|
|
if ((HeapWord*)obj < _boundary) {
|
|
|
|
assert(!_g->to()->is_in_reserved(obj), "Scanning field twice?");
|
6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
Compressed oops in instances, arrays, and headers. Code contributors are coleenp, phh, never, swamyv
Reviewed-by: jmasa, kamg, acorn, tbell, kvn, rasbold
2008-04-13 17:43:42 -04:00
|
|
|
oop new_obj = obj->is_forwarded() ? obj->forwardee()
|
|
|
|
: _g->copy_to_survivor_space(obj);
|
|
|
|
oopDesc::encode_store_heap_oop_not_null(p, new_obj);
|
2007-12-01 00:00:00 +00:00
|
|
|
}
|
|
|
|
if (_gc_barrier) {
|
|
|
|
// Now call parent closure
|
|
|
|
do_barrier(p);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
Compressed oops in instances, arrays, and headers. Code contributors are coleenp, phh, never, swamyv
Reviewed-by: jmasa, kamg, acorn, tbell, kvn, rasbold
2008-04-13 17:43:42 -04:00
|
|
|
inline void ScanClosure::do_oop_nv(oop* p) { ScanClosure::do_oop_work(p); }
|
|
|
|
inline void ScanClosure::do_oop_nv(narrowOop* p) { ScanClosure::do_oop_work(p); }
|
2007-12-01 00:00:00 +00:00
|
|
|
|
|
|
|
// NOTE! Any changes made here should also be made
|
6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
Compressed oops in instances, arrays, and headers. Code contributors are coleenp, phh, never, swamyv
Reviewed-by: jmasa, kamg, acorn, tbell, kvn, rasbold
2008-04-13 17:43:42 -04:00
|
|
|
// in ScanClosure::do_oop_work()
|
|
|
|
template <class T> inline void FastScanClosure::do_oop_work(T* p) {
|
|
|
|
T heap_oop = oopDesc::load_heap_oop(p);
|
2007-12-01 00:00:00 +00:00
|
|
|
// Should we copy the obj?
|
6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
Compressed oops in instances, arrays, and headers. Code contributors are coleenp, phh, never, swamyv
Reviewed-by: jmasa, kamg, acorn, tbell, kvn, rasbold
2008-04-13 17:43:42 -04:00
|
|
|
if (!oopDesc::is_null(heap_oop)) {
|
|
|
|
oop obj = oopDesc::decode_heap_oop_not_null(heap_oop);
|
2007-12-01 00:00:00 +00:00
|
|
|
if ((HeapWord*)obj < _boundary) {
|
|
|
|
assert(!_g->to()->is_in_reserved(obj), "Scanning field twice?");
|
6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
Compressed oops in instances, arrays, and headers. Code contributors are coleenp, phh, never, swamyv
Reviewed-by: jmasa, kamg, acorn, tbell, kvn, rasbold
2008-04-13 17:43:42 -04:00
|
|
|
oop new_obj = obj->is_forwarded() ? obj->forwardee()
|
|
|
|
: _g->copy_to_survivor_space(obj);
|
|
|
|
oopDesc::encode_store_heap_oop_not_null(p, new_obj);
|
2007-12-01 00:00:00 +00:00
|
|
|
if (_gc_barrier) {
|
|
|
|
// Now call parent closure
|
|
|
|
do_barrier(p);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
Compressed oops in instances, arrays, and headers. Code contributors are coleenp, phh, never, swamyv
Reviewed-by: jmasa, kamg, acorn, tbell, kvn, rasbold
2008-04-13 17:43:42 -04:00
|
|
|
inline void FastScanClosure::do_oop_nv(oop* p) { FastScanClosure::do_oop_work(p); }
|
|
|
|
inline void FastScanClosure::do_oop_nv(narrowOop* p) { FastScanClosure::do_oop_work(p); }
|
2007-12-01 00:00:00 +00:00
|
|
|
|
|
|
|
// Note similarity to ScanClosure; the difference is that
|
|
|
|
// the barrier set is taken care of outside this closure.
|
6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
Compressed oops in instances, arrays, and headers. Code contributors are coleenp, phh, never, swamyv
Reviewed-by: jmasa, kamg, acorn, tbell, kvn, rasbold
2008-04-13 17:43:42 -04:00
|
|
|
template <class T> inline void ScanWeakRefClosure::do_oop_work(T* p) {
|
|
|
|
assert(!oopDesc::is_null(*p), "null weak reference?");
|
|
|
|
oop obj = oopDesc::load_decode_heap_oop_not_null(p);
|
2007-12-01 00:00:00 +00:00
|
|
|
// weak references are sometimes scanned twice; must check
|
|
|
|
// that to-space doesn't already contain this object
|
|
|
|
if ((HeapWord*)obj < _boundary && !_g->to()->is_in_reserved(obj)) {
|
6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
Compressed oops in instances, arrays, and headers. Code contributors are coleenp, phh, never, swamyv
Reviewed-by: jmasa, kamg, acorn, tbell, kvn, rasbold
2008-04-13 17:43:42 -04:00
|
|
|
oop new_obj = obj->is_forwarded() ? obj->forwardee()
|
|
|
|
: _g->copy_to_survivor_space(obj);
|
|
|
|
oopDesc::encode_store_heap_oop_not_null(p, new_obj);
|
2007-12-01 00:00:00 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
Compressed oops in instances, arrays, and headers. Code contributors are coleenp, phh, never, swamyv
Reviewed-by: jmasa, kamg, acorn, tbell, kvn, rasbold
2008-04-13 17:43:42 -04:00
|
|
|
inline void ScanWeakRefClosure::do_oop_nv(oop* p) { ScanWeakRefClosure::do_oop_work(p); }
|
|
|
|
inline void ScanWeakRefClosure::do_oop_nv(narrowOop* p) { ScanWeakRefClosure::do_oop_work(p); }
|