8041623: Solaris Studio 12.4 C++ 5.13, CHECK_UNHANDLED_OOPS use of class oop's copy constructor definitions causing error level diagnostic
Fix several minor compilation issues with volatile oops for CHECK_UNHANDLED_OOPS support. Reviewed-by: coleenp, hseigel
This commit is contained in:
parent
436e1ecdf2
commit
5ff7186a1c
@ -1181,7 +1181,7 @@ public:
|
|||||||
static oop target( oop site) { return site->obj_field( _target_offset); }
|
static oop target( oop site) { return site->obj_field( _target_offset); }
|
||||||
static void set_target( oop site, oop target) { site->obj_field_put( _target_offset, target); }
|
static void set_target( oop site, oop target) { site->obj_field_put( _target_offset, target); }
|
||||||
|
|
||||||
static volatile oop target_volatile(oop site) { return site->obj_field_volatile( _target_offset); }
|
static volatile oop target_volatile(oop site) { return oop((oopDesc *)(site->obj_field_volatile(_target_offset))); }
|
||||||
static void set_target_volatile(oop site, oop target) { site->obj_field_put_volatile(_target_offset, target); }
|
static void set_target_volatile(oop site, oop target) { site->obj_field_put_volatile(_target_offset, target); }
|
||||||
|
|
||||||
// Testers
|
// Testers
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1997, 2013, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1997, 2014, 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
|
||||||
@ -112,9 +112,7 @@ public:
|
|||||||
|
|
||||||
// Assignment
|
// Assignment
|
||||||
oop& operator=(const oop& o) { _o = o.obj(); return *this; }
|
oop& operator=(const oop& o) { _o = o.obj(); return *this; }
|
||||||
#ifndef SOLARIS
|
|
||||||
volatile oop& operator=(const oop& o) volatile { _o = o.obj(); return *this; }
|
volatile oop& operator=(const oop& o) volatile { _o = o.obj(); return *this; }
|
||||||
#endif
|
|
||||||
volatile oop& operator=(const volatile oop& o) volatile { _o = o.obj(); return *this; }
|
volatile oop& operator=(const volatile oop& o) volatile { _o = o.obj(); return *this; }
|
||||||
|
|
||||||
// Explict user conversions
|
// Explict user conversions
|
||||||
@ -123,11 +121,10 @@ public:
|
|||||||
operator void* () const volatile { return (void *)obj(); }
|
operator void* () const volatile { return (void *)obj(); }
|
||||||
#endif
|
#endif
|
||||||
operator HeapWord* () const { return (HeapWord*)obj(); }
|
operator HeapWord* () const { return (HeapWord*)obj(); }
|
||||||
operator oopDesc* () const { return obj(); }
|
operator oopDesc* () const volatile { return obj(); }
|
||||||
operator intptr_t* () const { return (intptr_t*)obj(); }
|
operator intptr_t* () const { return (intptr_t*)obj(); }
|
||||||
operator PromotedObject* () const { return (PromotedObject*)obj(); }
|
operator PromotedObject* () const { return (PromotedObject*)obj(); }
|
||||||
operator markOop () const { return markOop(obj()); }
|
operator markOop () const { return markOop(obj()); }
|
||||||
|
|
||||||
operator address () const { return (address)obj(); }
|
operator address () const { return (address)obj(); }
|
||||||
|
|
||||||
// from javaCalls.cpp
|
// from javaCalls.cpp
|
||||||
@ -161,11 +158,10 @@ public:
|
|||||||
oop::operator=(o); \
|
oop::operator=(o); \
|
||||||
return *this; \
|
return *this; \
|
||||||
} \
|
} \
|
||||||
NOT_SOLARIS( \
|
|
||||||
volatile type##Oop& operator=(const type##Oop& o) volatile { \
|
volatile type##Oop& operator=(const type##Oop& o) volatile { \
|
||||||
(void)const_cast<oop&>(oop::operator=(o)); \
|
(void)const_cast<oop&>(oop::operator=(o)); \
|
||||||
return *this; \
|
return *this; \
|
||||||
}) \
|
} \
|
||||||
volatile type##Oop& operator=(const volatile type##Oop& o) volatile {\
|
volatile type##Oop& operator=(const volatile type##Oop& o) volatile {\
|
||||||
(void)const_cast<oop&>(oop::operator=(o)); \
|
(void)const_cast<oop&>(oop::operator=(o)); \
|
||||||
return *this; \
|
return *this; \
|
||||||
|
@ -1434,7 +1434,7 @@ void JavaThread::initialize() {
|
|||||||
_in_deopt_handler = 0;
|
_in_deopt_handler = 0;
|
||||||
_doing_unsafe_access = false;
|
_doing_unsafe_access = false;
|
||||||
_stack_guard_state = stack_guard_unused;
|
_stack_guard_state = stack_guard_unused;
|
||||||
(void)const_cast<oop&>(_exception_oop = NULL);
|
(void)const_cast<oop&>(_exception_oop = oop(NULL));
|
||||||
_exception_pc = 0;
|
_exception_pc = 0;
|
||||||
_exception_handler_pc = 0;
|
_exception_handler_pc = 0;
|
||||||
_is_method_handle_return = 0;
|
_is_method_handle_return = 0;
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2003, 2013, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2003, 2014, 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
|
||||||
@ -39,7 +39,7 @@
|
|||||||
|
|
||||||
MemoryManager::MemoryManager() {
|
MemoryManager::MemoryManager() {
|
||||||
_num_pools = 0;
|
_num_pools = 0;
|
||||||
(void)const_cast<instanceOop&>(_memory_mgr_obj = NULL);
|
(void)const_cast<instanceOop&>(_memory_mgr_obj = instanceOop(NULL));
|
||||||
}
|
}
|
||||||
|
|
||||||
void MemoryManager::add_pool(MemoryPool* pool) {
|
void MemoryManager::add_pool(MemoryPool* pool) {
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2003, 2013, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2003, 2014, 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
|
||||||
@ -46,7 +46,7 @@ MemoryPool::MemoryPool(const char* name,
|
|||||||
_name = name;
|
_name = name;
|
||||||
_initial_size = init_size;
|
_initial_size = init_size;
|
||||||
_max_size = max_size;
|
_max_size = max_size;
|
||||||
(void)const_cast<instanceOop&>(_memory_pool_obj = NULL);
|
(void)const_cast<instanceOop&>(_memory_pool_obj = instanceOop(NULL));
|
||||||
_available_for_allocation = true;
|
_available_for_allocation = true;
|
||||||
_num_managers = 0;
|
_num_managers = 0;
|
||||||
_type = type;
|
_type = type;
|
||||||
|
Loading…
Reference in New Issue
Block a user