8308092: Replace NULL with nullptr in gc/x
Reviewed-by: eosterlund, aboldtch, tschatzl, dholmes
This commit is contained in:
parent
682359cb48
commit
599fa774b8
@ -54,7 +54,7 @@ public:
|
|||||||
virtual void load_at(MacroAssembler* masm, DecoratorSet decorators, BasicType type,
|
virtual void load_at(MacroAssembler* masm, DecoratorSet decorators, BasicType type,
|
||||||
Register base, RegisterOrConstant ind_or_offs, Register dst,
|
Register base, RegisterOrConstant ind_or_offs, Register dst,
|
||||||
Register tmp1, Register tmp2,
|
Register tmp1, Register tmp2,
|
||||||
MacroAssembler::PreservationLevel preservation_level, Label *L_handle_null = NULL);
|
MacroAssembler::PreservationLevel preservation_level, Label *L_handle_null = nullptr);
|
||||||
|
|
||||||
#ifdef ASSERT
|
#ifdef ASSERT
|
||||||
virtual void store_at(MacroAssembler* masm, DecoratorSet decorators, BasicType type,
|
virtual void store_at(MacroAssembler* masm, DecoratorSet decorators, BasicType type,
|
||||||
|
@ -59,7 +59,7 @@ static void x_compare_and_swap(MacroAssembler& _masm, const MachNode* node,
|
|||||||
// z-specific load barrier requires strong CAS operations.
|
// z-specific load barrier requires strong CAS operations.
|
||||||
// Weak CAS operations are thus only emitted if the barrier is elided.
|
// Weak CAS operations are thus only emitted if the barrier is elided.
|
||||||
__ cmpxchgd(CCR0, tmp_xchg, oldval, newval, mem,
|
__ cmpxchgd(CCR0, tmp_xchg, oldval, newval, mem,
|
||||||
MacroAssembler::MemBarNone, MacroAssembler::cmpxchgx_hint_atomic_update(), res, NULL, true,
|
MacroAssembler::MemBarNone, MacroAssembler::cmpxchgx_hint_atomic_update(), res, nullptr, true,
|
||||||
weak && node->barrier_data() == XLoadBarrierElided);
|
weak && node->barrier_data() == XLoadBarrierElided);
|
||||||
|
|
||||||
if (node->barrier_data() != XLoadBarrierElided) {
|
if (node->barrier_data() != XLoadBarrierElided) {
|
||||||
@ -73,7 +73,7 @@ static void x_compare_and_swap(MacroAssembler& _masm, const MachNode* node,
|
|||||||
x_load_barrier_slow_path(_masm, node, Address(mem), tmp_xchg, res /* used as tmp */);
|
x_load_barrier_slow_path(_masm, node, Address(mem), tmp_xchg, res /* used as tmp */);
|
||||||
|
|
||||||
__ cmpxchgd(CCR0, tmp_xchg, oldval, newval, mem,
|
__ cmpxchgd(CCR0, tmp_xchg, oldval, newval, mem,
|
||||||
MacroAssembler::MemBarNone, MacroAssembler::cmpxchgx_hint_atomic_update(), res, NULL, true, weak);
|
MacroAssembler::MemBarNone, MacroAssembler::cmpxchgx_hint_atomic_update(), res, nullptr, true, weak);
|
||||||
|
|
||||||
__ bind(skip_barrier);
|
__ bind(skip_barrier);
|
||||||
}
|
}
|
||||||
@ -95,7 +95,7 @@ static void x_compare_and_exchange(MacroAssembler& _masm, const MachNode* node,
|
|||||||
// z-specific load barrier requires strong CAS operations.
|
// z-specific load barrier requires strong CAS operations.
|
||||||
// Weak CAS operations are thus only emitted if the barrier is elided.
|
// Weak CAS operations are thus only emitted if the barrier is elided.
|
||||||
__ cmpxchgd(CCR0, res, oldval, newval, mem,
|
__ cmpxchgd(CCR0, res, oldval, newval, mem,
|
||||||
MacroAssembler::MemBarNone, MacroAssembler::cmpxchgx_hint_atomic_update(), noreg, NULL, true,
|
MacroAssembler::MemBarNone, MacroAssembler::cmpxchgx_hint_atomic_update(), noreg, nullptr, true,
|
||||||
weak && node->barrier_data() == XLoadBarrierElided);
|
weak && node->barrier_data() == XLoadBarrierElided);
|
||||||
|
|
||||||
if (node->barrier_data() != XLoadBarrierElided) {
|
if (node->barrier_data() != XLoadBarrierElided) {
|
||||||
@ -107,7 +107,7 @@ static void x_compare_and_exchange(MacroAssembler& _masm, const MachNode* node,
|
|||||||
x_load_barrier_slow_path(_masm, node, Address(mem), res, tmp);
|
x_load_barrier_slow_path(_masm, node, Address(mem), res, tmp);
|
||||||
|
|
||||||
__ cmpxchgd(CCR0, res, oldval, newval, mem,
|
__ cmpxchgd(CCR0, res, oldval, newval, mem,
|
||||||
MacroAssembler::MemBarNone, MacroAssembler::cmpxchgx_hint_atomic_update(), noreg, NULL, true, weak);
|
MacroAssembler::MemBarNone, MacroAssembler::cmpxchgx_hint_atomic_update(), noreg, nullptr, true, weak);
|
||||||
|
|
||||||
__ bind(skip_barrier);
|
__ bind(skip_barrier);
|
||||||
}
|
}
|
||||||
|
@ -97,7 +97,7 @@ private:
|
|||||||
|
|
||||||
public:
|
public:
|
||||||
LIR_OpXLoadBarrierTest(LIR_Opr opr) :
|
LIR_OpXLoadBarrierTest(LIR_Opr opr) :
|
||||||
LIR_Op(lir_xloadbarrier_test, LIR_OprFact::illegalOpr, NULL),
|
LIR_Op(lir_xloadbarrier_test, LIR_OprFact::illegalOpr, nullptr),
|
||||||
_opr(opr) {}
|
_opr(opr) {}
|
||||||
|
|
||||||
virtual void visit(LIR_OpVisitState* state) {
|
virtual void visit(LIR_OpVisitState* state) {
|
||||||
@ -125,8 +125,8 @@ static bool barrier_needed(LIRAccess& access) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
XBarrierSetC1::XBarrierSetC1() :
|
XBarrierSetC1::XBarrierSetC1() :
|
||||||
_load_barrier_on_oop_field_preloaded_runtime_stub(NULL),
|
_load_barrier_on_oop_field_preloaded_runtime_stub(nullptr),
|
||||||
_load_barrier_on_weak_oop_field_preloaded_runtime_stub(NULL) {}
|
_load_barrier_on_weak_oop_field_preloaded_runtime_stub(nullptr) {}
|
||||||
|
|
||||||
address XBarrierSetC1::load_barrier_on_oop_field_preloaded_runtime_stub(DecoratorSet decorators) const {
|
address XBarrierSetC1::load_barrier_on_oop_field_preloaded_runtime_stub(DecoratorSet decorators) const {
|
||||||
assert((decorators & ON_PHANTOM_OOP_REF) == 0, "Unsupported decorator");
|
assert((decorators & ON_PHANTOM_OOP_REF) == 0, "Unsupported decorator");
|
||||||
@ -189,8 +189,8 @@ static void pre_load_barrier(LIRAccess& access) {
|
|||||||
access.base().item(),
|
access.base().item(),
|
||||||
access.offset().opr(),
|
access.offset().opr(),
|
||||||
access.gen()->new_register(access.type()),
|
access.gen()->new_register(access.type()),
|
||||||
NULL /* patch_emit_info */,
|
nullptr /* patch_emit_info */,
|
||||||
NULL /* load_emit_info */);
|
nullptr /* load_emit_info */);
|
||||||
}
|
}
|
||||||
|
|
||||||
LIR_Opr XBarrierSetC1::atomic_xchg_at_resolved(LIRAccess& access, LIRItem& value) {
|
LIR_Opr XBarrierSetC1::atomic_xchg_at_resolved(LIRAccess& access, LIRItem& value) {
|
||||||
@ -219,7 +219,7 @@ public:
|
|||||||
|
|
||||||
virtual OopMapSet* generate_code(StubAssembler* sasm) {
|
virtual OopMapSet* generate_code(StubAssembler* sasm) {
|
||||||
XBarrierSet::assembler()->generate_c1_load_barrier_runtime_stub(sasm, _decorators);
|
XBarrierSet::assembler()->generate_c1_load_barrier_runtime_stub(sasm, _decorators);
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -51,7 +51,7 @@ private:
|
|||||||
|
|
||||||
public:
|
public:
|
||||||
XBarrierSetC2State(Arena* arena) :
|
XBarrierSetC2State(Arena* arena) :
|
||||||
_stubs(new (arena) GrowableArray<XLoadBarrierStubC2*>(arena, 8, 0, NULL)),
|
_stubs(new (arena) GrowableArray<XLoadBarrierStubC2*>(arena, 8, 0, nullptr)),
|
||||||
_live(arena) {}
|
_live(arena) {}
|
||||||
|
|
||||||
GrowableArray<XLoadBarrierStubC2*>* stubs() {
|
GrowableArray<XLoadBarrierStubC2*>* stubs() {
|
||||||
@ -61,17 +61,17 @@ public:
|
|||||||
RegMask* live(const Node* node) {
|
RegMask* live(const Node* node) {
|
||||||
if (!node->is_Mach()) {
|
if (!node->is_Mach()) {
|
||||||
// Don't need liveness for non-MachNodes
|
// Don't need liveness for non-MachNodes
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
const MachNode* const mach = node->as_Mach();
|
const MachNode* const mach = node->as_Mach();
|
||||||
if (mach->barrier_data() == XLoadBarrierElided) {
|
if (mach->barrier_data() == XLoadBarrierElided) {
|
||||||
// Don't need liveness data for nodes without barriers
|
// Don't need liveness data for nodes without barriers
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
RegMask* live = (RegMask*)_live[node->_idx];
|
RegMask* live = (RegMask*)_live[node->_idx];
|
||||||
if (live == NULL) {
|
if (live == nullptr) {
|
||||||
live = new (Compile::current()->comp_arena()->AmallocWords(sizeof(RegMask))) RegMask();
|
live = new (Compile::current()->comp_arena()->AmallocWords(sizeof(RegMask))) RegMask();
|
||||||
_live.map(node->_idx, (Node*)live);
|
_live.map(node->_idx, (Node*)live);
|
||||||
}
|
}
|
||||||
@ -136,7 +136,7 @@ address XLoadBarrierStubC2::slow_path() const {
|
|||||||
|
|
||||||
RegMask& XLoadBarrierStubC2::live() const {
|
RegMask& XLoadBarrierStubC2::live() const {
|
||||||
RegMask* mask = barrier_set_state()->live(_node);
|
RegMask* mask = barrier_set_state()->live(_node);
|
||||||
assert(mask != NULL, "must be mach-node with barrier");
|
assert(mask != nullptr, "must be mach-node with barrier");
|
||||||
return *mask;
|
return *mask;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -167,7 +167,7 @@ void XBarrierSetC2::emit_stubs(CodeBuffer& cb) const {
|
|||||||
|
|
||||||
for (int i = 0; i < stubs->length(); i++) {
|
for (int i = 0; i < stubs->length(); i++) {
|
||||||
// Make sure there is enough space in the code buffer
|
// Make sure there is enough space in the code buffer
|
||||||
if (cb.insts()->maybe_expand_to_ensure_remaining(PhaseOutput::MAX_inst_size) && cb.blob() == NULL) {
|
if (cb.insts()->maybe_expand_to_ensure_remaining(PhaseOutput::MAX_inst_size) && cb.blob() == nullptr) {
|
||||||
ciEnv::current()->record_failure("CodeCache is full");
|
ciEnv::current()->record_failure("CodeCache is full");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -272,7 +272,7 @@ void XBarrierSetC2::clone_at_expansion(PhaseMacroExpand* phase, ArrayCopyNode* a
|
|||||||
Node* const src = ac->in(ArrayCopyNode::Src);
|
Node* const src = ac->in(ArrayCopyNode::Src);
|
||||||
const TypeAryPtr* ary_ptr = src->get_ptr_type()->isa_aryptr();
|
const TypeAryPtr* ary_ptr = src->get_ptr_type()->isa_aryptr();
|
||||||
|
|
||||||
if (ac->is_clone_array() && ary_ptr != NULL) {
|
if (ac->is_clone_array() && ary_ptr != nullptr) {
|
||||||
BasicType bt = ary_ptr->elem()->array_element_basic_type();
|
BasicType bt = ary_ptr->elem()->array_element_basic_type();
|
||||||
if (is_reference_type(bt)) {
|
if (is_reference_type(bt)) {
|
||||||
// Clone object array
|
// Clone object array
|
||||||
@ -309,7 +309,7 @@ void XBarrierSetC2::clone_at_expansion(PhaseMacroExpand* phase, ArrayCopyNode* a
|
|||||||
Node* payload_dst = phase->basic_plus_adr(dest, dest_offset);
|
Node* payload_dst = phase->basic_plus_adr(dest, dest_offset);
|
||||||
|
|
||||||
const char* copyfunc_name = "arraycopy";
|
const char* copyfunc_name = "arraycopy";
|
||||||
address copyfunc_addr = phase->basictype2arraycopy(bt, NULL, NULL, true, copyfunc_name, true);
|
address copyfunc_addr = phase->basictype2arraycopy(bt, nullptr, nullptr, true, copyfunc_name, true);
|
||||||
|
|
||||||
const TypePtr* raw_adr_type = TypeRawPtr::BOTTOM;
|
const TypePtr* raw_adr_type = TypeRawPtr::BOTTOM;
|
||||||
const TypeFunc* call_type = OptoRuntime::fast_arraycopy_Type();
|
const TypeFunc* call_type = OptoRuntime::fast_arraycopy_Type();
|
||||||
@ -425,7 +425,7 @@ void XBarrierSetC2::analyze_dominating_barriers() const {
|
|||||||
// Step 2 - Find dominating accesses for each load
|
// Step 2 - Find dominating accesses for each load
|
||||||
for (uint i = 0; i < barrier_loads.size(); i++) {
|
for (uint i = 0; i < barrier_loads.size(); i++) {
|
||||||
MachNode* const load = barrier_loads.at(i)->as_Mach();
|
MachNode* const load = barrier_loads.at(i)->as_Mach();
|
||||||
const TypePtr* load_adr_type = NULL;
|
const TypePtr* load_adr_type = nullptr;
|
||||||
intptr_t load_offset = 0;
|
intptr_t load_offset = 0;
|
||||||
const Node* const load_obj = load->get_base_and_disp(load_offset, load_adr_type);
|
const Node* const load_obj = load->get_base_and_disp(load_offset, load_adr_type);
|
||||||
Block* const load_block = cfg->get_block_for_node(load);
|
Block* const load_block = cfg->get_block_for_node(load);
|
||||||
@ -433,14 +433,14 @@ void XBarrierSetC2::analyze_dominating_barriers() const {
|
|||||||
|
|
||||||
for (uint j = 0; j < mem_ops.size(); j++) {
|
for (uint j = 0; j < mem_ops.size(); j++) {
|
||||||
MachNode* mem = mem_ops.at(j)->as_Mach();
|
MachNode* mem = mem_ops.at(j)->as_Mach();
|
||||||
const TypePtr* mem_adr_type = NULL;
|
const TypePtr* mem_adr_type = nullptr;
|
||||||
intptr_t mem_offset = 0;
|
intptr_t mem_offset = 0;
|
||||||
const Node* mem_obj = mem->get_base_and_disp(mem_offset, mem_adr_type);
|
const Node* mem_obj = mem->get_base_and_disp(mem_offset, mem_adr_type);
|
||||||
Block* mem_block = cfg->get_block_for_node(mem);
|
Block* mem_block = cfg->get_block_for_node(mem);
|
||||||
uint mem_index = block_index(mem_block, mem);
|
uint mem_index = block_index(mem_block, mem);
|
||||||
|
|
||||||
if (load_obj == NodeSentinel || mem_obj == NodeSentinel ||
|
if (load_obj == NodeSentinel || mem_obj == NodeSentinel ||
|
||||||
load_obj == NULL || mem_obj == NULL ||
|
load_obj == nullptr || mem_obj == nullptr ||
|
||||||
load_offset < 0 || mem_offset < 0) {
|
load_offset < 0 || mem_offset < 0) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
@ -547,7 +547,7 @@ void XBarrierSetC2::compute_liveness_at_stubs() const {
|
|||||||
|
|
||||||
// If this node tracks liveness, update it
|
// If this node tracks liveness, update it
|
||||||
RegMask* const regs = barrier_set_state()->live(node);
|
RegMask* const regs = barrier_set_state()->live(node);
|
||||||
if (regs != NULL) {
|
if (regs != nullptr) {
|
||||||
regs->OR(new_live);
|
regs->OR(new_live);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -67,7 +67,7 @@ inline XArrayIteratorImpl<T, Parallel>::XArrayIteratorImpl(const T* array, size_
|
|||||||
|
|
||||||
template <typename T, bool Parallel>
|
template <typename T, bool Parallel>
|
||||||
inline XArrayIteratorImpl<T, Parallel>::XArrayIteratorImpl(const XArray<T>* array) :
|
inline XArrayIteratorImpl<T, Parallel>::XArrayIteratorImpl(const XArray<T>* array) :
|
||||||
XArrayIteratorImpl<T, Parallel>(array->is_empty() ? NULL : array->adr_at(0), array->length()) {}
|
XArrayIteratorImpl<T, Parallel>(array->is_empty() ? nullptr : array->adr_at(0), array->length()) {}
|
||||||
|
|
||||||
template <typename T, bool Parallel>
|
template <typename T, bool Parallel>
|
||||||
inline bool XArrayIteratorImpl<T, Parallel>::next(T* elem) {
|
inline bool XArrayIteratorImpl<T, Parallel>::next(T* elem) {
|
||||||
|
@ -215,12 +215,12 @@ uintptr_t XBarrier::mark_barrier_on_finalizable_oop_slow_path(uintptr_t addr) {
|
|||||||
//
|
//
|
||||||
oop XBarrier::load_barrier_on_oop_field(volatile narrowOop* p) {
|
oop XBarrier::load_barrier_on_oop_field(volatile narrowOop* p) {
|
||||||
ShouldNotReachHere();
|
ShouldNotReachHere();
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
oop XBarrier::load_barrier_on_oop_field_preloaded(volatile narrowOop* p, oop o) {
|
oop XBarrier::load_barrier_on_oop_field_preloaded(volatile narrowOop* p, oop o) {
|
||||||
ShouldNotReachHere();
|
ShouldNotReachHere();
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
void XBarrier::load_barrier_on_oop_array(volatile narrowOop* p, size_t length) {
|
void XBarrier::load_barrier_on_oop_array(volatile narrowOop* p, size_t length) {
|
||||||
@ -229,12 +229,12 @@ void XBarrier::load_barrier_on_oop_array(volatile narrowOop* p, size_t length) {
|
|||||||
|
|
||||||
oop XBarrier::load_barrier_on_weak_oop_field_preloaded(volatile narrowOop* p, oop o) {
|
oop XBarrier::load_barrier_on_weak_oop_field_preloaded(volatile narrowOop* p, oop o) {
|
||||||
ShouldNotReachHere();
|
ShouldNotReachHere();
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
oop XBarrier::load_barrier_on_phantom_oop_field_preloaded(volatile narrowOop* p, oop o) {
|
oop XBarrier::load_barrier_on_phantom_oop_field_preloaded(volatile narrowOop* p, oop o) {
|
||||||
ShouldNotReachHere();
|
ShouldNotReachHere();
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
oop XBarrier::weak_load_barrier_on_oop_field_preloaded(volatile narrowOop* p, oop o) {
|
oop XBarrier::weak_load_barrier_on_oop_field_preloaded(volatile narrowOop* p, oop o) {
|
||||||
@ -244,19 +244,19 @@ oop XBarrier::weak_load_barrier_on_oop_field_preloaded(volatile narrowOop* p, oo
|
|||||||
|
|
||||||
oop XBarrier::weak_load_barrier_on_weak_oop_field_preloaded(volatile narrowOop* p, oop o) {
|
oop XBarrier::weak_load_barrier_on_weak_oop_field_preloaded(volatile narrowOop* p, oop o) {
|
||||||
ShouldNotReachHere();
|
ShouldNotReachHere();
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
oop XBarrier::weak_load_barrier_on_phantom_oop_field_preloaded(volatile narrowOop* p, oop o) {
|
oop XBarrier::weak_load_barrier_on_phantom_oop_field_preloaded(volatile narrowOop* p, oop o) {
|
||||||
ShouldNotReachHere();
|
ShouldNotReachHere();
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef ASSERT
|
#ifdef ASSERT
|
||||||
|
|
||||||
// ON_WEAK barriers should only ever be applied to j.l.r.Reference.referents.
|
// ON_WEAK barriers should only ever be applied to j.l.r.Reference.referents.
|
||||||
void XBarrier::verify_on_weak(volatile oop* referent_addr) {
|
void XBarrier::verify_on_weak(volatile oop* referent_addr) {
|
||||||
if (referent_addr != NULL) {
|
if (referent_addr != nullptr) {
|
||||||
uintptr_t base = (uintptr_t)referent_addr - java_lang_ref_Reference::referent_offset();
|
uintptr_t base = (uintptr_t)referent_addr - java_lang_ref_Reference::referent_offset();
|
||||||
oop obj = cast_to_oop(base);
|
oop obj = cast_to_oop(base);
|
||||||
assert(oopDesc::is_oop(obj), "Verification failed for: ref " PTR_FORMAT " obj: " PTR_FORMAT, (uintptr_t)referent_addr, base);
|
assert(oopDesc::is_oop(obj), "Verification failed for: ref " PTR_FORMAT " obj: " PTR_FORMAT, (uintptr_t)referent_addr, base);
|
||||||
|
@ -150,7 +150,7 @@ inline oop XBarrier::barrier(volatile oop* p, oop o) {
|
|||||||
// Slow path
|
// Slow path
|
||||||
const uintptr_t good_addr = slow_path(addr);
|
const uintptr_t good_addr = slow_path(addr);
|
||||||
|
|
||||||
if (p != NULL) {
|
if (p != nullptr) {
|
||||||
self_heal<fast_path>(p, addr, good_addr);
|
self_heal<fast_path>(p, addr, good_addr);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -171,7 +171,7 @@ inline oop XBarrier::weak_barrier(volatile oop* p, oop o) {
|
|||||||
// Slow path
|
// Slow path
|
||||||
const uintptr_t good_addr = slow_path(addr);
|
const uintptr_t good_addr = slow_path(addr);
|
||||||
|
|
||||||
if (p != NULL) {
|
if (p != nullptr) {
|
||||||
// The slow path returns a good/marked address or null, but we never mark
|
// The slow path returns a good/marked address or null, but we never mark
|
||||||
// oops in a weak load barrier so we always heal with the remapped address.
|
// oops in a weak load barrier so we always heal with the remapped address.
|
||||||
self_heal<fast_path>(p, addr, XAddress::remapped_or_null(good_addr));
|
self_heal<fast_path>(p, addr, XAddress::remapped_or_null(good_addr));
|
||||||
@ -226,7 +226,7 @@ inline bool XBarrier::during_relocate() {
|
|||||||
// Load barrier
|
// Load barrier
|
||||||
//
|
//
|
||||||
inline oop XBarrier::load_barrier_on_oop(oop o) {
|
inline oop XBarrier::load_barrier_on_oop(oop o) {
|
||||||
return load_barrier_on_oop_field_preloaded((oop*)NULL, o);
|
return load_barrier_on_oop_field_preloaded((oop*)nullptr, o);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline oop XBarrier::load_barrier_on_oop_field(volatile oop* p) {
|
inline oop XBarrier::load_barrier_on_oop_field(volatile oop* p) {
|
||||||
@ -286,7 +286,7 @@ inline oop XBarrier::weak_load_barrier_on_oop_field_preloaded(volatile oop* p, o
|
|||||||
}
|
}
|
||||||
|
|
||||||
inline oop XBarrier::weak_load_barrier_on_weak_oop(oop o) {
|
inline oop XBarrier::weak_load_barrier_on_weak_oop(oop o) {
|
||||||
return weak_load_barrier_on_weak_oop_field_preloaded((oop*)NULL, o);
|
return weak_load_barrier_on_weak_oop_field_preloaded((oop*)nullptr, o);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline oop XBarrier::weak_load_barrier_on_weak_oop_field_preloaded(volatile oop* p, oop o) {
|
inline oop XBarrier::weak_load_barrier_on_weak_oop_field_preloaded(volatile oop* p, oop o) {
|
||||||
@ -300,7 +300,7 @@ inline oop XBarrier::weak_load_barrier_on_weak_oop_field_preloaded(volatile oop*
|
|||||||
}
|
}
|
||||||
|
|
||||||
inline oop XBarrier::weak_load_barrier_on_phantom_oop(oop o) {
|
inline oop XBarrier::weak_load_barrier_on_phantom_oop(oop o) {
|
||||||
return weak_load_barrier_on_phantom_oop_field_preloaded((oop*)NULL, o);
|
return weak_load_barrier_on_phantom_oop_field_preloaded((oop*)nullptr, o);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline oop XBarrier::weak_load_barrier_on_phantom_oop_field_preloaded(volatile oop* p, oop o) {
|
inline oop XBarrier::weak_load_barrier_on_phantom_oop_field_preloaded(volatile oop* p, oop o) {
|
||||||
@ -318,14 +318,14 @@ inline bool XBarrier::is_alive_barrier_on_weak_oop(oop o) {
|
|||||||
// Check if oop is logically non-null. This operation
|
// Check if oop is logically non-null. This operation
|
||||||
// is only valid when resurrection is blocked.
|
// is only valid when resurrection is blocked.
|
||||||
assert(XResurrection::is_blocked(), "Invalid phase");
|
assert(XResurrection::is_blocked(), "Invalid phase");
|
||||||
return weak_load_barrier_on_weak_oop(o) != NULL;
|
return weak_load_barrier_on_weak_oop(o) != nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline bool XBarrier::is_alive_barrier_on_phantom_oop(oop o) {
|
inline bool XBarrier::is_alive_barrier_on_phantom_oop(oop o) {
|
||||||
// Check if oop is logically non-null. This operation
|
// Check if oop is logically non-null. This operation
|
||||||
// is only valid when resurrection is blocked.
|
// is only valid when resurrection is blocked.
|
||||||
assert(XResurrection::is_blocked(), "Invalid phase");
|
assert(XResurrection::is_blocked(), "Invalid phase");
|
||||||
return weak_load_barrier_on_phantom_oop(o) != NULL;
|
return weak_load_barrier_on_phantom_oop(o) != nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
//
|
//
|
||||||
|
@ -48,7 +48,7 @@ inline void XBarrierSet::AccessBarrier<decorators, BarrierSetT>::verify_decorato
|
|||||||
|
|
||||||
template <DecoratorSet decorators, typename BarrierSetT>
|
template <DecoratorSet decorators, typename BarrierSetT>
|
||||||
inline oop* XBarrierSet::AccessBarrier<decorators, BarrierSetT>::field_addr(oop base, ptrdiff_t offset) {
|
inline oop* XBarrierSet::AccessBarrier<decorators, BarrierSetT>::field_addr(oop base, ptrdiff_t offset) {
|
||||||
assert(base != NULL, "Invalid base");
|
assert(base != nullptr, "Invalid base");
|
||||||
return reinterpret_cast<oop*>(reinterpret_cast<intptr_t>((void*)base) + offset);
|
return reinterpret_cast<oop*>(reinterpret_cast<intptr_t>((void*)base) + offset);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -184,7 +184,7 @@ inline bool XBarrierSet::AccessBarrier<decorators, BarrierSetT>::oop_arraycopy_i
|
|||||||
if (!HasDecorator<decorators, ARRAYCOPY_CHECKCAST>::value) {
|
if (!HasDecorator<decorators, ARRAYCOPY_CHECKCAST>::value) {
|
||||||
// No check cast, bulk barrier and bulk copy
|
// No check cast, bulk barrier and bulk copy
|
||||||
XBarrier::load_barrier_on_oop_array(src, length);
|
XBarrier::load_barrier_on_oop_array(src, length);
|
||||||
return Raw::oop_arraycopy_in_heap(NULL, 0, src, NULL, 0, dst, length);
|
return Raw::oop_arraycopy_in_heap(nullptr, 0, src, NULL, 0, dst, length);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Check cast and copy each elements
|
// Check cast and copy each elements
|
||||||
|
@ -38,10 +38,10 @@ void XBarrierSetStackChunk::decode_gc_mode(stackChunkOop chunk, OopIterator* ite
|
|||||||
|
|
||||||
oop XBarrierSetStackChunk::load_oop(stackChunkOop chunk, oop* addr) {
|
oop XBarrierSetStackChunk::load_oop(stackChunkOop chunk, oop* addr) {
|
||||||
oop obj = Atomic::load(addr);
|
oop obj = Atomic::load(addr);
|
||||||
return XBarrier::load_barrier_on_oop_field_preloaded((volatile oop*)NULL, obj);
|
return XBarrier::load_barrier_on_oop_field_preloaded((volatile oop*)nullptr, obj);
|
||||||
}
|
}
|
||||||
|
|
||||||
oop XBarrierSetStackChunk::load_oop(stackChunkOop chunk, narrowOop* addr) {
|
oop XBarrierSetStackChunk::load_oop(stackChunkOop chunk, narrowOop* addr) {
|
||||||
ShouldNotReachHere();
|
ShouldNotReachHere();
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
@ -32,12 +32,12 @@
|
|||||||
#define XCPU_UNKNOWN_AFFINITY ((Thread*)-1)
|
#define XCPU_UNKNOWN_AFFINITY ((Thread*)-1)
|
||||||
#define XCPU_UNKNOWN_SELF ((Thread*)-2)
|
#define XCPU_UNKNOWN_SELF ((Thread*)-2)
|
||||||
|
|
||||||
PaddedEnd<XCPU::XCPUAffinity>* XCPU::_affinity = NULL;
|
PaddedEnd<XCPU::XCPUAffinity>* XCPU::_affinity = nullptr;
|
||||||
THREAD_LOCAL Thread* XCPU::_self = XCPU_UNKNOWN_SELF;
|
THREAD_LOCAL Thread* XCPU::_self = XCPU_UNKNOWN_SELF;
|
||||||
THREAD_LOCAL uint32_t XCPU::_cpu = 0;
|
THREAD_LOCAL uint32_t XCPU::_cpu = 0;
|
||||||
|
|
||||||
void XCPU::initialize() {
|
void XCPU::initialize() {
|
||||||
assert(_affinity == NULL, "Already initialized");
|
assert(_affinity == nullptr, "Already initialized");
|
||||||
const uint32_t ncpus = count();
|
const uint32_t ncpus = count();
|
||||||
|
|
||||||
_affinity = PaddedArray<XCPUAffinity, mtGC>::create_unfreeable(ncpus);
|
_affinity = PaddedArray<XCPUAffinity, mtGC>::create_unfreeable(ncpus);
|
||||||
|
@ -34,7 +34,7 @@ inline uint32_t XCPU::count() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
inline uint32_t XCPU::id() {
|
inline uint32_t XCPU::id() {
|
||||||
assert(_affinity != NULL, "Not initialized");
|
assert(_affinity != nullptr, "Not initialized");
|
||||||
|
|
||||||
// Fast path
|
// Fast path
|
||||||
if (_affinity[_cpu]._thread == _self) {
|
if (_affinity[_cpu]._thread == _self) {
|
||||||
|
@ -175,7 +175,7 @@ MetaWord* XCollectedHeap::satisfy_failed_metadata_allocation(ClassLoaderData* lo
|
|||||||
|
|
||||||
// Expand and retry allocation
|
// Expand and retry allocation
|
||||||
MetaWord* const result = loader_data->metaspace_non_null()->expand_and_allocate(size, mdtype);
|
MetaWord* const result = loader_data->metaspace_non_null()->expand_and_allocate(size, mdtype);
|
||||||
if (result != NULL) {
|
if (result != nullptr) {
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -157,7 +157,7 @@ XPage* XForwarding::detach_page() {
|
|||||||
|
|
||||||
// Detach and return page
|
// Detach and return page
|
||||||
XPage* const page = _page;
|
XPage* const page = _page;
|
||||||
_page = NULL;
|
_page = nullptr;
|
||||||
return page;
|
return page;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -171,7 +171,7 @@ void XForwarding::abort_page() {
|
|||||||
|
|
||||||
void XForwarding::verify() const {
|
void XForwarding::verify() const {
|
||||||
guarantee(_ref_count != 0, "Invalid reference count");
|
guarantee(_ref_count != 0, "Invalid reference count");
|
||||||
guarantee(_page != NULL, "Invalid page");
|
guarantee(_page != nullptr, "Invalid page");
|
||||||
|
|
||||||
uint32_t live_objects = 0;
|
uint32_t live_objects = 0;
|
||||||
size_t live_bytes = 0;
|
size_t live_bytes = 0;
|
||||||
|
@ -26,9 +26,9 @@
|
|||||||
#include "memory/allocation.inline.hpp"
|
#include "memory/allocation.inline.hpp"
|
||||||
|
|
||||||
XForwardingAllocator::XForwardingAllocator() :
|
XForwardingAllocator::XForwardingAllocator() :
|
||||||
_start(NULL),
|
_start(nullptr),
|
||||||
_end(NULL),
|
_end(nullptr),
|
||||||
_top(NULL) {}
|
_top(nullptr) {}
|
||||||
|
|
||||||
XForwardingAllocator::~XForwardingAllocator() {
|
XForwardingAllocator::~XForwardingAllocator() {
|
||||||
FREE_C_HEAP_ARRAY(char, _start);
|
FREE_C_HEAP_ARRAY(char, _start);
|
||||||
|
@ -44,7 +44,7 @@ inline void XForwardingTable::insert(XForwarding* forwarding) {
|
|||||||
const uintptr_t offset = forwarding->start();
|
const uintptr_t offset = forwarding->start();
|
||||||
const size_t size = forwarding->size();
|
const size_t size = forwarding->size();
|
||||||
|
|
||||||
assert(_map.get(offset) == NULL, "Invalid entry");
|
assert(_map.get(offset) == nullptr, "Invalid entry");
|
||||||
_map.put(offset, size, forwarding);
|
_map.put(offset, size, forwarding);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -53,7 +53,7 @@ inline void XForwardingTable::remove(XForwarding* forwarding) {
|
|||||||
const size_t size = forwarding->size();
|
const size_t size = forwarding->size();
|
||||||
|
|
||||||
assert(_map.get(offset) == forwarding, "Invalid entry");
|
assert(_map.get(offset) == forwarding, "Invalid entry");
|
||||||
_map.put(offset, size, NULL);
|
_map.put(offset, size, nullptr);
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif // SHARE_GC_X_XFORWARDINGTABLE_INLINE_HPP
|
#endif // SHARE_GC_X_XFORWARDINGTABLE_INLINE_HPP
|
||||||
|
@ -55,7 +55,7 @@
|
|||||||
static const XStatCounter XCounterUndoPageAllocation("Memory", "Undo Page Allocation", XStatUnitOpsPerSecond);
|
static const XStatCounter XCounterUndoPageAllocation("Memory", "Undo Page Allocation", XStatUnitOpsPerSecond);
|
||||||
static const XStatCounter XCounterOutOfMemory("Memory", "Out Of Memory", XStatUnitOpsPerSecond);
|
static const XStatCounter XCounterOutOfMemory("Memory", "Out Of Memory", XStatUnitOpsPerSecond);
|
||||||
|
|
||||||
XHeap* XHeap::_heap = NULL;
|
XHeap* XHeap::_heap = nullptr;
|
||||||
|
|
||||||
XHeap::XHeap() :
|
XHeap::XHeap() :
|
||||||
_workers(),
|
_workers(),
|
||||||
@ -71,7 +71,7 @@ XHeap::XHeap() :
|
|||||||
_unload(&_workers),
|
_unload(&_workers),
|
||||||
_serviceability(min_capacity(), max_capacity()) {
|
_serviceability(min_capacity(), max_capacity()) {
|
||||||
// Install global heap instance
|
// Install global heap instance
|
||||||
assert(_heap == NULL, "Already initialized");
|
assert(_heap == nullptr, "Already initialized");
|
||||||
_heap = this;
|
_heap = this;
|
||||||
|
|
||||||
// Update statistics
|
// Update statistics
|
||||||
@ -142,7 +142,7 @@ bool XHeap::is_in(uintptr_t addr) const {
|
|||||||
|
|
||||||
if (XAddress::is_in(addr)) {
|
if (XAddress::is_in(addr)) {
|
||||||
const XPage* const page = _page_table.get(addr);
|
const XPage* const page = _page_table.get(addr);
|
||||||
if (page != NULL) {
|
if (page != nullptr) {
|
||||||
return page->is_in(addr);
|
return page->is_in(addr);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -172,7 +172,7 @@ void XHeap::out_of_memory() {
|
|||||||
|
|
||||||
XPage* XHeap::alloc_page(uint8_t type, size_t size, XAllocationFlags flags) {
|
XPage* XHeap::alloc_page(uint8_t type, size_t size, XAllocationFlags flags) {
|
||||||
XPage* const page = _page_allocator.alloc_page(type, size, flags);
|
XPage* const page = _page_allocator.alloc_page(type, size, flags);
|
||||||
if (page != NULL) {
|
if (page != nullptr) {
|
||||||
// Insert page table entry
|
// Insert page table entry
|
||||||
_page_table.insert(page);
|
_page_table.insert(page);
|
||||||
}
|
}
|
||||||
|
@ -34,7 +34,7 @@
|
|||||||
#include "utilities/debug.hpp"
|
#include "utilities/debug.hpp"
|
||||||
|
|
||||||
inline XHeap* XHeap::heap() {
|
inline XHeap* XHeap::heap() {
|
||||||
assert(_heap != NULL, "Not initialized");
|
assert(_heap != nullptr, "Not initialized");
|
||||||
return _heap;
|
return _heap;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -89,7 +89,7 @@ inline uintptr_t XHeap::relocate_object(uintptr_t addr) {
|
|||||||
assert(XGlobalPhase == XPhaseRelocate, "Relocate not allowed");
|
assert(XGlobalPhase == XPhaseRelocate, "Relocate not allowed");
|
||||||
|
|
||||||
XForwarding* const forwarding = _forwarding_table.get(addr);
|
XForwarding* const forwarding = _forwarding_table.get(addr);
|
||||||
if (forwarding == NULL) {
|
if (forwarding == nullptr) {
|
||||||
// Not forwarding
|
// Not forwarding
|
||||||
return XAddress::good(addr);
|
return XAddress::good(addr);
|
||||||
}
|
}
|
||||||
@ -103,7 +103,7 @@ inline uintptr_t XHeap::remap_object(uintptr_t addr) {
|
|||||||
XGlobalPhase == XPhaseMarkCompleted, "Forward not allowed");
|
XGlobalPhase == XPhaseMarkCompleted, "Forward not allowed");
|
||||||
|
|
||||||
XForwarding* const forwarding = _forwarding_table.get(addr);
|
XForwarding* const forwarding = _forwarding_table.get(addr);
|
||||||
if (forwarding == NULL) {
|
if (forwarding == nullptr) {
|
||||||
// Not forwarding
|
// Not forwarding
|
||||||
return XAddress::good(addr);
|
return XAddress::good(addr);
|
||||||
}
|
}
|
||||||
|
@ -255,10 +255,10 @@ static size_t object_index(oop obj) {
|
|||||||
XHeapIteratorBitMap* XHeapIterator::object_bitmap(oop obj) {
|
XHeapIteratorBitMap* XHeapIterator::object_bitmap(oop obj) {
|
||||||
const uintptr_t offset = XAddress::offset(XOop::to_address(obj));
|
const uintptr_t offset = XAddress::offset(XOop::to_address(obj));
|
||||||
XHeapIteratorBitMap* bitmap = _bitmaps.get_acquire(offset);
|
XHeapIteratorBitMap* bitmap = _bitmaps.get_acquire(offset);
|
||||||
if (bitmap == NULL) {
|
if (bitmap == nullptr) {
|
||||||
XLocker<XLock> locker(&_bitmaps_lock);
|
XLocker<XLock> locker(&_bitmaps_lock);
|
||||||
bitmap = _bitmaps.get(offset);
|
bitmap = _bitmaps.get(offset);
|
||||||
if (bitmap == NULL) {
|
if (bitmap == nullptr) {
|
||||||
// Install new bitmap
|
// Install new bitmap
|
||||||
bitmap = new XHeapIteratorBitMap(object_index_max());
|
bitmap = new XHeapIteratorBitMap(object_index_max());
|
||||||
_bitmaps.release_put(offset, bitmap);
|
_bitmaps.release_put(offset, bitmap);
|
||||||
@ -269,7 +269,7 @@ XHeapIteratorBitMap* XHeapIterator::object_bitmap(oop obj) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
bool XHeapIterator::mark_object(oop obj) {
|
bool XHeapIterator::mark_object(oop obj) {
|
||||||
if (obj == NULL) {
|
if (obj == nullptr) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -110,12 +110,12 @@ inline bool XList<T>::is_empty() const {
|
|||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
inline T* XList<T>::first() const {
|
inline T* XList<T>::first() const {
|
||||||
return is_empty() ? NULL : cast_to_outer(_head._next);
|
return is_empty() ? nullptr : cast_to_outer(_head._next);
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
inline T* XList<T>::last() const {
|
inline T* XList<T>::last() const {
|
||||||
return is_empty() ? NULL : cast_to_outer(_head._prev);
|
return is_empty() ? nullptr : cast_to_outer(_head._prev);
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
@ -128,7 +128,7 @@ inline T* XList<T>::next(T* elem) const {
|
|||||||
XListNode<T>* const next = node->_next;
|
XListNode<T>* const next = node->_next;
|
||||||
next->verify_links_linked();
|
next->verify_links_linked();
|
||||||
|
|
||||||
return (next == &_head) ? NULL : cast_to_outer(next);
|
return (next == &_head) ? nullptr : cast_to_outer(next);
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
@ -141,7 +141,7 @@ inline T* XList<T>::prev(T* elem) const {
|
|||||||
XListNode<T>* const prev = node->_prev;
|
XListNode<T>* const prev = node->_prev;
|
||||||
prev->verify_links_linked();
|
prev->verify_links_linked();
|
||||||
|
|
||||||
return (prev == &_head) ? NULL : cast_to_outer(prev);
|
return (prev == &_head) ? nullptr : cast_to_outer(prev);
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
@ -191,7 +191,7 @@ inline void XList<T>::remove(T* elem) {
|
|||||||
template <typename T>
|
template <typename T>
|
||||||
inline T* XList<T>::remove_first() {
|
inline T* XList<T>::remove_first() {
|
||||||
T* elem = first();
|
T* elem = first();
|
||||||
if (elem != NULL) {
|
if (elem != nullptr) {
|
||||||
remove(elem);
|
remove(elem);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -201,7 +201,7 @@ inline T* XList<T>::remove_first() {
|
|||||||
template <typename T>
|
template <typename T>
|
||||||
inline T* XList<T>::remove_last() {
|
inline T* XList<T>::remove_last() {
|
||||||
T* elem = last();
|
T* elem = last();
|
||||||
if (elem != NULL) {
|
if (elem != nullptr) {
|
||||||
remove(elem);
|
remove(elem);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -215,7 +215,7 @@ inline XListIteratorImpl<T, Forward>::XListIteratorImpl(const XList<T>* list) :
|
|||||||
|
|
||||||
template <typename T, bool Forward>
|
template <typename T, bool Forward>
|
||||||
inline bool XListIteratorImpl<T, Forward>::next(T** elem) {
|
inline bool XListIteratorImpl<T, Forward>::next(T** elem) {
|
||||||
if (_next != NULL) {
|
if (_next != nullptr) {
|
||||||
*elem = _next;
|
*elem = _next;
|
||||||
_next = Forward ? _list->next(_next) : _list->prev(_next);
|
_next = Forward ? _list->next(_next) : _list->prev(_next);
|
||||||
return true;
|
return true;
|
||||||
@ -232,7 +232,7 @@ inline XListRemoveIteratorImpl<T, Forward>::XListRemoveIteratorImpl(XList<T>* li
|
|||||||
template <typename T, bool Forward>
|
template <typename T, bool Forward>
|
||||||
inline bool XListRemoveIteratorImpl<T, Forward>::next(T** elem) {
|
inline bool XListRemoveIteratorImpl<T, Forward>::next(T** elem) {
|
||||||
*elem = Forward ? _list->remove_first() : _list->remove_last();
|
*elem = Forward ? _list->remove_first() : _list->remove_last();
|
||||||
return *elem != NULL;
|
return *elem != nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif // SHARE_GC_X_XLIST_INLINE_HPP
|
#endif // SHARE_GC_X_XLIST_INLINE_HPP
|
||||||
|
@ -45,7 +45,7 @@ inline void XLock::unlock() {
|
|||||||
|
|
||||||
inline XReentrantLock::XReentrantLock() :
|
inline XReentrantLock::XReentrantLock() :
|
||||||
_lock(),
|
_lock(),
|
||||||
_owner(NULL),
|
_owner(nullptr),
|
||||||
_count(0) {}
|
_count(0) {}
|
||||||
|
|
||||||
inline void XReentrantLock::lock() {
|
inline void XReentrantLock::lock() {
|
||||||
@ -67,7 +67,7 @@ inline void XReentrantLock::unlock() {
|
|||||||
_count--;
|
_count--;
|
||||||
|
|
||||||
if (_count == 0) {
|
if (_count == 0) {
|
||||||
Atomic::store(&_owner, (Thread*)NULL);
|
Atomic::store(&_owner, (Thread*)nullptr);
|
||||||
_lock.unlock();
|
_lock.unlock();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -105,14 +105,14 @@ inline void XConditionLock::notify_all() {
|
|||||||
template <typename T>
|
template <typename T>
|
||||||
inline XLocker<T>::XLocker(T* lock) :
|
inline XLocker<T>::XLocker(T* lock) :
|
||||||
_lock(lock) {
|
_lock(lock) {
|
||||||
if (_lock != NULL) {
|
if (_lock != nullptr) {
|
||||||
_lock->lock();
|
_lock->lock();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
inline XLocker<T>::~XLocker() {
|
inline XLocker<T>::~XLocker() {
|
||||||
if (_lock != NULL) {
|
if (_lock != nullptr) {
|
||||||
_lock->unlock();
|
_lock->unlock();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -254,7 +254,7 @@ public:
|
|||||||
? ClassLoaderData::_claim_finalizable
|
? ClassLoaderData::_claim_finalizable
|
||||||
: ClassLoaderData::_claim_strong,
|
: ClassLoaderData::_claim_strong,
|
||||||
finalizable
|
finalizable
|
||||||
? NULL
|
? nullptr
|
||||||
: XHeap::heap()->reference_discoverer()) {}
|
: XHeap::heap()->reference_discoverer()) {}
|
||||||
|
|
||||||
virtual void do_oop(oop* p) {
|
virtual void do_oop(oop* p) {
|
||||||
@ -403,7 +403,7 @@ bool XMark::try_steal_local(XMarkContext* context) {
|
|||||||
victim_stripe != stripe;
|
victim_stripe != stripe;
|
||||||
victim_stripe = _stripes.stripe_next(victim_stripe)) {
|
victim_stripe = _stripes.stripe_next(victim_stripe)) {
|
||||||
XMarkStack* const stack = stacks->steal(&_stripes, victim_stripe);
|
XMarkStack* const stack = stacks->steal(&_stripes, victim_stripe);
|
||||||
if (stack != NULL) {
|
if (stack != nullptr) {
|
||||||
// Success, install the stolen stack
|
// Success, install the stolen stack
|
||||||
stacks->install(&_stripes, stripe, stack);
|
stacks->install(&_stripes, stripe, stack);
|
||||||
return true;
|
return true;
|
||||||
@ -423,7 +423,7 @@ bool XMark::try_steal_global(XMarkContext* context) {
|
|||||||
victim_stripe != stripe;
|
victim_stripe != stripe;
|
||||||
victim_stripe = _stripes.stripe_next(victim_stripe)) {
|
victim_stripe = _stripes.stripe_next(victim_stripe)) {
|
||||||
XMarkStack* const stack = victim_stripe->steal_stack();
|
XMarkStack* const stack = victim_stripe->steal_stack();
|
||||||
if (stack != NULL) {
|
if (stack != nullptr) {
|
||||||
// Success, install the stolen stack
|
// Success, install the stolen stack
|
||||||
stacks->install(&_stripes, stripe, stack);
|
stacks->install(&_stripes, stripe, stack);
|
||||||
return true;
|
return true;
|
||||||
|
@ -27,7 +27,7 @@
|
|||||||
#include "utilities/powerOfTwo.hpp"
|
#include "utilities/powerOfTwo.hpp"
|
||||||
|
|
||||||
XMarkCacheEntry::XMarkCacheEntry() :
|
XMarkCacheEntry::XMarkCacheEntry() :
|
||||||
_page(NULL),
|
_page(nullptr),
|
||||||
_objects(0),
|
_objects(0),
|
||||||
_bytes(0) {}
|
_bytes(0) {}
|
||||||
|
|
||||||
|
@ -43,10 +43,10 @@ inline void XMarkCacheEntry::inc_live(XPage* page, size_t bytes) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
inline void XMarkCacheEntry::evict() {
|
inline void XMarkCacheEntry::evict() {
|
||||||
if (_page != NULL) {
|
if (_page != nullptr) {
|
||||||
// Write cached data out to page
|
// Write cached data out to page
|
||||||
_page->inc_live(_objects, _bytes);
|
_page->inc_live(_objects, _bytes);
|
||||||
_page = NULL;
|
_page = nullptr;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -79,16 +79,16 @@ XMarkStripe* XMarkStripeSet::stripe_for_worker(uint nworkers, uint worker_id) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
XMarkThreadLocalStacks::XMarkThreadLocalStacks() :
|
XMarkThreadLocalStacks::XMarkThreadLocalStacks() :
|
||||||
_magazine(NULL) {
|
_magazine(nullptr) {
|
||||||
for (size_t i = 0; i < XMarkStripesMax; i++) {
|
for (size_t i = 0; i < XMarkStripesMax; i++) {
|
||||||
_stacks[i] = NULL;
|
_stacks[i] = nullptr;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
bool XMarkThreadLocalStacks::is_empty(const XMarkStripeSet* stripes) const {
|
bool XMarkThreadLocalStacks::is_empty(const XMarkStripeSet* stripes) const {
|
||||||
for (size_t i = 0; i < stripes->nstripes(); i++) {
|
for (size_t i = 0; i < stripes->nstripes(); i++) {
|
||||||
XMarkStack* const stack = _stacks[i];
|
XMarkStack* const stack = _stacks[i];
|
||||||
if (stack != NULL) {
|
if (stack != nullptr) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -97,21 +97,21 @@ bool XMarkThreadLocalStacks::is_empty(const XMarkStripeSet* stripes) const {
|
|||||||
}
|
}
|
||||||
|
|
||||||
XMarkStack* XMarkThreadLocalStacks::allocate_stack(XMarkStackAllocator* allocator) {
|
XMarkStack* XMarkThreadLocalStacks::allocate_stack(XMarkStackAllocator* allocator) {
|
||||||
if (_magazine == NULL) {
|
if (_magazine == nullptr) {
|
||||||
// Allocate new magazine
|
// Allocate new magazine
|
||||||
_magazine = allocator->alloc_magazine();
|
_magazine = allocator->alloc_magazine();
|
||||||
if (_magazine == NULL) {
|
if (_magazine == nullptr) {
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
XMarkStack* stack = NULL;
|
XMarkStack* stack = nullptr;
|
||||||
|
|
||||||
if (!_magazine->pop(stack)) {
|
if (!_magazine->pop(stack)) {
|
||||||
// Magazine is empty, convert magazine into a new stack
|
// Magazine is empty, convert magazine into a new stack
|
||||||
_magazine->~XMarkStackMagazine();
|
_magazine->~XMarkStackMagazine();
|
||||||
stack = new ((void*)_magazine) XMarkStack();
|
stack = new ((void*)_magazine) XMarkStack();
|
||||||
_magazine = NULL;
|
_magazine = nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
return stack;
|
return stack;
|
||||||
@ -119,7 +119,7 @@ XMarkStack* XMarkThreadLocalStacks::allocate_stack(XMarkStackAllocator* allocato
|
|||||||
|
|
||||||
void XMarkThreadLocalStacks::free_stack(XMarkStackAllocator* allocator, XMarkStack* stack) {
|
void XMarkThreadLocalStacks::free_stack(XMarkStackAllocator* allocator, XMarkStack* stack) {
|
||||||
for (;;) {
|
for (;;) {
|
||||||
if (_magazine == NULL) {
|
if (_magazine == nullptr) {
|
||||||
// Convert stack into a new magazine
|
// Convert stack into a new magazine
|
||||||
stack->~XMarkStack();
|
stack->~XMarkStack();
|
||||||
_magazine = new ((void*)stack) XMarkStackMagazine();
|
_magazine = new ((void*)stack) XMarkStackMagazine();
|
||||||
@ -133,7 +133,7 @@ void XMarkThreadLocalStacks::free_stack(XMarkStackAllocator* allocator, XMarkSta
|
|||||||
|
|
||||||
// Free and uninstall full magazine
|
// Free and uninstall full magazine
|
||||||
allocator->free_magazine(_magazine);
|
allocator->free_magazine(_magazine);
|
||||||
_magazine = NULL;
|
_magazine = nullptr;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -145,10 +145,10 @@ bool XMarkThreadLocalStacks::push_slow(XMarkStackAllocator* allocator,
|
|||||||
XMarkStack* stack = *stackp;
|
XMarkStack* stack = *stackp;
|
||||||
|
|
||||||
for (;;) {
|
for (;;) {
|
||||||
if (stack == NULL) {
|
if (stack == nullptr) {
|
||||||
// Allocate and install new stack
|
// Allocate and install new stack
|
||||||
*stackp = stack = allocate_stack(allocator);
|
*stackp = stack = allocate_stack(allocator);
|
||||||
if (stack == NULL) {
|
if (stack == nullptr) {
|
||||||
// Out of mark stack memory
|
// Out of mark stack memory
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
@ -161,7 +161,7 @@ bool XMarkThreadLocalStacks::push_slow(XMarkStackAllocator* allocator,
|
|||||||
|
|
||||||
// Publish/Overflow and uninstall stack
|
// Publish/Overflow and uninstall stack
|
||||||
stripe->publish_stack(stack, publish);
|
stripe->publish_stack(stack, publish);
|
||||||
*stackp = stack = NULL;
|
*stackp = stack = nullptr;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -172,10 +172,10 @@ bool XMarkThreadLocalStacks::pop_slow(XMarkStackAllocator* allocator,
|
|||||||
XMarkStack* stack = *stackp;
|
XMarkStack* stack = *stackp;
|
||||||
|
|
||||||
for (;;) {
|
for (;;) {
|
||||||
if (stack == NULL) {
|
if (stack == nullptr) {
|
||||||
// Try steal and install stack
|
// Try steal and install stack
|
||||||
*stackp = stack = stripe->steal_stack();
|
*stackp = stack = stripe->steal_stack();
|
||||||
if (stack == NULL) {
|
if (stack == nullptr) {
|
||||||
// Nothing to steal
|
// Nothing to steal
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
@ -188,7 +188,7 @@ bool XMarkThreadLocalStacks::pop_slow(XMarkStackAllocator* allocator,
|
|||||||
|
|
||||||
// Free and uninstall stack
|
// Free and uninstall stack
|
||||||
free_stack(allocator, stack);
|
free_stack(allocator, stack);
|
||||||
*stackp = stack = NULL;
|
*stackp = stack = nullptr;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -200,7 +200,7 @@ bool XMarkThreadLocalStacks::flush(XMarkStackAllocator* allocator, XMarkStripeSe
|
|||||||
XMarkStripe* const stripe = stripes->stripe_at(i);
|
XMarkStripe* const stripe = stripes->stripe_at(i);
|
||||||
XMarkStack** const stackp = &_stacks[i];
|
XMarkStack** const stackp = &_stacks[i];
|
||||||
XMarkStack* const stack = *stackp;
|
XMarkStack* const stack = *stackp;
|
||||||
if (stack == NULL) {
|
if (stack == nullptr) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -211,7 +211,7 @@ bool XMarkThreadLocalStacks::flush(XMarkStackAllocator* allocator, XMarkStripeSe
|
|||||||
stripe->publish_stack(stack);
|
stripe->publish_stack(stack);
|
||||||
flushed = true;
|
flushed = true;
|
||||||
}
|
}
|
||||||
*stackp = NULL;
|
*stackp = nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
return flushed;
|
return flushed;
|
||||||
@ -219,8 +219,8 @@ bool XMarkThreadLocalStacks::flush(XMarkStackAllocator* allocator, XMarkStripeSe
|
|||||||
|
|
||||||
void XMarkThreadLocalStacks::free(XMarkStackAllocator* allocator) {
|
void XMarkThreadLocalStacks::free(XMarkStackAllocator* allocator) {
|
||||||
// Free and uninstall magazine
|
// Free and uninstall magazine
|
||||||
if (_magazine != NULL) {
|
if (_magazine != nullptr) {
|
||||||
allocator->free_magazine(_magazine);
|
allocator->free_magazine(_magazine);
|
||||||
_magazine = NULL;
|
_magazine = nullptr;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -32,7 +32,7 @@
|
|||||||
template <typename T, size_t S>
|
template <typename T, size_t S>
|
||||||
inline XStack<T, S>::XStack() :
|
inline XStack<T, S>::XStack() :
|
||||||
_top(0),
|
_top(0),
|
||||||
_next(NULL) {}
|
_next(nullptr) {}
|
||||||
|
|
||||||
template <typename T, size_t S>
|
template <typename T, size_t S>
|
||||||
inline bool XStack<T, S>::is_empty() const {
|
inline bool XStack<T, S>::is_empty() const {
|
||||||
@ -76,13 +76,13 @@ inline XStack<T, S>** XStack<T, S>::next_addr() {
|
|||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
inline XStackList<T>::XStackList() :
|
inline XStackList<T>::XStackList() :
|
||||||
_head(encode_versioned_pointer(NULL, 0)) {}
|
_head(encode_versioned_pointer(nullptr, 0)) {}
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
inline T* XStackList<T>::encode_versioned_pointer(const T* stack, uint32_t version) const {
|
inline T* XStackList<T>::encode_versioned_pointer(const T* stack, uint32_t version) const {
|
||||||
uint64_t addr;
|
uint64_t addr;
|
||||||
|
|
||||||
if (stack == NULL) {
|
if (stack == nullptr) {
|
||||||
addr = (uint32_t)-1;
|
addr = (uint32_t)-1;
|
||||||
} else {
|
} else {
|
||||||
addr = ((uint64_t)stack - XMarkStackSpaceStart) >> XMarkStackSizeShift;
|
addr = ((uint64_t)stack - XMarkStackSpaceStart) >> XMarkStackSizeShift;
|
||||||
@ -96,7 +96,7 @@ inline void XStackList<T>::decode_versioned_pointer(const T* vstack, T** stack,
|
|||||||
const uint64_t addr = (uint64_t)vstack >> 32;
|
const uint64_t addr = (uint64_t)vstack >> 32;
|
||||||
|
|
||||||
if (addr == (uint32_t)-1) {
|
if (addr == (uint32_t)-1) {
|
||||||
*stack = NULL;
|
*stack = nullptr;
|
||||||
} else {
|
} else {
|
||||||
*stack = (T*)((addr << XMarkStackSizeShift) + XMarkStackSpaceStart);
|
*stack = (T*)((addr << XMarkStackSizeShift) + XMarkStackSpaceStart);
|
||||||
}
|
}
|
||||||
@ -107,11 +107,11 @@ inline void XStackList<T>::decode_versioned_pointer(const T* vstack, T** stack,
|
|||||||
template <typename T>
|
template <typename T>
|
||||||
inline bool XStackList<T>::is_empty() const {
|
inline bool XStackList<T>::is_empty() const {
|
||||||
const T* vstack = _head;
|
const T* vstack = _head;
|
||||||
T* stack = NULL;
|
T* stack = nullptr;
|
||||||
uint32_t version = 0;
|
uint32_t version = 0;
|
||||||
|
|
||||||
decode_versioned_pointer(vstack, &stack, &version);
|
decode_versioned_pointer(vstack, &stack, &version);
|
||||||
return stack == NULL;
|
return stack == nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
@ -136,13 +136,13 @@ inline void XStackList<T>::push(T* stack) {
|
|||||||
template <typename T>
|
template <typename T>
|
||||||
inline T* XStackList<T>::pop() {
|
inline T* XStackList<T>::pop() {
|
||||||
T* vstack = _head;
|
T* vstack = _head;
|
||||||
T* stack = NULL;
|
T* stack = nullptr;
|
||||||
uint32_t version = 0;
|
uint32_t version = 0;
|
||||||
|
|
||||||
for (;;) {
|
for (;;) {
|
||||||
decode_versioned_pointer(vstack, &stack, &version);
|
decode_versioned_pointer(vstack, &stack, &version);
|
||||||
if (stack == NULL) {
|
if (stack == nullptr) {
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
T* const new_vstack = encode_versioned_pointer(stack->next(), version + 1);
|
T* const new_vstack = encode_versioned_pointer(stack->next(), version + 1);
|
||||||
@ -159,7 +159,7 @@ inline T* XStackList<T>::pop() {
|
|||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
inline void XStackList<T>::clear() {
|
inline void XStackList<T>::clear() {
|
||||||
_head = encode_versioned_pointer(NULL, 0);
|
_head = encode_versioned_pointer(nullptr, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline bool XMarkStripe::is_empty() const {
|
inline bool XMarkStripe::is_empty() const {
|
||||||
@ -183,7 +183,7 @@ inline void XMarkStripe::publish_stack(XMarkStack* stack, bool publish) {
|
|||||||
inline XMarkStack* XMarkStripe::steal_stack() {
|
inline XMarkStack* XMarkStripe::steal_stack() {
|
||||||
// Steal overflowed stacks first, then published stacks
|
// Steal overflowed stacks first, then published stacks
|
||||||
XMarkStack* const stack = _overflowed.pop();
|
XMarkStack* const stack = _overflowed.pop();
|
||||||
if (stack != NULL) {
|
if (stack != nullptr) {
|
||||||
return stack;
|
return stack;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -221,7 +221,7 @@ inline void XMarkThreadLocalStacks::install(XMarkStripeSet* stripes,
|
|||||||
XMarkStripe* stripe,
|
XMarkStripe* stripe,
|
||||||
XMarkStack* stack) {
|
XMarkStack* stack) {
|
||||||
XMarkStack** const stackp = &_stacks[stripes->stripe_id(stripe)];
|
XMarkStack** const stackp = &_stacks[stripes->stripe_id(stripe)];
|
||||||
assert(*stackp == NULL, "Should be empty");
|
assert(*stackp == nullptr, "Should be empty");
|
||||||
*stackp = stack;
|
*stackp = stack;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -229,8 +229,8 @@ inline XMarkStack* XMarkThreadLocalStacks::steal(XMarkStripeSet* stripes,
|
|||||||
XMarkStripe* stripe) {
|
XMarkStripe* stripe) {
|
||||||
XMarkStack** const stackp = &_stacks[stripes->stripe_id(stripe)];
|
XMarkStack** const stackp = &_stacks[stripes->stripe_id(stripe)];
|
||||||
XMarkStack* const stack = *stackp;
|
XMarkStack* const stack = *stackp;
|
||||||
if (stack != NULL) {
|
if (stack != nullptr) {
|
||||||
*stackp = NULL;
|
*stackp = nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
return stack;
|
return stack;
|
||||||
@ -243,7 +243,7 @@ inline bool XMarkThreadLocalStacks::push(XMarkStackAllocator* allocator,
|
|||||||
bool publish) {
|
bool publish) {
|
||||||
XMarkStack** const stackp = &_stacks[stripes->stripe_id(stripe)];
|
XMarkStack** const stackp = &_stacks[stripes->stripe_id(stripe)];
|
||||||
XMarkStack* const stack = *stackp;
|
XMarkStack* const stack = *stackp;
|
||||||
if (stack != NULL && stack->push(entry)) {
|
if (stack != nullptr && stack->push(entry)) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -256,7 +256,7 @@ inline bool XMarkThreadLocalStacks::pop(XMarkStackAllocator* allocator,
|
|||||||
XMarkStackEntry& entry) {
|
XMarkStackEntry& entry) {
|
||||||
XMarkStack** const stackp = &_stacks[stripes->stripe_id(stripe)];
|
XMarkStack** const stackp = &_stacks[stripes->stripe_id(stripe)];
|
||||||
XMarkStack* const stack = *stackp;
|
XMarkStack* const stack = *stackp;
|
||||||
if (stack != NULL && stack->pop(entry)) {
|
if (stack != nullptr && stack->pop(entry)) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -198,14 +198,14 @@ XMarkStackMagazine* XMarkStackAllocator::create_magazine_from_space(uintptr_t ad
|
|||||||
XMarkStackMagazine* XMarkStackAllocator::alloc_magazine() {
|
XMarkStackMagazine* XMarkStackAllocator::alloc_magazine() {
|
||||||
// Try allocating from the free list first
|
// Try allocating from the free list first
|
||||||
XMarkStackMagazine* const magazine = _freelist.pop();
|
XMarkStackMagazine* const magazine = _freelist.pop();
|
||||||
if (magazine != NULL) {
|
if (magazine != nullptr) {
|
||||||
return magazine;
|
return magazine;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Allocate new magazine
|
// Allocate new magazine
|
||||||
const uintptr_t addr = _space.alloc(XMarkStackMagazineSize);
|
const uintptr_t addr = _space.alloc(XMarkStackMagazineSize);
|
||||||
if (addr == 0) {
|
if (addr == 0) {
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
return create_magazine_from_space(addr, XMarkStackMagazineSize);
|
return create_magazine_from_space(addr, XMarkStackMagazineSize);
|
||||||
|
@ -28,54 +28,54 @@
|
|||||||
|
|
||||||
XMemory* XMemoryManager::create(uintptr_t start, size_t size) {
|
XMemory* XMemoryManager::create(uintptr_t start, size_t size) {
|
||||||
XMemory* const area = new XMemory(start, size);
|
XMemory* const area = new XMemory(start, size);
|
||||||
if (_callbacks._create != NULL) {
|
if (_callbacks._create != nullptr) {
|
||||||
_callbacks._create(area);
|
_callbacks._create(area);
|
||||||
}
|
}
|
||||||
return area;
|
return area;
|
||||||
}
|
}
|
||||||
|
|
||||||
void XMemoryManager::destroy(XMemory* area) {
|
void XMemoryManager::destroy(XMemory* area) {
|
||||||
if (_callbacks._destroy != NULL) {
|
if (_callbacks._destroy != nullptr) {
|
||||||
_callbacks._destroy(area);
|
_callbacks._destroy(area);
|
||||||
}
|
}
|
||||||
delete area;
|
delete area;
|
||||||
}
|
}
|
||||||
|
|
||||||
void XMemoryManager::shrink_from_front(XMemory* area, size_t size) {
|
void XMemoryManager::shrink_from_front(XMemory* area, size_t size) {
|
||||||
if (_callbacks._shrink_from_front != NULL) {
|
if (_callbacks._shrink_from_front != nullptr) {
|
||||||
_callbacks._shrink_from_front(area, size);
|
_callbacks._shrink_from_front(area, size);
|
||||||
}
|
}
|
||||||
area->shrink_from_front(size);
|
area->shrink_from_front(size);
|
||||||
}
|
}
|
||||||
|
|
||||||
void XMemoryManager::shrink_from_back(XMemory* area, size_t size) {
|
void XMemoryManager::shrink_from_back(XMemory* area, size_t size) {
|
||||||
if (_callbacks._shrink_from_back != NULL) {
|
if (_callbacks._shrink_from_back != nullptr) {
|
||||||
_callbacks._shrink_from_back(area, size);
|
_callbacks._shrink_from_back(area, size);
|
||||||
}
|
}
|
||||||
area->shrink_from_back(size);
|
area->shrink_from_back(size);
|
||||||
}
|
}
|
||||||
|
|
||||||
void XMemoryManager::grow_from_front(XMemory* area, size_t size) {
|
void XMemoryManager::grow_from_front(XMemory* area, size_t size) {
|
||||||
if (_callbacks._grow_from_front != NULL) {
|
if (_callbacks._grow_from_front != nullptr) {
|
||||||
_callbacks._grow_from_front(area, size);
|
_callbacks._grow_from_front(area, size);
|
||||||
}
|
}
|
||||||
area->grow_from_front(size);
|
area->grow_from_front(size);
|
||||||
}
|
}
|
||||||
|
|
||||||
void XMemoryManager::grow_from_back(XMemory* area, size_t size) {
|
void XMemoryManager::grow_from_back(XMemory* area, size_t size) {
|
||||||
if (_callbacks._grow_from_back != NULL) {
|
if (_callbacks._grow_from_back != nullptr) {
|
||||||
_callbacks._grow_from_back(area, size);
|
_callbacks._grow_from_back(area, size);
|
||||||
}
|
}
|
||||||
area->grow_from_back(size);
|
area->grow_from_back(size);
|
||||||
}
|
}
|
||||||
|
|
||||||
XMemoryManager::Callbacks::Callbacks() :
|
XMemoryManager::Callbacks::Callbacks() :
|
||||||
_create(NULL),
|
_create(nullptr),
|
||||||
_destroy(NULL),
|
_destroy(nullptr),
|
||||||
_shrink_from_front(NULL),
|
_shrink_from_front(nullptr),
|
||||||
_shrink_from_back(NULL),
|
_shrink_from_back(nullptr),
|
||||||
_grow_from_front(NULL),
|
_grow_from_front(nullptr),
|
||||||
_grow_from_back(NULL) {}
|
_grow_from_back(nullptr) {}
|
||||||
|
|
||||||
XMemoryManager::XMemoryManager() :
|
XMemoryManager::XMemoryManager() :
|
||||||
_freelist(),
|
_freelist(),
|
||||||
@ -89,7 +89,7 @@ uintptr_t XMemoryManager::peek_low_address() const {
|
|||||||
XLocker<XLock> locker(&_lock);
|
XLocker<XLock> locker(&_lock);
|
||||||
|
|
||||||
const XMemory* const area = _freelist.first();
|
const XMemory* const area = _freelist.first();
|
||||||
if (area != NULL) {
|
if (area != nullptr) {
|
||||||
return area->start();
|
return area->start();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -126,7 +126,7 @@ uintptr_t XMemoryManager::alloc_low_address_at_most(size_t size, size_t* allocat
|
|||||||
XLocker<XLock> locker(&_lock);
|
XLocker<XLock> locker(&_lock);
|
||||||
|
|
||||||
XMemory* area = _freelist.first();
|
XMemory* area = _freelist.first();
|
||||||
if (area != NULL) {
|
if (area != nullptr) {
|
||||||
if (area->size() <= size) {
|
if (area->size() <= size) {
|
||||||
// Smaller than or equal to requested, remove area
|
// Smaller than or equal to requested, remove area
|
||||||
const uintptr_t start = area->start();
|
const uintptr_t start = area->start();
|
||||||
@ -182,7 +182,7 @@ void XMemoryManager::free(uintptr_t start, size_t size) {
|
|||||||
for (XMemory* area; iter.next(&area);) {
|
for (XMemory* area; iter.next(&area);) {
|
||||||
if (start < area->start()) {
|
if (start < area->start()) {
|
||||||
XMemory* const prev = _freelist.prev(area);
|
XMemory* const prev = _freelist.prev(area);
|
||||||
if (prev != NULL && start == prev->end()) {
|
if (prev != nullptr && start == prev->end()) {
|
||||||
if (end == area->start()) {
|
if (end == area->start()) {
|
||||||
// Merge with prev and current area
|
// Merge with prev and current area
|
||||||
grow_from_back(prev, size + area->size());
|
grow_from_back(prev, size + area->size());
|
||||||
@ -209,7 +209,7 @@ void XMemoryManager::free(uintptr_t start, size_t size) {
|
|||||||
|
|
||||||
// Insert last
|
// Insert last
|
||||||
XMemory* const last = _freelist.last();
|
XMemory* const last = _freelist.last();
|
||||||
if (last != NULL && start == last->end()) {
|
if (last != nullptr && start == last->end()) {
|
||||||
// Merge with last area
|
// Merge with last area
|
||||||
grow_from_back(last, size);
|
grow_from_back(last, size);
|
||||||
} else {
|
} else {
|
||||||
|
@ -74,17 +74,17 @@ void XNMethod::attach_gc_data(nmethod* nm) {
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (r->oop_value() != NULL) {
|
if (r->oop_value() != nullptr) {
|
||||||
// Non-NULL immediate oop found. NULL oops can safely be
|
// Non-null immediate oop found. Null oops can safely be
|
||||||
// ignored since the method will be re-registered if they
|
// ignored since the method will be re-registered if they
|
||||||
// are later patched to be non-NULL.
|
// are later patched to be non-null.
|
||||||
immediate_oops.push(r->oop_addr());
|
immediate_oops.push(r->oop_addr());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Attach GC data to nmethod
|
// Attach GC data to nmethod
|
||||||
XNMethodData* data = gc_data(nm);
|
XNMethodData* data = gc_data(nm);
|
||||||
if (data == NULL) {
|
if (data == nullptr) {
|
||||||
data = new XNMethodData();
|
data = new XNMethodData();
|
||||||
set_gc_data(nm, data);
|
set_gc_data(nm, data);
|
||||||
}
|
}
|
||||||
|
@ -66,7 +66,7 @@ bool XNMethodDataOops::has_non_immediates() const {
|
|||||||
|
|
||||||
XNMethodData::XNMethodData() :
|
XNMethodData::XNMethodData() :
|
||||||
_lock(),
|
_lock(),
|
||||||
_oops(NULL) {}
|
_oops(nullptr) {}
|
||||||
|
|
||||||
XNMethodData::~XNMethodData() {
|
XNMethodData::~XNMethodData() {
|
||||||
XNMethodDataOops::destroy(_oops);
|
XNMethodDataOops::destroy(_oops);
|
||||||
|
@ -45,7 +45,7 @@
|
|||||||
#include "utilities/debug.hpp"
|
#include "utilities/debug.hpp"
|
||||||
#include "utilities/powerOfTwo.hpp"
|
#include "utilities/powerOfTwo.hpp"
|
||||||
|
|
||||||
XNMethodTableEntry* XNMethodTable::_table = NULL;
|
XNMethodTableEntry* XNMethodTable::_table = nullptr;
|
||||||
size_t XNMethodTable::_size = 0;
|
size_t XNMethodTable::_size = 0;
|
||||||
size_t XNMethodTable::_nregistered = 0;
|
size_t XNMethodTable::_nregistered = 0;
|
||||||
size_t XNMethodTable::_nunregistered = 0;
|
size_t XNMethodTable::_nunregistered = 0;
|
||||||
|
@ -58,7 +58,7 @@ public:
|
|||||||
explicit XNMethodTableEntry(bool unregistered = false) :
|
explicit XNMethodTableEntry(bool unregistered = false) :
|
||||||
_entry(field_registered::encode(false) |
|
_entry(field_registered::encode(false) |
|
||||||
field_unregistered::encode(unregistered) |
|
field_unregistered::encode(unregistered) |
|
||||||
field_method::encode(NULL)) {}
|
field_method::encode(nullptr)) {}
|
||||||
|
|
||||||
explicit XNMethodTableEntry(nmethod* method) :
|
explicit XNMethodTableEntry(nmethod* method) :
|
||||||
_entry(field_registered::encode(true) |
|
_entry(field_registered::encode(true) |
|
||||||
|
@ -30,12 +30,12 @@
|
|||||||
#include "utilities/globalDefinitions.hpp"
|
#include "utilities/globalDefinitions.hpp"
|
||||||
|
|
||||||
XNMethodTableIteration::XNMethodTableIteration() :
|
XNMethodTableIteration::XNMethodTableIteration() :
|
||||||
_table(NULL),
|
_table(nullptr),
|
||||||
_size(0),
|
_size(0),
|
||||||
_claimed(0) {}
|
_claimed(0) {}
|
||||||
|
|
||||||
bool XNMethodTableIteration::in_progress() const {
|
bool XNMethodTableIteration::in_progress() const {
|
||||||
return _table != NULL;
|
return _table != nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
void XNMethodTableIteration::nmethods_do_begin(XNMethodTableEntry* table, size_t size) {
|
void XNMethodTableIteration::nmethods_do_begin(XNMethodTableEntry* table, size_t size) {
|
||||||
@ -50,7 +50,7 @@ void XNMethodTableIteration::nmethods_do_end() {
|
|||||||
assert(_claimed >= _size, "Failed to claim all table entries");
|
assert(_claimed >= _size, "Failed to claim all table entries");
|
||||||
|
|
||||||
// Finish iteration
|
// Finish iteration
|
||||||
_table = NULL;
|
_table = nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
void XNMethodTableIteration::nmethods_do(NMethodClosure* cl) {
|
void XNMethodTableIteration::nmethods_do(NMethodClosure* cl) {
|
||||||
|
@ -46,8 +46,8 @@ XObjectAllocator::XObjectAllocator() :
|
|||||||
_undone(0),
|
_undone(0),
|
||||||
_alloc_for_relocation(0),
|
_alloc_for_relocation(0),
|
||||||
_undo_alloc_for_relocation(0),
|
_undo_alloc_for_relocation(0),
|
||||||
_shared_medium_page(NULL),
|
_shared_medium_page(nullptr),
|
||||||
_shared_small_page(NULL) {}
|
_shared_small_page(nullptr) {}
|
||||||
|
|
||||||
XPage** XObjectAllocator::shared_small_page_addr() {
|
XPage** XObjectAllocator::shared_small_page_addr() {
|
||||||
return _use_per_cpu_shared_small_pages ? _shared_small_page.addr() : _shared_small_page.addr(0);
|
return _use_per_cpu_shared_small_pages ? _shared_small_page.addr() : _shared_small_page.addr(0);
|
||||||
@ -70,7 +70,7 @@ void XObjectAllocator::register_undo_alloc_for_relocation(const XPage* page, siz
|
|||||||
|
|
||||||
XPage* XObjectAllocator::alloc_page(uint8_t type, size_t size, XAllocationFlags flags) {
|
XPage* XObjectAllocator::alloc_page(uint8_t type, size_t size, XAllocationFlags flags) {
|
||||||
XPage* const page = XHeap::heap()->alloc_page(type, size, flags);
|
XPage* const page = XHeap::heap()->alloc_page(type, size, flags);
|
||||||
if (page != NULL) {
|
if (page != nullptr) {
|
||||||
// Increment used bytes
|
// Increment used bytes
|
||||||
Atomic::add(_used.addr(), size);
|
Atomic::add(_used.addr(), size);
|
||||||
}
|
}
|
||||||
@ -93,14 +93,14 @@ uintptr_t XObjectAllocator::alloc_object_in_shared_page(XPage** shared_page,
|
|||||||
uintptr_t addr = 0;
|
uintptr_t addr = 0;
|
||||||
XPage* page = Atomic::load_acquire(shared_page);
|
XPage* page = Atomic::load_acquire(shared_page);
|
||||||
|
|
||||||
if (page != NULL) {
|
if (page != nullptr) {
|
||||||
addr = page->alloc_object_atomic(size);
|
addr = page->alloc_object_atomic(size);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (addr == 0) {
|
if (addr == 0) {
|
||||||
// Allocate new page
|
// Allocate new page
|
||||||
XPage* const new_page = alloc_page(page_type, page_size, flags);
|
XPage* const new_page = alloc_page(page_type, page_size, flags);
|
||||||
if (new_page != NULL) {
|
if (new_page != nullptr) {
|
||||||
// Allocate object before installing the new page
|
// Allocate object before installing the new page
|
||||||
addr = new_page->alloc_object(size);
|
addr = new_page->alloc_object(size);
|
||||||
|
|
||||||
@ -108,7 +108,7 @@ uintptr_t XObjectAllocator::alloc_object_in_shared_page(XPage** shared_page,
|
|||||||
// Install new page
|
// Install new page
|
||||||
XPage* const prev_page = Atomic::cmpxchg(shared_page, page, new_page);
|
XPage* const prev_page = Atomic::cmpxchg(shared_page, page, new_page);
|
||||||
if (prev_page != page) {
|
if (prev_page != page) {
|
||||||
if (prev_page == NULL) {
|
if (prev_page == nullptr) {
|
||||||
// Previous page was retired, retry installing the new page
|
// Previous page was retired, retry installing the new page
|
||||||
page = prev_page;
|
page = prev_page;
|
||||||
goto retry;
|
goto retry;
|
||||||
@ -140,7 +140,7 @@ uintptr_t XObjectAllocator::alloc_large_object(size_t size, XAllocationFlags fla
|
|||||||
// Allocate new large page
|
// Allocate new large page
|
||||||
const size_t page_size = align_up(size, XGranuleSize);
|
const size_t page_size = align_up(size, XGranuleSize);
|
||||||
XPage* const page = alloc_page(XPageTypeLarge, page_size, flags);
|
XPage* const page = alloc_page(XPageTypeLarge, page_size, flags);
|
||||||
if (page != NULL) {
|
if (page != nullptr) {
|
||||||
// Allocate the object
|
// Allocate the object
|
||||||
addr = page->alloc_object(size);
|
addr = page->alloc_object(size);
|
||||||
}
|
}
|
||||||
@ -224,7 +224,7 @@ size_t XObjectAllocator::remaining() const {
|
|||||||
assert(XThread::is_java(), "Should be a Java thread");
|
assert(XThread::is_java(), "Should be a Java thread");
|
||||||
|
|
||||||
const XPage* const page = Atomic::load_acquire(shared_small_page_addr());
|
const XPage* const page = Atomic::load_acquire(shared_small_page_addr());
|
||||||
if (page != NULL) {
|
if (page != nullptr) {
|
||||||
return page->remaining();
|
return page->remaining();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -262,6 +262,6 @@ void XObjectAllocator::retire_pages() {
|
|||||||
_undo_alloc_for_relocation.set_all(0);
|
_undo_alloc_for_relocation.set_all(0);
|
||||||
|
|
||||||
// Reset allocation pages
|
// Reset allocation pages
|
||||||
_shared_medium_page.set(NULL);
|
_shared_medium_page.set(nullptr);
|
||||||
_shared_small_page.set_all(NULL);
|
_shared_small_page.set_all(nullptr);
|
||||||
}
|
}
|
||||||
|
@ -103,7 +103,7 @@ XPage* XPage::split_committed() {
|
|||||||
const XPhysicalMemory pmem = _physical.split_committed();
|
const XPhysicalMemory pmem = _physical.split_committed();
|
||||||
if (pmem.is_null()) {
|
if (pmem.is_null()) {
|
||||||
// Nothing committed
|
// Nothing committed
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
assert(!_physical.is_null(), "Should not be null");
|
assert(!_physical.is_null(), "Should not be null");
|
||||||
|
@ -219,7 +219,7 @@ bool XPageAllocator::prime_cache(XWorkers* workers, size_t size) {
|
|||||||
flags.set_low_address();
|
flags.set_low_address();
|
||||||
|
|
||||||
XPage* const page = alloc_page(XPageTypeLarge, size, flags);
|
XPage* const page = alloc_page(XPageTypeLarge, size, flags);
|
||||||
if (page == NULL) {
|
if (page == nullptr) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -400,7 +400,7 @@ bool XPageAllocator::alloc_page_common_inner(uint8_t type, size_t size, XList<XP
|
|||||||
|
|
||||||
// Try allocate from the page cache
|
// Try allocate from the page cache
|
||||||
XPage* const page = _cache.alloc_page(type, size);
|
XPage* const page = _cache.alloc_page(type, size);
|
||||||
if (page != NULL) {
|
if (page != nullptr) {
|
||||||
// Success
|
// Success
|
||||||
pages->insert_last(page);
|
pages->insert_last(page);
|
||||||
return true;
|
return true;
|
||||||
@ -519,7 +519,7 @@ XPage* XPageAllocator::alloc_page_create(XPageAllocation* allocation) {
|
|||||||
const XVirtualMemory vmem = _virtual.alloc(size, allocation->flags().low_address());
|
const XVirtualMemory vmem = _virtual.alloc(size, allocation->flags().low_address());
|
||||||
if (vmem.is_null()) {
|
if (vmem.is_null()) {
|
||||||
log_error(gc)("Out of address space");
|
log_error(gc)("Out of address space");
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
XPhysicalMemory pmem;
|
XPhysicalMemory pmem;
|
||||||
@ -607,9 +607,9 @@ XPage* XPageAllocator::alloc_page_finalize(XPageAllocation* allocation) {
|
|||||||
|
|
||||||
// Slow path
|
// Slow path
|
||||||
XPage* const page = alloc_page_create(allocation);
|
XPage* const page = alloc_page_create(allocation);
|
||||||
if (page == NULL) {
|
if (page == nullptr) {
|
||||||
// Out of address space
|
// Out of address space
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Commit page
|
// Commit page
|
||||||
@ -625,12 +625,12 @@ XPage* XPageAllocator::alloc_page_finalize(XPageAllocation* allocation) {
|
|||||||
XPage* const committed_page = page->split_committed();
|
XPage* const committed_page = page->split_committed();
|
||||||
destroy_page(page);
|
destroy_page(page);
|
||||||
|
|
||||||
if (committed_page != NULL) {
|
if (committed_page != nullptr) {
|
||||||
map_page(committed_page);
|
map_page(committed_page);
|
||||||
allocation->pages()->insert_last(committed_page);
|
allocation->pages()->insert_last(committed_page);
|
||||||
}
|
}
|
||||||
|
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
void XPageAllocator::alloc_page_failed(XPageAllocation* allocation) {
|
void XPageAllocator::alloc_page_failed(XPageAllocation* allocation) {
|
||||||
@ -667,11 +667,11 @@ retry:
|
|||||||
// block in a safepoint if the non-blocking flag is not set.
|
// block in a safepoint if the non-blocking flag is not set.
|
||||||
if (!alloc_page_or_stall(&allocation)) {
|
if (!alloc_page_or_stall(&allocation)) {
|
||||||
// Out of memory
|
// Out of memory
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
XPage* const page = alloc_page_finalize(&allocation);
|
XPage* const page = alloc_page_finalize(&allocation);
|
||||||
if (page == NULL) {
|
if (page == nullptr) {
|
||||||
// Failed to commit or map. Clean up and retry, in the hope that
|
// Failed to commit or map. Clean up and retry, in the hope that
|
||||||
// we can still allocate by flushing the page cache (more aggressively).
|
// we can still allocate by flushing the page cache (more aggressively).
|
||||||
alloc_page_failed(&allocation);
|
alloc_page_failed(&allocation);
|
||||||
@ -703,7 +703,7 @@ retry:
|
|||||||
void XPageAllocator::satisfy_stalled() {
|
void XPageAllocator::satisfy_stalled() {
|
||||||
for (;;) {
|
for (;;) {
|
||||||
XPageAllocation* const allocation = _stalled.first();
|
XPageAllocation* const allocation = _stalled.first();
|
||||||
if (allocation == NULL) {
|
if (allocation == nullptr) {
|
||||||
// Allocation queue is empty
|
// Allocation queue is empty
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -850,7 +850,7 @@ void XPageAllocator::check_out_of_memory() {
|
|||||||
|
|
||||||
// Fail allocation requests that were enqueued before the
|
// Fail allocation requests that were enqueued before the
|
||||||
// last GC cycle started, otherwise start a new GC cycle.
|
// last GC cycle started, otherwise start a new GC cycle.
|
||||||
for (XPageAllocation* allocation = _stalled.first(); allocation != NULL; allocation = _stalled.first()) {
|
for (XPageAllocation* allocation = _stalled.first(); allocation != nullptr; allocation = _stalled.first()) {
|
||||||
if (allocation->seqnum() == XGlobalSeqNum) {
|
if (allocation->seqnum() == XGlobalSeqNum) {
|
||||||
// Start a new GC cycle, keep allocation requests enqueued
|
// Start a new GC cycle, keep allocation requests enqueued
|
||||||
allocation->satisfy(XPageAllocationStallStartGC);
|
allocation->satisfy(XPageAllocationStallStartGC);
|
||||||
|
@ -66,7 +66,7 @@ XPage* XPageCache::alloc_small_page() {
|
|||||||
|
|
||||||
// Try NUMA local page cache
|
// Try NUMA local page cache
|
||||||
XPage* const l1_page = _small.get(numa_id).remove_first();
|
XPage* const l1_page = _small.get(numa_id).remove_first();
|
||||||
if (l1_page != NULL) {
|
if (l1_page != nullptr) {
|
||||||
XStatInc(XCounterPageCacheHitL1);
|
XStatInc(XCounterPageCacheHitL1);
|
||||||
return l1_page;
|
return l1_page;
|
||||||
}
|
}
|
||||||
@ -80,7 +80,7 @@ XPage* XPageCache::alloc_small_page() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
XPage* const l2_page = _small.get(remote_numa_id).remove_first();
|
XPage* const l2_page = _small.get(remote_numa_id).remove_first();
|
||||||
if (l2_page != NULL) {
|
if (l2_page != nullptr) {
|
||||||
XStatInc(XCounterPageCacheHitL2);
|
XStatInc(XCounterPageCacheHitL2);
|
||||||
return l2_page;
|
return l2_page;
|
||||||
}
|
}
|
||||||
@ -88,17 +88,17 @@ XPage* XPageCache::alloc_small_page() {
|
|||||||
remote_numa_id++;
|
remote_numa_id++;
|
||||||
}
|
}
|
||||||
|
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
XPage* XPageCache::alloc_medium_page() {
|
XPage* XPageCache::alloc_medium_page() {
|
||||||
XPage* const page = _medium.remove_first();
|
XPage* const page = _medium.remove_first();
|
||||||
if (page != NULL) {
|
if (page != nullptr) {
|
||||||
XStatInc(XCounterPageCacheHitL1);
|
XStatInc(XCounterPageCacheHitL1);
|
||||||
return page;
|
return page;
|
||||||
}
|
}
|
||||||
|
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
XPage* XPageCache::alloc_large_page(size_t size) {
|
XPage* XPageCache::alloc_large_page(size_t size) {
|
||||||
@ -113,7 +113,7 @@ XPage* XPageCache::alloc_large_page(size_t size) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
XPage* XPageCache::alloc_oversized_medium_page(size_t size) {
|
XPage* XPageCache::alloc_oversized_medium_page(size_t size) {
|
||||||
@ -121,7 +121,7 @@ XPage* XPageCache::alloc_oversized_medium_page(size_t size) {
|
|||||||
return _medium.remove_first();
|
return _medium.remove_first();
|
||||||
}
|
}
|
||||||
|
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
XPage* XPageCache::alloc_oversized_large_page(size_t size) {
|
XPage* XPageCache::alloc_oversized_large_page(size_t size) {
|
||||||
@ -135,16 +135,16 @@ XPage* XPageCache::alloc_oversized_large_page(size_t size) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
XPage* XPageCache::alloc_oversized_page(size_t size) {
|
XPage* XPageCache::alloc_oversized_page(size_t size) {
|
||||||
XPage* page = alloc_oversized_large_page(size);
|
XPage* page = alloc_oversized_large_page(size);
|
||||||
if (page == NULL) {
|
if (page == nullptr) {
|
||||||
page = alloc_oversized_medium_page(size);
|
page = alloc_oversized_medium_page(size);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (page != NULL) {
|
if (page != nullptr) {
|
||||||
XStatInc(XCounterPageCacheHitL3);
|
XStatInc(XCounterPageCacheHitL3);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -163,10 +163,10 @@ XPage* XPageCache::alloc_page(uint8_t type, size_t size) {
|
|||||||
page = alloc_large_page(size);
|
page = alloc_large_page(size);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (page == NULL) {
|
if (page == nullptr) {
|
||||||
// Try allocate potentially oversized page
|
// Try allocate potentially oversized page
|
||||||
XPage* const oversized = alloc_oversized_page(size);
|
XPage* const oversized = alloc_oversized_page(size);
|
||||||
if (oversized != NULL) {
|
if (oversized != nullptr) {
|
||||||
if (size < oversized->size()) {
|
if (size < oversized->size()) {
|
||||||
// Split oversized page
|
// Split oversized page
|
||||||
page = oversized->split(type, size);
|
page = oversized->split(type, size);
|
||||||
@ -180,7 +180,7 @@ XPage* XPageCache::alloc_page(uint8_t type, size_t size) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (page == NULL) {
|
if (page == nullptr) {
|
||||||
XStatInc(XCounterPageCacheMiss);
|
XStatInc(XCounterPageCacheMiss);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -200,7 +200,7 @@ void XPageCache::free_page(XPage* page) {
|
|||||||
|
|
||||||
bool XPageCache::flush_list_inner(XPageCacheFlushClosure* cl, XList<XPage>* from, XList<XPage>* to) {
|
bool XPageCache::flush_list_inner(XPageCacheFlushClosure* cl, XList<XPage>* from, XList<XPage>* to) {
|
||||||
XPage* const page = from->last();
|
XPage* const page = from->last();
|
||||||
if (page == NULL || !cl->do_page(page)) {
|
if (page == nullptr || !cl->do_page(page)) {
|
||||||
// Don't flush page
|
// Don't flush page
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -40,7 +40,7 @@ void XPageTable::insert(XPage* page) {
|
|||||||
// visible before updating the page table.
|
// visible before updating the page table.
|
||||||
OrderAccess::storestore();
|
OrderAccess::storestore();
|
||||||
|
|
||||||
assert(_map.get(offset) == NULL, "Invalid entry");
|
assert(_map.get(offset) == nullptr, "Invalid entry");
|
||||||
_map.put(offset, size, page);
|
_map.put(offset, size, page);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -49,5 +49,5 @@ void XPageTable::remove(XPage* page) {
|
|||||||
const size_t size = page->size();
|
const size_t size = page->size();
|
||||||
|
|
||||||
assert(_map.get(offset) == page, "Invalid entry");
|
assert(_map.get(offset) == page, "Invalid entry");
|
||||||
_map.put(offset, size, NULL);
|
_map.put(offset, size, nullptr);
|
||||||
}
|
}
|
||||||
|
@ -36,7 +36,7 @@ inline XPage* XPageTable::get(uintptr_t addr) const {
|
|||||||
|
|
||||||
inline XPageTableIterator::XPageTableIterator(const XPageTable* page_table) :
|
inline XPageTableIterator::XPageTableIterator(const XPageTable* page_table) :
|
||||||
_iter(&page_table->_map),
|
_iter(&page_table->_map),
|
||||||
_prev(NULL) {}
|
_prev(nullptr) {}
|
||||||
|
|
||||||
inline bool XPageTableIterator::next(XPage** page) {
|
inline bool XPageTableIterator::next(XPage** page) {
|
||||||
for (XPage* entry; _iter.next(&entry);) {
|
for (XPage* entry; _iter.next(&entry);) {
|
||||||
|
@ -106,12 +106,12 @@ static void soft_reference_update_clock() {
|
|||||||
|
|
||||||
XReferenceProcessor::XReferenceProcessor(XWorkers* workers) :
|
XReferenceProcessor::XReferenceProcessor(XWorkers* workers) :
|
||||||
_workers(workers),
|
_workers(workers),
|
||||||
_soft_reference_policy(NULL),
|
_soft_reference_policy(nullptr),
|
||||||
_encountered_count(),
|
_encountered_count(),
|
||||||
_discovered_count(),
|
_discovered_count(),
|
||||||
_enqueued_count(),
|
_enqueued_count(),
|
||||||
_discovered_list(NULL),
|
_discovered_list(nullptr),
|
||||||
_pending_list(NULL),
|
_pending_list(nullptr),
|
||||||
_pending_list_tail(_pending_list.addr()) {}
|
_pending_list_tail(_pending_list.addr()) {}
|
||||||
|
|
||||||
void XReferenceProcessor::set_soft_reference_policy(bool clear) {
|
void XReferenceProcessor::set_soft_reference_policy(bool clear) {
|
||||||
@ -132,11 +132,11 @@ bool XReferenceProcessor::is_inactive(oop reference, oop referent, ReferenceType
|
|||||||
if (type == REF_FINAL) {
|
if (type == REF_FINAL) {
|
||||||
// A FinalReference is inactive if its next field is non-null. An application can't
|
// A FinalReference is inactive if its next field is non-null. An application can't
|
||||||
// call enqueue() or clear() on a FinalReference.
|
// call enqueue() or clear() on a FinalReference.
|
||||||
return reference_next(reference) != NULL;
|
return reference_next(reference) != nullptr;
|
||||||
} else {
|
} else {
|
||||||
// A non-FinalReference is inactive if the referent is null. The referent can only
|
// A non-FinalReference is inactive if the referent is null. The referent can only
|
||||||
// be null if the application called Reference.enqueue() or Reference.clear().
|
// be null if the application called Reference.enqueue() or Reference.clear().
|
||||||
return referent == NULL;
|
return referent == nullptr;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -153,7 +153,7 @@ bool XReferenceProcessor::is_softly_live(oop reference, ReferenceType type) cons
|
|||||||
// Ask SoftReference policy
|
// Ask SoftReference policy
|
||||||
const jlong clock = java_lang_ref_SoftReference::clock();
|
const jlong clock = java_lang_ref_SoftReference::clock();
|
||||||
assert(clock != 0, "Clock not initialized");
|
assert(clock != 0, "Clock not initialized");
|
||||||
assert(_soft_reference_policy != NULL, "Policy not initialized");
|
assert(_soft_reference_policy != nullptr, "Policy not initialized");
|
||||||
return !_soft_reference_policy->should_clear_reference(reference, clock);
|
return !_soft_reference_policy->should_clear_reference(reference, clock);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -184,7 +184,7 @@ bool XReferenceProcessor::should_discover(oop reference, ReferenceType type) con
|
|||||||
|
|
||||||
bool XReferenceProcessor::should_drop(oop reference, ReferenceType type) const {
|
bool XReferenceProcessor::should_drop(oop reference, ReferenceType type) const {
|
||||||
const oop referent = reference_referent(reference);
|
const oop referent = reference_referent(reference);
|
||||||
if (referent == NULL) {
|
if (referent == nullptr) {
|
||||||
// Reference has been cleared, by a call to Reference.enqueue()
|
// Reference has been cleared, by a call to Reference.enqueue()
|
||||||
// or Reference.clear() from the application, which means we
|
// or Reference.clear() from the application, which means we
|
||||||
// should drop the reference.
|
// should drop the reference.
|
||||||
@ -215,7 +215,7 @@ void XReferenceProcessor::make_inactive(oop reference, ReferenceType type) const
|
|||||||
// to finalize(). A FinalReference is instead made inactive by self-looping the
|
// to finalize(). A FinalReference is instead made inactive by self-looping the
|
||||||
// next field. An application can't call FinalReference.enqueue(), so there is
|
// next field. An application can't call FinalReference.enqueue(), so there is
|
||||||
// no race to worry about when setting the next field.
|
// no race to worry about when setting the next field.
|
||||||
assert(reference_next(reference) == NULL, "Already inactive");
|
assert(reference_next(reference) == nullptr, "Already inactive");
|
||||||
reference_set_next(reference, reference);
|
reference_set_next(reference, reference);
|
||||||
} else {
|
} else {
|
||||||
// Clear referent
|
// Clear referent
|
||||||
@ -238,7 +238,7 @@ void XReferenceProcessor::discover(oop reference, ReferenceType type) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Add reference to discovered list
|
// Add reference to discovered list
|
||||||
assert(reference_discovered(reference) == NULL, "Already discovered");
|
assert(reference_discovered(reference) == nullptr, "Already discovered");
|
||||||
oop* const list = _discovered_list.addr();
|
oop* const list = _discovered_list.addr();
|
||||||
reference_set_discovered(reference, *list);
|
reference_set_discovered(reference, *list);
|
||||||
*list = reference;
|
*list = reference;
|
||||||
@ -274,7 +274,7 @@ oop XReferenceProcessor::drop(oop reference, ReferenceType type) {
|
|||||||
|
|
||||||
// Unlink and return next in list
|
// Unlink and return next in list
|
||||||
const oop next = reference_discovered(reference);
|
const oop next = reference_discovered(reference);
|
||||||
reference_set_discovered(reference, NULL);
|
reference_set_discovered(reference, nullptr);
|
||||||
return next;
|
return next;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -296,7 +296,7 @@ void XReferenceProcessor::work() {
|
|||||||
oop* const list = _discovered_list.addr();
|
oop* const list = _discovered_list.addr();
|
||||||
oop* p = list;
|
oop* p = list;
|
||||||
|
|
||||||
while (*p != NULL) {
|
while (*p != nullptr) {
|
||||||
const oop reference = *p;
|
const oop reference = *p;
|
||||||
const ReferenceType type = reference_type(reference);
|
const ReferenceType type = reference_type(reference);
|
||||||
|
|
||||||
@ -308,27 +308,27 @@ void XReferenceProcessor::work() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Prepend discovered references to internal pending list
|
// Prepend discovered references to internal pending list
|
||||||
if (*list != NULL) {
|
if (*list != nullptr) {
|
||||||
*p = Atomic::xchg(_pending_list.addr(), *list);
|
*p = Atomic::xchg(_pending_list.addr(), *list);
|
||||||
if (*p == NULL) {
|
if (*p == nullptr) {
|
||||||
// First to prepend to list, record tail
|
// First to prepend to list, record tail
|
||||||
_pending_list_tail = p;
|
_pending_list_tail = p;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Clear discovered list
|
// Clear discovered list
|
||||||
*list = NULL;
|
*list = nullptr;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
bool XReferenceProcessor::is_empty() const {
|
bool XReferenceProcessor::is_empty() const {
|
||||||
XPerWorkerConstIterator<oop> iter(&_discovered_list);
|
XPerWorkerConstIterator<oop> iter(&_discovered_list);
|
||||||
for (const oop* list; iter.next(&list);) {
|
for (const oop* list; iter.next(&list);) {
|
||||||
if (*list != NULL) {
|
if (*list != nullptr) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (_pending_list.get() != NULL) {
|
if (_pending_list.get() != nullptr) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -437,7 +437,7 @@ void XReferenceProcessor::process_references() {
|
|||||||
void XReferenceProcessor::enqueue_references() {
|
void XReferenceProcessor::enqueue_references() {
|
||||||
XStatTimer timer(XSubPhaseConcurrentReferencesEnqueue);
|
XStatTimer timer(XSubPhaseConcurrentReferencesEnqueue);
|
||||||
|
|
||||||
if (_pending_list.get() == NULL) {
|
if (_pending_list.get() == nullptr) {
|
||||||
// Nothing to enqueue
|
// Nothing to enqueue
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -454,6 +454,6 @@ void XReferenceProcessor::enqueue_references() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Reset internal pending list
|
// Reset internal pending list
|
||||||
_pending_list.set(NULL);
|
_pending_list.set(nullptr);
|
||||||
_pending_list_tail = _pending_list.addr();
|
_pending_list_tail = _pending_list.addr();
|
||||||
}
|
}
|
||||||
|
@ -129,7 +129,7 @@ static XPage* alloc_page(const XForwarding* forwarding) {
|
|||||||
if (ZStressRelocateInPlace) {
|
if (ZStressRelocateInPlace) {
|
||||||
// Simulate failure to allocate a new page. This will
|
// Simulate failure to allocate a new page. This will
|
||||||
// cause the page being relocated to be relocated in-place.
|
// cause the page being relocated to be relocated in-place.
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
XAllocationFlags flags;
|
XAllocationFlags flags;
|
||||||
@ -147,7 +147,7 @@ static bool should_free_target_page(XPage* page) {
|
|||||||
// page if we allocated a new target page, and then lost the race to
|
// page if we allocated a new target page, and then lost the race to
|
||||||
// relocate the remaining objects, leaving the target page empty when
|
// relocate the remaining objects, leaving the target page empty when
|
||||||
// relocation completed.
|
// relocation completed.
|
||||||
return page != NULL && page->top() == page->start();
|
return page != nullptr && page->top() == page->start();
|
||||||
}
|
}
|
||||||
|
|
||||||
class XRelocateSmallAllocator {
|
class XRelocateSmallAllocator {
|
||||||
@ -160,7 +160,7 @@ public:
|
|||||||
|
|
||||||
XPage* alloc_target_page(XForwarding* forwarding, XPage* target) {
|
XPage* alloc_target_page(XForwarding* forwarding, XPage* target) {
|
||||||
XPage* const page = alloc_page(forwarding);
|
XPage* const page = alloc_page(forwarding);
|
||||||
if (page == NULL) {
|
if (page == nullptr) {
|
||||||
Atomic::inc(&_in_place_count);
|
Atomic::inc(&_in_place_count);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -182,7 +182,7 @@ public:
|
|||||||
}
|
}
|
||||||
|
|
||||||
uintptr_t alloc_object(XPage* page, size_t size) const {
|
uintptr_t alloc_object(XPage* page, size_t size) const {
|
||||||
return (page != NULL) ? page->alloc_object(size) : 0;
|
return (page != nullptr) ? page->alloc_object(size) : 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
void undo_alloc_object(XPage* page, uintptr_t addr, size_t size) const {
|
void undo_alloc_object(XPage* page, uintptr_t addr, size_t size) const {
|
||||||
@ -204,7 +204,7 @@ private:
|
|||||||
public:
|
public:
|
||||||
XRelocateMediumAllocator() :
|
XRelocateMediumAllocator() :
|
||||||
_lock(),
|
_lock(),
|
||||||
_shared(NULL),
|
_shared(nullptr),
|
||||||
_in_place(false),
|
_in_place(false),
|
||||||
_in_place_count(0) {}
|
_in_place_count(0) {}
|
||||||
|
|
||||||
@ -228,7 +228,7 @@ public:
|
|||||||
// a new page.
|
// a new page.
|
||||||
if (_shared == target) {
|
if (_shared == target) {
|
||||||
_shared = alloc_page(forwarding);
|
_shared = alloc_page(forwarding);
|
||||||
if (_shared == NULL) {
|
if (_shared == nullptr) {
|
||||||
Atomic::inc(&_in_place_count);
|
Atomic::inc(&_in_place_count);
|
||||||
_in_place = true;
|
_in_place = true;
|
||||||
}
|
}
|
||||||
@ -241,8 +241,8 @@ public:
|
|||||||
XLocker<XConditionLock> locker(&_lock);
|
XLocker<XConditionLock> locker(&_lock);
|
||||||
|
|
||||||
assert(_in_place, "Invalid state");
|
assert(_in_place, "Invalid state");
|
||||||
assert(_shared == NULL, "Invalid state");
|
assert(_shared == nullptr, "Invalid state");
|
||||||
assert(page != NULL, "Invalid page");
|
assert(page != nullptr, "Invalid page");
|
||||||
|
|
||||||
_shared = page;
|
_shared = page;
|
||||||
_in_place = false;
|
_in_place = false;
|
||||||
@ -259,7 +259,7 @@ public:
|
|||||||
}
|
}
|
||||||
|
|
||||||
uintptr_t alloc_object(XPage* page, size_t size) const {
|
uintptr_t alloc_object(XPage* page, size_t size) const {
|
||||||
return (page != NULL) ? page->alloc_object_atomic(size) : 0;
|
return (page != nullptr) ? page->alloc_object_atomic(size) : 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
void undo_alloc_object(XPage* page, uintptr_t addr, size_t size) const {
|
void undo_alloc_object(XPage* page, uintptr_t addr, size_t size) const {
|
||||||
@ -321,7 +321,7 @@ private:
|
|||||||
// relocated as the new target, which will cause it to be relocated
|
// relocated as the new target, which will cause it to be relocated
|
||||||
// in-place.
|
// in-place.
|
||||||
_target = _allocator->alloc_target_page(_forwarding, _target);
|
_target = _allocator->alloc_target_page(_forwarding, _target);
|
||||||
if (_target != NULL) {
|
if (_target != nullptr) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -337,8 +337,8 @@ private:
|
|||||||
public:
|
public:
|
||||||
XRelocateClosure(Allocator* allocator) :
|
XRelocateClosure(Allocator* allocator) :
|
||||||
_allocator(allocator),
|
_allocator(allocator),
|
||||||
_forwarding(NULL),
|
_forwarding(nullptr),
|
||||||
_target(NULL) {}
|
_target(nullptr) {}
|
||||||
|
|
||||||
~XRelocateClosure() {
|
~XRelocateClosure() {
|
||||||
_allocator->free_target_page(_target);
|
_allocator->free_target_page(_target);
|
||||||
|
@ -61,7 +61,7 @@ public:
|
|||||||
XRelocationSetInstallTask(XForwardingAllocator* allocator, const XRelocationSetSelector* selector) :
|
XRelocationSetInstallTask(XForwardingAllocator* allocator, const XRelocationSetSelector* selector) :
|
||||||
XTask("XRelocationSetInstallTask"),
|
XTask("XRelocationSetInstallTask"),
|
||||||
_allocator(allocator),
|
_allocator(allocator),
|
||||||
_forwardings(NULL),
|
_forwardings(nullptr),
|
||||||
_nforwardings(selector->small()->length() + selector->medium()->length()),
|
_nforwardings(selector->small()->length() + selector->medium()->length()),
|
||||||
_small_iter(selector->small()),
|
_small_iter(selector->small()),
|
||||||
_medium_iter(selector->medium()),
|
_medium_iter(selector->medium()),
|
||||||
@ -109,7 +109,7 @@ public:
|
|||||||
XRelocationSet::XRelocationSet(XWorkers* workers) :
|
XRelocationSet::XRelocationSet(XWorkers* workers) :
|
||||||
_workers(workers),
|
_workers(workers),
|
||||||
_allocator(),
|
_allocator(),
|
||||||
_forwardings(NULL),
|
_forwardings(nullptr),
|
||||||
_nforwardings(0) {}
|
_nforwardings(0) {}
|
||||||
|
|
||||||
void XRelocationSet::install(const XRelocationSetSelector* selector) {
|
void XRelocationSet::install(const XRelocationSetSelector* selector) {
|
||||||
|
@ -91,14 +91,14 @@ void XRelocationSetSelectorGroup::semi_sort() {
|
|||||||
|
|
||||||
// Allocate destination array
|
// Allocate destination array
|
||||||
const int npages = _live_pages.length();
|
const int npages = _live_pages.length();
|
||||||
XArray<XPage*> sorted_live_pages(npages, npages, NULL);
|
XArray<XPage*> sorted_live_pages(npages, npages, nullptr);
|
||||||
|
|
||||||
// Sort pages into partitions
|
// Sort pages into partitions
|
||||||
XArrayIterator<XPage*> iter2(&_live_pages);
|
XArrayIterator<XPage*> iter2(&_live_pages);
|
||||||
for (XPage* page; iter2.next(&page);) {
|
for (XPage* page; iter2.next(&page);) {
|
||||||
const size_t index = page->live_bytes() >> partition_size_shift;
|
const size_t index = page->live_bytes() >> partition_size_shift;
|
||||||
const int finger = partitions[index]++;
|
const int finger = partitions[index]++;
|
||||||
assert(sorted_live_pages.at(finger) == NULL, "Invalid finger");
|
assert(sorted_live_pages.at(finger) == nullptr, "Invalid finger");
|
||||||
sorted_live_pages.at_put(finger, page);
|
sorted_live_pages.at_put(finger, page);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -95,6 +95,6 @@ XSafeDelete<T>::XSafeDelete() :
|
|||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
XSafeDeleteNoLock<T>::XSafeDeleteNoLock() :
|
XSafeDeleteNoLock<T>::XSafeDeleteNoLock() :
|
||||||
XSafeDeleteImpl<T>(NULL) {}
|
XSafeDeleteImpl<T>(nullptr) {}
|
||||||
|
|
||||||
#endif // SHARE_GC_X_XSAFEDELETE_INLINE_HPP
|
#endif // SHARE_GC_X_XSAFEDELETE_INLINE_HPP
|
||||||
|
@ -121,7 +121,7 @@ XServiceability::XServiceability(size_t min_capacity, size_t max_capacity) :
|
|||||||
_memory_pool(_min_capacity, _max_capacity),
|
_memory_pool(_min_capacity, _max_capacity),
|
||||||
_cycle_memory_manager("ZGC Cycles", &_memory_pool),
|
_cycle_memory_manager("ZGC Cycles", &_memory_pool),
|
||||||
_pause_memory_manager("ZGC Pauses", &_memory_pool),
|
_pause_memory_manager("ZGC Pauses", &_memory_pool),
|
||||||
_counters(NULL) {}
|
_counters(nullptr) {}
|
||||||
|
|
||||||
void XServiceability::initialize() {
|
void XServiceability::initialize() {
|
||||||
_counters = new XServiceabilityCounters(_min_capacity, _max_capacity);
|
_counters = new XServiceabilityCounters(_min_capacity, _max_capacity);
|
||||||
|
@ -38,7 +38,7 @@ XOnStackCodeBlobClosure::XOnStackCodeBlobClosure() :
|
|||||||
|
|
||||||
void XOnStackCodeBlobClosure::do_code_blob(CodeBlob* cb) {
|
void XOnStackCodeBlobClosure::do_code_blob(CodeBlob* cb) {
|
||||||
nmethod* const nm = cb->as_nmethod_or_null();
|
nmethod* const nm = cb->as_nmethod_or_null();
|
||||||
if (nm != NULL) {
|
if (nm != nullptr) {
|
||||||
const bool result = _bs_nm->nmethod_entry_barrier(nm);
|
const bool result = _bs_nm->nmethod_entry_barrier(nm);
|
||||||
assert(result, "NMethod on-stack must be alive");
|
assert(result, "NMethod on-stack must be alive");
|
||||||
}
|
}
|
||||||
@ -59,7 +59,7 @@ XStackWatermark::XStackWatermark(JavaThread* jt) :
|
|||||||
_stats() {}
|
_stats() {}
|
||||||
|
|
||||||
OopClosure* XStackWatermark::closure_from_context(void* context) {
|
OopClosure* XStackWatermark::closure_from_context(void* context) {
|
||||||
if (context != NULL) {
|
if (context != nullptr) {
|
||||||
assert(XThread::is_worker(), "Unexpected thread passing in context: " PTR_FORMAT, p2i(context));
|
assert(XThread::is_worker(), "Unexpected thread passing in context: " PTR_FORMAT, p2i(context));
|
||||||
return reinterpret_cast<OopClosure*>(context);
|
return reinterpret_cast<OopClosure*>(context);
|
||||||
} else {
|
} else {
|
||||||
|
@ -397,16 +397,16 @@ T* XStatIterableValue<T>::insert() const {
|
|||||||
template <typename T>
|
template <typename T>
|
||||||
void XStatIterableValue<T>::sort() {
|
void XStatIterableValue<T>::sort() {
|
||||||
T* first_unsorted = _first;
|
T* first_unsorted = _first;
|
||||||
_first = NULL;
|
_first = nullptr;
|
||||||
|
|
||||||
while (first_unsorted != NULL) {
|
while (first_unsorted != nullptr) {
|
||||||
T* const value = first_unsorted;
|
T* const value = first_unsorted;
|
||||||
first_unsorted = value->_next;
|
first_unsorted = value->_next;
|
||||||
value->_next = NULL;
|
value->_next = nullptr;
|
||||||
|
|
||||||
T** current = &_first;
|
T** current = &_first;
|
||||||
|
|
||||||
while (*current != NULL) {
|
while (*current != nullptr) {
|
||||||
// First sort by group, then by name
|
// First sort by group, then by name
|
||||||
const int group_cmp = strcmp((*current)->group(), value->group());
|
const int group_cmp = strcmp((*current)->group(), value->group());
|
||||||
if ((group_cmp > 0) || (group_cmp == 0 && strcmp((*current)->name(), value->name()) > 0)) {
|
if ((group_cmp > 0) || (group_cmp == 0 && strcmp((*current)->name(), value->name()) > 0)) {
|
||||||
@ -881,12 +881,12 @@ XStat::XStat() :
|
|||||||
|
|
||||||
void XStat::sample_and_collect(XStatSamplerHistory* history) const {
|
void XStat::sample_and_collect(XStatSamplerHistory* history) const {
|
||||||
// Sample counters
|
// Sample counters
|
||||||
for (const XStatCounter* counter = XStatCounter::first(); counter != NULL; counter = counter->next()) {
|
for (const XStatCounter* counter = XStatCounter::first(); counter != nullptr; counter = counter->next()) {
|
||||||
counter->sample_and_reset();
|
counter->sample_and_reset();
|
||||||
}
|
}
|
||||||
|
|
||||||
// Collect samples
|
// Collect samples
|
||||||
for (const XStatSampler* sampler = XStatSampler::first(); sampler != NULL; sampler = sampler->next()) {
|
for (const XStatSampler* sampler = XStatSampler::first(); sampler != nullptr; sampler = sampler->next()) {
|
||||||
XStatSamplerHistory& sampler_history = history[sampler->id()];
|
XStatSamplerHistory& sampler_history = history[sampler->id()];
|
||||||
sampler_history.add(sampler->collect_and_reset());
|
sampler_history.add(sampler->collect_and_reset());
|
||||||
}
|
}
|
||||||
@ -911,7 +911,7 @@ void XStat::print(LogTargetHandle log, const XStatSamplerHistory* history) const
|
|||||||
log.print(" Last 10s Last 10m Last 10h Total");
|
log.print(" Last 10s Last 10m Last 10h Total");
|
||||||
log.print(" Avg / Max Avg / Max Avg / Max Avg / Max");
|
log.print(" Avg / Max Avg / Max Avg / Max Avg / Max");
|
||||||
|
|
||||||
for (const XStatSampler* sampler = XStatSampler::first(); sampler != NULL; sampler = sampler->next()) {
|
for (const XStatSampler* sampler = XStatSampler::first(); sampler != nullptr; sampler = sampler->next()) {
|
||||||
const XStatSamplerHistory& sampler_history = history[sampler->id()];
|
const XStatSamplerHistory& sampler_history = history[sampler->id()];
|
||||||
const XStatUnitPrinter printer = sampler->printer();
|
const XStatUnitPrinter printer = sampler->printer();
|
||||||
printer(log, *sampler, sampler_history);
|
printer(log, *sampler, sampler_history);
|
||||||
|
@ -118,7 +118,7 @@ public:
|
|||||||
};
|
};
|
||||||
|
|
||||||
template <typename T> uint32_t XStatIterableValue<T>::_count = 0;
|
template <typename T> uint32_t XStatIterableValue<T>::_count = 0;
|
||||||
template <typename T> T* XStatIterableValue<T>::_first = NULL;
|
template <typename T> T* XStatIterableValue<T>::_first = nullptr;
|
||||||
|
|
||||||
//
|
//
|
||||||
// Stat sampler
|
// Stat sampler
|
||||||
|
@ -31,11 +31,11 @@
|
|||||||
#include "runtime/javaThread.hpp"
|
#include "runtime/javaThread.hpp"
|
||||||
#include "runtime/stackWatermarkSet.inline.hpp"
|
#include "runtime/stackWatermarkSet.inline.hpp"
|
||||||
|
|
||||||
XPerWorker<ThreadLocalAllocStats>* XThreadLocalAllocBuffer::_stats = NULL;
|
XPerWorker<ThreadLocalAllocStats>* XThreadLocalAllocBuffer::_stats = nullptr;
|
||||||
|
|
||||||
void XThreadLocalAllocBuffer::initialize() {
|
void XThreadLocalAllocBuffer::initialize() {
|
||||||
if (UseTLAB) {
|
if (UseTLAB) {
|
||||||
assert(_stats == NULL, "Already initialized");
|
assert(_stats == nullptr, "Already initialized");
|
||||||
_stats = new XPerWorker<ThreadLocalAllocStats>();
|
_stats = new XPerWorker<ThreadLocalAllocStats>();
|
||||||
reset_statistics();
|
reset_statistics();
|
||||||
}
|
}
|
||||||
|
@ -39,7 +39,7 @@ private:
|
|||||||
XThreadLocalData() :
|
XThreadLocalData() :
|
||||||
_address_bad_mask(0),
|
_address_bad_mask(0),
|
||||||
_stacks(),
|
_stacks(),
|
||||||
_invisible_root(NULL) {}
|
_invisible_root(nullptr) {}
|
||||||
|
|
||||||
static XThreadLocalData* data(Thread* thread) {
|
static XThreadLocalData* data(Thread* thread) {
|
||||||
return thread->gc_data<XThreadLocalData>();
|
return thread->gc_data<XThreadLocalData>();
|
||||||
@ -63,18 +63,18 @@ public:
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void set_invisible_root(Thread* thread, oop* root) {
|
static void set_invisible_root(Thread* thread, oop* root) {
|
||||||
assert(data(thread)->_invisible_root == NULL, "Already set");
|
assert(data(thread)->_invisible_root == nullptr, "Already set");
|
||||||
data(thread)->_invisible_root = root;
|
data(thread)->_invisible_root = root;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void clear_invisible_root(Thread* thread) {
|
static void clear_invisible_root(Thread* thread) {
|
||||||
assert(data(thread)->_invisible_root != NULL, "Should be set");
|
assert(data(thread)->_invisible_root != nullptr, "Should be set");
|
||||||
data(thread)->_invisible_root = NULL;
|
data(thread)->_invisible_root = nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
static void do_invisible_root(Thread* thread, T f) {
|
static void do_invisible_root(Thread* thread, T f) {
|
||||||
if (data(thread)->_invisible_root != NULL) {
|
if (data(thread)->_invisible_root != nullptr) {
|
||||||
f(data(thread)->_invisible_root);
|
f(data(thread)->_invisible_root);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -53,7 +53,7 @@ class XStatisticsCounterTypeConstant : public JfrSerializer {
|
|||||||
public:
|
public:
|
||||||
virtual void serialize(JfrCheckpointWriter& writer) {
|
virtual void serialize(JfrCheckpointWriter& writer) {
|
||||||
writer.write_count(XStatCounter::count());
|
writer.write_count(XStatCounter::count());
|
||||||
for (XStatCounter* counter = XStatCounter::first(); counter != NULL; counter = counter->next()) {
|
for (XStatCounter* counter = XStatCounter::first(); counter != nullptr; counter = counter->next()) {
|
||||||
writer.write_key(counter->id());
|
writer.write_key(counter->id());
|
||||||
writer.write(counter->name());
|
writer.write(counter->name());
|
||||||
}
|
}
|
||||||
@ -64,7 +64,7 @@ class XStatisticsSamplerTypeConstant : public JfrSerializer {
|
|||||||
public:
|
public:
|
||||||
virtual void serialize(JfrCheckpointWriter& writer) {
|
virtual void serialize(JfrCheckpointWriter& writer) {
|
||||||
writer.write_count(XStatSampler::count());
|
writer.write_count(XStatSampler::count());
|
||||||
for (XStatSampler* sampler = XStatSampler::first(); sampler != NULL; sampler = sampler->next()) {
|
for (XStatSampler* sampler = XStatSampler::first(); sampler != nullptr; sampler = sampler->next()) {
|
||||||
writer.write_key(sampler->id());
|
writer.write_key(sampler->id());
|
||||||
writer.write(sampler->name());
|
writer.write(sampler->name());
|
||||||
}
|
}
|
||||||
@ -85,13 +85,13 @@ static void register_jfr_type_serializers() {
|
|||||||
|
|
||||||
#endif // INCLUDE_JFR
|
#endif // INCLUDE_JFR
|
||||||
|
|
||||||
XTracer* XTracer::_tracer = NULL;
|
XTracer* XTracer::_tracer = nullptr;
|
||||||
|
|
||||||
XTracer::XTracer() :
|
XTracer::XTracer() :
|
||||||
GCTracer(Z) {}
|
GCTracer(Z) {}
|
||||||
|
|
||||||
void XTracer::initialize() {
|
void XTracer::initialize() {
|
||||||
assert(_tracer == NULL, "Already initialized");
|
assert(_tracer == nullptr, "Already initialized");
|
||||||
_tracer = new XTracer();
|
_tracer = new XTracer();
|
||||||
JFR_ONLY(register_jfr_type_serializers());
|
JFR_ONLY(register_jfr_type_serializers());
|
||||||
}
|
}
|
||||||
|
@ -59,7 +59,7 @@ public:
|
|||||||
|
|
||||||
virtual void do_oop(oop* p) {
|
virtual void do_oop(oop* p) {
|
||||||
const oop o = RawAccess<>::oop_load(p);
|
const oop o = RawAccess<>::oop_load(p);
|
||||||
if (o != NULL && !_is_alive.do_object_b(o)) {
|
if (o != nullptr && !_is_alive.do_object_b(o)) {
|
||||||
_is_unloading = true;
|
_is_unloading = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -45,11 +45,11 @@ XPage* XUnmapper::dequeue() {
|
|||||||
|
|
||||||
for (;;) {
|
for (;;) {
|
||||||
if (_stop) {
|
if (_stop) {
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
XPage* const page = _queue.remove_first();
|
XPage* const page = _queue.remove_first();
|
||||||
if (page != NULL) {
|
if (page != nullptr) {
|
||||||
return page;
|
return page;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -85,7 +85,7 @@ void XUnmapper::unmap_and_destroy_page(XPage* page) {
|
|||||||
void XUnmapper::run_service() {
|
void XUnmapper::run_service() {
|
||||||
for (;;) {
|
for (;;) {
|
||||||
XPage* const page = dequeue();
|
XPage* const page = dequeue();
|
||||||
if (page == NULL) {
|
if (page == nullptr) {
|
||||||
// Stop
|
// Stop
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -53,7 +53,7 @@
|
|||||||
|
|
||||||
static void z_verify_oop(oop* p) {
|
static void z_verify_oop(oop* p) {
|
||||||
const oop o = RawAccess<>::oop_load(p);
|
const oop o = RawAccess<>::oop_load(p);
|
||||||
if (o != NULL) {
|
if (o != nullptr) {
|
||||||
const uintptr_t addr = XOop::to_address(o);
|
const uintptr_t addr = XOop::to_address(o);
|
||||||
guarantee(XAddress::is_good(addr), BAD_OOP_ARG(o, p));
|
guarantee(XAddress::is_good(addr), BAD_OOP_ARG(o, p));
|
||||||
guarantee(oopDesc::is_oop(XOop::from_address(addr)), BAD_OOP_ARG(o, p));
|
guarantee(oopDesc::is_oop(XOop::from_address(addr)), BAD_OOP_ARG(o, p));
|
||||||
@ -62,7 +62,7 @@ static void z_verify_oop(oop* p) {
|
|||||||
|
|
||||||
static void z_verify_possibly_weak_oop(oop* p) {
|
static void z_verify_possibly_weak_oop(oop* p) {
|
||||||
const oop o = RawAccess<>::oop_load(p);
|
const oop o = RawAccess<>::oop_load(p);
|
||||||
if (o != NULL) {
|
if (o != nullptr) {
|
||||||
const uintptr_t addr = XOop::to_address(o);
|
const uintptr_t addr = XOop::to_address(o);
|
||||||
guarantee(XAddress::is_good(addr) || XAddress::is_finalizable_good(addr), BAD_OOP_ARG(o, p));
|
guarantee(XAddress::is_good(addr) || XAddress::is_finalizable_good(addr), BAD_OOP_ARG(o, p));
|
||||||
guarantee(oopDesc::is_oop(XOop::from_address(XAddress::good(addr))), BAD_OOP_ARG(o, p));
|
guarantee(oopDesc::is_oop(XOop::from_address(XAddress::good(addr))), BAD_OOP_ARG(o, p));
|
||||||
@ -220,7 +220,7 @@ public:
|
|||||||
_cl(cl) {}
|
_cl(cl) {}
|
||||||
|
|
||||||
virtual void do_thread(Thread* thread) {
|
virtual void do_thread(Thread* thread) {
|
||||||
thread->oops_do_no_frames(_cl, NULL);
|
thread->oops_do_no_frames(_cl, nullptr);
|
||||||
|
|
||||||
JavaThread* const jt = JavaThread::cast(thread);
|
JavaThread* const jt = JavaThread::cast(thread);
|
||||||
if (!jt->has_last_Java_frame()) {
|
if (!jt->has_last_Java_frame()) {
|
||||||
@ -393,12 +393,12 @@ public:
|
|||||||
|
|
||||||
void XVerify::verify_frame_bad(const frame& fr, RegisterMap& register_map) {
|
void XVerify::verify_frame_bad(const frame& fr, RegisterMap& register_map) {
|
||||||
XVerifyBadOopClosure verify_cl;
|
XVerifyBadOopClosure verify_cl;
|
||||||
fr.oops_do(&verify_cl, NULL, ®ister_map, DerivedPointerIterationMode::_ignore);
|
fr.oops_do(&verify_cl, nullptr, ®ister_map, DerivedPointerIterationMode::_ignore);
|
||||||
}
|
}
|
||||||
|
|
||||||
void XVerify::verify_thread_head_bad(JavaThread* jt) {
|
void XVerify::verify_thread_head_bad(JavaThread* jt) {
|
||||||
XVerifyBadOopClosure verify_cl;
|
XVerifyBadOopClosure verify_cl;
|
||||||
jt->oops_do_no_frames(&verify_cl, NULL);
|
jt->oops_do_no_frames(&verify_cl, nullptr);
|
||||||
}
|
}
|
||||||
|
|
||||||
void XVerify::verify_thread_frames_bad(JavaThread* jt) {
|
void XVerify::verify_thread_frames_bad(JavaThread* jt) {
|
||||||
@ -407,7 +407,7 @@ void XVerify::verify_thread_frames_bad(JavaThread* jt) {
|
|||||||
StackWatermarkProcessingMark swpm(Thread::current());
|
StackWatermarkProcessingMark swpm(Thread::current());
|
||||||
// Traverse the execution stack
|
// Traverse the execution stack
|
||||||
for (StackFrameStream fst(jt, true /* update */, false /* process_frames */); !fst.is_done(); fst.next()) {
|
for (StackFrameStream fst(jt, true /* update */, false /* process_frames */); !fst.is_done(); fst.next()) {
|
||||||
fst.current()->oops_do(&verify_cl, NULL /* code_cl */, fst.register_map(), DerivedPointerIterationMode::_ignore);
|
fst.current()->oops_do(&verify_cl, nullptr /* code_cl */, fst.register_map(), DerivedPointerIterationMode::_ignore);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -42,7 +42,7 @@ public:
|
|||||||
// oop here again (the object would be strongly live and we would
|
// oop here again (the object would be strongly live and we would
|
||||||
// not consider clearing such oops), so therefore we don't have an
|
// not consider clearing such oops), so therefore we don't have an
|
||||||
// ABA problem here.
|
// ABA problem here.
|
||||||
Atomic::cmpxchg(p, obj, oop(NULL));
|
Atomic::cmpxchg(p, obj, oop(nullptr));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user