8245594: Remove volatile-qualified member functions and parameters from oop class
Remove volatile qualifications in oop and derived classes; use Atomic for access. Reviewed-by: dholmes, coleenp
This commit is contained in:
parent
bc822ffad8
commit
d3042cc401
@ -41,17 +41,7 @@ class ShenandoahVerifierTask {
|
|||||||
public:
|
public:
|
||||||
ShenandoahVerifierTask(oop o = NULL, int idx = 0): _obj(o) { }
|
ShenandoahVerifierTask(oop o = NULL, int idx = 0): _obj(o) { }
|
||||||
ShenandoahVerifierTask(oop o, size_t idx): _obj(o) { }
|
ShenandoahVerifierTask(oop o, size_t idx): _obj(o) { }
|
||||||
ShenandoahVerifierTask(const ShenandoahVerifierTask& t): _obj(t._obj) { }
|
// Trivially copyable.
|
||||||
|
|
||||||
ShenandoahVerifierTask& operator =(const ShenandoahVerifierTask& t) {
|
|
||||||
_obj = t._obj;
|
|
||||||
return *this;
|
|
||||||
}
|
|
||||||
volatile ShenandoahVerifierTask&
|
|
||||||
operator =(const volatile ShenandoahVerifierTask& t) volatile {
|
|
||||||
(void)const_cast<oop&>(_obj = t._obj);
|
|
||||||
return *this;
|
|
||||||
}
|
|
||||||
|
|
||||||
inline oop obj() const { return _obj; }
|
inline oop obj() const { return _obj; }
|
||||||
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2015, 2019, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2015, 2020, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -87,7 +87,7 @@ inline void ZPhantomKeepAliveOopClosure::do_oop(narrowOop* p) {
|
|||||||
inline void ZPhantomCleanOopClosure::do_oop(oop* p) {
|
inline void ZPhantomCleanOopClosure::do_oop(oop* p) {
|
||||||
// Read the oop once, to make sure the liveness check
|
// Read the oop once, to make sure the liveness check
|
||||||
// and the later clearing uses the same value.
|
// and the later clearing uses the same value.
|
||||||
const oop obj = *(volatile oop*)p;
|
const oop obj = Atomic::load(p);
|
||||||
if (ZBarrier::is_alive_barrier_on_phantom_oop(obj)) {
|
if (ZBarrier::is_alive_barrier_on_phantom_oop(obj)) {
|
||||||
ZBarrier::keep_alive_barrier_on_phantom_oop_field(p);
|
ZBarrier::keep_alive_barrier_on_phantom_oop_field(p);
|
||||||
} else {
|
} else {
|
||||||
|
@ -80,36 +80,28 @@ class oop {
|
|||||||
void register_oop();
|
void register_oop();
|
||||||
void unregister_oop();
|
void unregister_oop();
|
||||||
|
|
||||||
public:
|
void register_if_checking() {
|
||||||
void set_obj(const void* p) {
|
|
||||||
_o = (oopDesc*)p;
|
|
||||||
if (CheckUnhandledOops) register_oop();
|
if (CheckUnhandledOops) register_oop();
|
||||||
}
|
}
|
||||||
|
|
||||||
oop() { set_obj(NULL); }
|
public:
|
||||||
oop(const oop& o) { set_obj(o.obj()); }
|
oop() : _o(NULL) { register_if_checking(); }
|
||||||
oop(const volatile oop& o) { set_obj(o.obj()); }
|
oop(const oop& o) : _o(o._o) { register_if_checking(); }
|
||||||
oop(const void* p) { set_obj(p); }
|
oop(const void* p) : _o((oopDesc*)p) { register_if_checking(); }
|
||||||
~oop() {
|
~oop() {
|
||||||
if (CheckUnhandledOops) unregister_oop();
|
if (CheckUnhandledOops) unregister_oop();
|
||||||
}
|
}
|
||||||
|
|
||||||
oopDesc* obj() const volatile { return _o; }
|
oopDesc* obj() const { return _o; }
|
||||||
|
oopDesc* operator->() const { return _o; }
|
||||||
|
operator oopDesc* () const { return _o; }
|
||||||
|
|
||||||
// General access
|
bool operator==(const oop& o) const { return _o == o._o; }
|
||||||
oopDesc* operator->() const { return obj(); }
|
bool operator==(void *p) const { return _o == p; }
|
||||||
bool operator==(const oop o) const { return obj() == o.obj(); }
|
bool operator!=(const oop& o) const { return _o != o._o; }
|
||||||
bool operator==(void *p) const { return obj() == p; }
|
bool operator!=(void *p) const { return _o != p; }
|
||||||
bool operator!=(const volatile oop o) const { return obj() != o.obj(); }
|
|
||||||
bool operator!=(void *p) const { return obj() != p; }
|
|
||||||
|
|
||||||
// Assignment
|
oop& operator=(const oop& o) { _o = o._o; return *this; }
|
||||||
oop& operator=(const oop& o) { _o = o.obj(); return *this; }
|
|
||||||
volatile oop& operator=(const oop& o) volatile { _o = o.obj(); return *this; }
|
|
||||||
volatile oop& operator=(const volatile oop& o) volatile { _o = o.obj(); return *this; }
|
|
||||||
|
|
||||||
// Explict user conversions
|
|
||||||
operator oopDesc* () const volatile { return obj(); }
|
|
||||||
};
|
};
|
||||||
|
|
||||||
template<>
|
template<>
|
||||||
@ -128,7 +120,6 @@ struct PrimitiveConversions::Translate<oop> : public TrueType {
|
|||||||
type##Oop() : oop() {} \
|
type##Oop() : oop() {} \
|
||||||
type##Oop(const type##Oop& o) : oop(o) {} \
|
type##Oop(const type##Oop& o) : oop(o) {} \
|
||||||
type##Oop(const oop& o) : oop(o) {} \
|
type##Oop(const oop& o) : oop(o) {} \
|
||||||
type##Oop(const volatile oop& o) : oop(o) {} \
|
|
||||||
type##Oop(const void* p) : oop(p) {} \
|
type##Oop(const void* p) : oop(p) {} \
|
||||||
operator type##OopDesc* () const { return (type##OopDesc*)obj(); } \
|
operator type##OopDesc* () const { return (type##OopDesc*)obj(); } \
|
||||||
type##OopDesc* operator->() const { \
|
type##OopDesc* operator->() const { \
|
||||||
@ -138,14 +129,6 @@ struct PrimitiveConversions::Translate<oop> : public TrueType {
|
|||||||
oop::operator=(o); \
|
oop::operator=(o); \
|
||||||
return *this; \
|
return *this; \
|
||||||
} \
|
} \
|
||||||
volatile type##Oop& operator=(const type##Oop& o) volatile { \
|
|
||||||
(void)const_cast<oop&>(oop::operator=(o)); \
|
|
||||||
return *this; \
|
|
||||||
} \
|
|
||||||
volatile type##Oop& operator=(const volatile type##Oop& o) volatile {\
|
|
||||||
(void)const_cast<oop&>(oop::operator=(o)); \
|
|
||||||
return *this; \
|
|
||||||
} \
|
|
||||||
}; \
|
}; \
|
||||||
\
|
\
|
||||||
template<> \
|
template<> \
|
||||||
|
@ -1665,7 +1665,7 @@ void JavaThread::initialize() {
|
|||||||
}
|
}
|
||||||
#endif // INCLUDE_JVMCI
|
#endif // INCLUDE_JVMCI
|
||||||
_reserved_stack_activation = NULL; // stack base not known yet
|
_reserved_stack_activation = NULL; // stack base not known yet
|
||||||
(void)const_cast<oop&>(_exception_oop = oop(NULL));
|
set_exception_oop(oop());
|
||||||
_exception_pc = 0;
|
_exception_pc = 0;
|
||||||
_exception_handler_pc = 0;
|
_exception_handler_pc = 0;
|
||||||
_is_method_handle_return = 0;
|
_is_method_handle_return = 0;
|
||||||
@ -2252,6 +2252,13 @@ bool JavaThread::is_lock_owned(address adr) const {
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
oop JavaThread::exception_oop() const {
|
||||||
|
return Atomic::load(&_exception_oop);
|
||||||
|
}
|
||||||
|
|
||||||
|
void JavaThread::set_exception_oop(oop o) {
|
||||||
|
Atomic::store(&_exception_oop, o);
|
||||||
|
}
|
||||||
|
|
||||||
void JavaThread::add_monitor_chunk(MonitorChunk* chunk) {
|
void JavaThread::add_monitor_chunk(MonitorChunk* chunk) {
|
||||||
chunk->set_next(monitor_chunks());
|
chunk->set_next(monitor_chunks());
|
||||||
|
@ -1574,12 +1574,12 @@ class JavaThread: public Thread {
|
|||||||
#endif // INCLUDE_JVMCI
|
#endif // INCLUDE_JVMCI
|
||||||
|
|
||||||
// Exception handling for compiled methods
|
// Exception handling for compiled methods
|
||||||
oop exception_oop() const { return _exception_oop; }
|
oop exception_oop() const;
|
||||||
address exception_pc() const { return _exception_pc; }
|
address exception_pc() const { return _exception_pc; }
|
||||||
address exception_handler_pc() const { return _exception_handler_pc; }
|
address exception_handler_pc() const { return _exception_handler_pc; }
|
||||||
bool is_method_handle_return() const { return _is_method_handle_return == 1; }
|
bool is_method_handle_return() const { return _is_method_handle_return == 1; }
|
||||||
|
|
||||||
void set_exception_oop(oop o) { (void)const_cast<oop&>(_exception_oop = o); }
|
void set_exception_oop(oop o);
|
||||||
void set_exception_pc(address a) { _exception_pc = a; }
|
void set_exception_pc(address a) { _exception_pc = a; }
|
||||||
void set_exception_handler_pc(address a) { _exception_handler_pc = a; }
|
void set_exception_handler_pc(address a) { _exception_handler_pc = a; }
|
||||||
void set_is_method_handle_return(bool value) { _is_method_handle_return = value ? 1 : 0; }
|
void set_is_method_handle_return(bool value) { _is_method_handle_return = value ? 1 : 0; }
|
||||||
|
@ -38,10 +38,8 @@
|
|||||||
#include "services/gcNotifier.hpp"
|
#include "services/gcNotifier.hpp"
|
||||||
#include "utilities/dtrace.hpp"
|
#include "utilities/dtrace.hpp"
|
||||||
|
|
||||||
MemoryManager::MemoryManager(const char* name) : _name(name) {
|
MemoryManager::MemoryManager(const char* name) :
|
||||||
_num_pools = 0;
|
_num_pools(0), _name(name), _memory_mgr_obj() {}
|
||||||
(void)const_cast<instanceOop&>(_memory_mgr_obj = instanceOop(NULL));
|
|
||||||
}
|
|
||||||
|
|
||||||
int MemoryManager::add_pool(MemoryPool* pool) {
|
int MemoryManager::add_pool(MemoryPool* pool) {
|
||||||
int index = _num_pools;
|
int index = _num_pools;
|
||||||
@ -54,6 +52,10 @@ int MemoryManager::add_pool(MemoryPool* pool) {
|
|||||||
return index;
|
return index;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool MemoryManager::is_manager(instanceHandle mh) const {
|
||||||
|
return mh() == Atomic::load(&_memory_mgr_obj);
|
||||||
|
}
|
||||||
|
|
||||||
MemoryManager* MemoryManager::get_code_cache_memory_manager() {
|
MemoryManager* MemoryManager::get_code_cache_memory_manager() {
|
||||||
return new MemoryManager("CodeCacheManager");
|
return new MemoryManager("CodeCacheManager");
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2003, 2019, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2003, 2020, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -70,7 +70,7 @@ public:
|
|||||||
|
|
||||||
int add_pool(MemoryPool* pool);
|
int add_pool(MemoryPool* pool);
|
||||||
|
|
||||||
bool is_manager(instanceHandle mh) { return mh() == _memory_mgr_obj; }
|
bool is_manager(instanceHandle mh) const;
|
||||||
|
|
||||||
virtual instanceOop get_memory_manager_instance(TRAPS);
|
virtual instanceOop get_memory_manager_instance(TRAPS);
|
||||||
virtual bool is_gc_memory_manager() { return false; }
|
virtual bool is_gc_memory_manager() { return false; }
|
||||||
|
@ -42,24 +42,27 @@ MemoryPool::MemoryPool(const char* name,
|
|||||||
size_t init_size,
|
size_t init_size,
|
||||||
size_t max_size,
|
size_t max_size,
|
||||||
bool support_usage_threshold,
|
bool support_usage_threshold,
|
||||||
bool support_gc_threshold) {
|
bool support_gc_threshold) :
|
||||||
_name = name;
|
_name(name),
|
||||||
_initial_size = init_size;
|
_type(type),
|
||||||
_max_size = max_size;
|
_initial_size(init_size),
|
||||||
(void)const_cast<instanceOop&>(_memory_pool_obj = instanceOop(NULL));
|
_max_size(max_size),
|
||||||
_available_for_allocation = true;
|
_available_for_allocation(true),
|
||||||
_num_managers = 0;
|
_managers(),
|
||||||
_type = type;
|
_num_managers(0),
|
||||||
|
_peak_usage(),
|
||||||
// initialize the max and init size of collection usage
|
_after_gc_usage(init_size, 0, 0, max_size),
|
||||||
_after_gc_usage = MemoryUsage(_initial_size, 0, 0, _max_size);
|
|
||||||
|
|
||||||
_usage_sensor = NULL;
|
|
||||||
_gc_usage_sensor = NULL;
|
|
||||||
// usage threshold supports both high and low threshold
|
// usage threshold supports both high and low threshold
|
||||||
_usage_threshold = new ThresholdSupport(support_usage_threshold, support_usage_threshold);
|
_usage_threshold(new ThresholdSupport(support_usage_threshold, support_usage_threshold)),
|
||||||
// gc usage threshold supports only high threshold
|
// gc usage threshold supports only high threshold
|
||||||
_gc_usage_threshold = new ThresholdSupport(support_gc_threshold, support_gc_threshold);
|
_gc_usage_threshold(new ThresholdSupport(support_gc_threshold, support_gc_threshold)),
|
||||||
|
_usage_sensor(),
|
||||||
|
_gc_usage_sensor(),
|
||||||
|
_memory_pool_obj()
|
||||||
|
{}
|
||||||
|
|
||||||
|
bool MemoryPool::is_pool(instanceHandle pool) const {
|
||||||
|
return pool() == Atomic::load(&_memory_pool_obj);
|
||||||
}
|
}
|
||||||
|
|
||||||
void MemoryPool::add_manager(MemoryManager* mgr) {
|
void MemoryPool::add_manager(MemoryManager* mgr) {
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2003, 2019, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2003, 2020, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -95,7 +95,7 @@ class MemoryPool : public CHeapObj<mtInternal> {
|
|||||||
// max size could be changed
|
// max size could be changed
|
||||||
virtual size_t max_size() const { return _max_size; }
|
virtual size_t max_size() const { return _max_size; }
|
||||||
|
|
||||||
bool is_pool(instanceHandle pool) { return pool() == _memory_pool_obj; }
|
bool is_pool(instanceHandle pool) const;
|
||||||
|
|
||||||
bool available_for_allocation() { return _available_for_allocation; }
|
bool available_for_allocation() { return _available_for_allocation; }
|
||||||
bool set_available_for_allocation(bool value) {
|
bool set_available_for_allocation(bool value) {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user