oopsHierarchy.hpp revision 1472:c18cbe5936b8
1195360Simp/*
2195360Simp * Copyright (c) 1997, 2009, Oracle and/or its affiliates. All rights reserved.
3195360Simp * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4195360Simp *
5195360Simp * This code is free software; you can redistribute it and/or modify it
6195360Simp * under the terms of the GNU General Public License version 2 only, as
7195360Simp * published by the Free Software Foundation.
8195360Simp *
9195360Simp * This code is distributed in the hope that it will be useful, but WITHOUT
10195360Simp * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
11195360Simp * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
12195360Simp * version 2 for more details (a copy is included in the LICENSE file that
13195360Simp * accompanied this code).
14195360Simp *
15195360Simp * You should have received a copy of the GNU General Public License version
16195360Simp * 2 along with this work; if not, write to the Free Software Foundation,
17195360Simp * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
18 *
19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
20 * or visit www.oracle.com if you need additional information or have any
21 * questions.
22 *
23 */
24
25// OBJECT hierarchy
26// This hierarchy is a representation hierarchy, i.e. if A is a superclass
27// of B, A's representation is a prefix of B's representation.
28
29typedef juint narrowOop; // Offset instead of address for an oop within a java object
30typedef class klassOopDesc* wideKlassOop; // to keep SA happy and unhandled oop
31                                          // detector happy.
32typedef void* OopOrNarrowOopStar;
33
34#ifndef CHECK_UNHANDLED_OOPS
35
36typedef class oopDesc*                            oop;
37typedef class   instanceOopDesc*            instanceOop;
38typedef class   methodOopDesc*                    methodOop;
39typedef class   constMethodOopDesc*            constMethodOop;
40typedef class   methodDataOopDesc*            methodDataOop;
41typedef class   arrayOopDesc*                    arrayOop;
42typedef class     objArrayOopDesc*            objArrayOop;
43typedef class     typeArrayOopDesc*            typeArrayOop;
44typedef class   constantPoolOopDesc*            constantPoolOop;
45typedef class   constantPoolCacheOopDesc*   constantPoolCacheOop;
46typedef class   symbolOopDesc*                    symbolOop;
47typedef class   klassOopDesc*                    klassOop;
48typedef class   markOopDesc*                    markOop;
49typedef class   compiledICHolderOopDesc*    compiledICHolderOop;
50
51#else
52
53
54// When CHECK_UNHANDLED_OOPS is defined, an "oop" is a class with a
55// carefully chosen set of constructors and conversion operators to go
56// to and from the underlying oopDesc pointer type.
57//
58// Because oop and its subclasses <type>Oop are class types, arbitrary
59// conversions are not accepted by the compiler, and you may get a message
60// about overloading ambiguity (between long and int is common when converting
61// from a constant in 64 bit mode), or unable to convert from type to 'oop'.
62// Applying a cast to one of these conversion operators first will get to the
63// underlying oopDesc* type if appropriate.
64// Converting NULL to oop to Handle implicit is no longer accepted by the
65// compiler because there are too many steps in the conversion.  Use Handle()
66// instead, which generates less code anyway.
67
68class Thread;
69typedef class   markOopDesc*                markOop;
70class PromotedObject;
71
72
73class oop {
74  oopDesc* _o;
75
76  void register_oop();
77  void unregister_oop();
78
79  // friend class markOop;
80public:
81  void set_obj(const void* p)         {
82    raw_set_obj(p);
83    if (CheckUnhandledOops) register_oop();
84  }
85  void raw_set_obj(const void* p)     { _o = (oopDesc*)p; }
86
87  oop()                               { set_obj(NULL); }
88  oop(const volatile oop& o)          { set_obj(o.obj()); }
89  oop(const void* p)                  { set_obj(p); }
90  oop(intptr_t i)                     { set_obj((void *)i); }
91#ifdef _LP64
92  oop(int i)                          { set_obj((void *)i); }
93#endif
94  ~oop()                              {
95    if (CheckUnhandledOops) unregister_oop();
96  }
97
98  oopDesc* obj()  const volatile      { return _o; }
99
100  // General access
101  oopDesc*  operator->() const        { return obj(); }
102  bool operator==(const oop o) const  { return obj() == o.obj(); }
103  bool operator==(void *p) const      { return obj() == p; }
104  bool operator!=(const oop o) const  { return obj() != o.obj(); }
105  bool operator!=(void *p) const      { return obj() != p; }
106  bool operator==(intptr_t p) const   { return obj() == (oopDesc*)p; }
107  bool operator!=(intptr_t p) const   { return obj() != (oopDesc*)p; }
108
109  bool operator<(oop o) const         { return obj() < o.obj(); }
110  bool operator>(oop o) const         { return obj() > o.obj(); }
111  bool operator<=(oop o) const        { return obj() <= o.obj(); }
112  bool operator>=(oop o) const        { return obj() >= o.obj(); }
113  bool operator!() const              { return !obj(); }
114
115  // Cast
116  operator void* () const             { return (void *)obj(); }
117  operator HeapWord* () const         { return (HeapWord*)obj(); }
118  operator oopDesc* () const          { return obj(); }
119  operator intptr_t* () const         { return (intptr_t*)obj(); }
120  operator PromotedObject* () const   { return (PromotedObject*)obj(); }
121  operator markOop () const           { return markOop(obj()); }
122
123  operator address   () const         { return (address)obj(); }
124  operator intptr_t () const          { return (intptr_t)obj(); }
125
126  // from javaCalls.cpp
127  operator jobject () const           { return (jobject)obj(); }
128  // from javaClasses.cpp
129  operator JavaThread* () const       { return (JavaThread*)obj(); }
130
131#ifndef _LP64
132  // from jvm.cpp
133  operator jlong* () const            { return (jlong*)obj(); }
134#endif
135
136  // from parNewGeneration and other things that want to get to the end of
137  // an oop for stuff (like constMethodKlass.cpp, objArrayKlass.cpp)
138  operator oop* () const              { return (oop *)obj(); }
139};
140
141#define DEF_OOP(type)                                                      \
142   class type##OopDesc;                                                    \
143   class type##Oop : public oop {                                          \
144     public:                                                               \
145       type##Oop() : oop() {}                                              \
146       type##Oop(const volatile oop& o) : oop(o) {}                        \
147       type##Oop(const void* p) : oop(p) {}                                \
148       operator type##OopDesc* () const { return (type##OopDesc*)obj(); }  \
149       type##OopDesc* operator->() const {                                 \
150            return (type##OopDesc*)obj();                                  \
151       }                                                                   \
152   };                                                                      \
153
154DEF_OOP(instance);
155DEF_OOP(method);
156DEF_OOP(methodData);
157DEF_OOP(array);
158DEF_OOP(constMethod);
159DEF_OOP(constantPool);
160DEF_OOP(constantPoolCache);
161DEF_OOP(objArray);
162DEF_OOP(typeArray);
163DEF_OOP(symbol);
164DEF_OOP(klass);
165DEF_OOP(compiledICHolder);
166
167#endif // CHECK_UNHANDLED_OOPS
168
169// The klass hierarchy is separate from the oop hierarchy.
170
171class Klass;
172class   instanceKlass;
173class     instanceRefKlass;
174class   methodKlass;
175class   constMethodKlass;
176class   methodDataKlass;
177class   klassKlass;
178class     instanceKlassKlass;
179class     arrayKlassKlass;
180class       objArrayKlassKlass;
181class       typeArrayKlassKlass;
182class   arrayKlass;
183class     objArrayKlass;
184class     typeArrayKlass;
185class   constantPoolKlass;
186class   constantPoolCacheKlass;
187class   symbolKlass;
188class   compiledICHolderKlass;
189