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:
Lois Foltan 2014-05-29 08:58:51 -04:00
parent 436e1ecdf2
commit 5ff7186a1c
5 changed files with 9 additions and 13 deletions

View File

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

View File

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

View File

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

View File

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

View File

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