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:
Kim Barrett 2020-05-25 16:21:25 -04:00
parent bc822ffad8
commit d3042cc401
9 changed files with 56 additions and 71 deletions

View File

@ -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; }

View File

@ -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 {

View File

@ -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<> \

View File

@ -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());

View File

@ -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; }

View File

@ -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");
} }

View File

@ -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; }

View File

@ -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) {

View File

@ -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) {