src/share/vm/memory/universe.hpp

Wed, 19 Jun 2013 11:02:10 +0100

author
chegar
date
Wed, 19 Jun 2013 11:02:10 +0100
changeset 5252
3a0774193f71
parent 5249
ce9ecec70f99
parent 5237
f2110083203d
child 5338
cedf20e2a655
permissions
-rw-r--r--

Merge

     1 /*
     2  * Copyright (c) 1997, 2013, Oracle and/or its affiliates. All rights reserved.
     3  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
     4  *
     5  * This code is free software; you can redistribute it and/or modify it
     6  * under the terms of the GNU General Public License version 2 only, as
     7  * published by the Free Software Foundation.
     8  *
     9  * This code is distributed in the hope that it will be useful, but WITHOUT
    10  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
    11  * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
    12  * version 2 for more details (a copy is included in the LICENSE file that
    13  * accompanied this code).
    14  *
    15  * You should have received a copy of the GNU General Public License version
    16  * 2 along with this work; if not, write to the Free Software Foundation,
    17  * 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  */
    25 #ifndef SHARE_VM_MEMORY_UNIVERSE_HPP
    26 #define SHARE_VM_MEMORY_UNIVERSE_HPP
    28 #include "runtime/handles.hpp"
    29 #include "utilities/array.hpp"
    30 #include "utilities/growableArray.hpp"
    32 // Universe is a name space holding known system classes and objects in the VM.
    33 //
    34 // Loaded classes are accessible through the SystemDictionary.
    35 //
    36 // The object heap is allocated and accessed through Universe, and various allocation
    37 // support is provided. Allocation by the interpreter and compiled code is done inline
    38 // and bails out to Scavenge::invoke_and_allocate.
    40 class CollectedHeap;
    41 class DeferredObjAllocEvent;
    44 // Common parts of a Method* cache. This cache safely interacts with
    45 // the RedefineClasses API.
    46 //
    47 class CommonMethodOopCache : public CHeapObj<mtClass> {
    48   // We save the Klass* and the idnum of Method* in order to get
    49   // the current cached Method*.
    50  private:
    51   Klass*                _klass;
    52   int                   _method_idnum;
    54  public:
    55   CommonMethodOopCache()   { _klass = NULL; _method_idnum = -1; }
    56   ~CommonMethodOopCache()  { _klass = NULL; _method_idnum = -1; }
    58   void     init(Klass* k, Method* m, TRAPS);
    59   Klass* klass() const         { return _klass; }
    60   int      method_idnum() const  { return _method_idnum; }
    62   // Enhanced Class Redefinition support
    63   void classes_do(void f(Klass*)) {
    64     f(_klass);
    65   }
    67   // CDS support.  Replace the klass in this with the archive version
    68   // could use this for Enhanced Class Redefinition also.
    69   void serialize(SerializeClosure* f) {
    70     f->do_ptr((void**)&_klass);
    71   }
    72 };
    75 // A helper class for caching a Method* when the user of the cache
    76 // cares about all versions of the Method*.
    77 //
    78 class ActiveMethodOopsCache : public CommonMethodOopCache {
    79   // This subclass adds weak references to older versions of the
    80   // Method* and a query method for a Method*.
    82  private:
    83   // If the cached Method* has not been redefined, then
    84   // _prev_methods will be NULL. If all of the previous
    85   // versions of the method have been collected, then
    86   // _prev_methods can have a length of zero.
    87   GrowableArray<Method*>* _prev_methods;
    89  public:
    90   ActiveMethodOopsCache()   { _prev_methods = NULL; }
    91   ~ActiveMethodOopsCache();
    93   void add_previous_version(Method* method);
    94   bool is_same_method(const Method* method) const;
    95 };
    98 // A helper class for caching a Method* when the user of the cache
    99 // only cares about the latest version of the Method*.
   100 //
   101 class LatestMethodOopCache : public CommonMethodOopCache {
   102   // This subclass adds a getter method for the latest Method*.
   104  public:
   105   Method* get_Method();
   106 };
   108 // For UseCompressedOops and UseCompressedKlassPointers.
   109 struct NarrowPtrStruct {
   110   // Base address for oop/klass-within-java-object materialization.
   111   // NULL if using wide oops/klasses or zero based narrow oops/klasses.
   112   address _base;
   113   // Number of shift bits for encoding/decoding narrow ptrs.
   114   // 0 if using wide ptrs or zero based unscaled narrow ptrs,
   115   // LogMinObjAlignmentInBytes/LogKlassAlignmentInBytes otherwise.
   116   int     _shift;
   117   // Generate code with implicit null checks for narrow ptrs.
   118   bool    _use_implicit_null_checks;
   119 };
   121 enum VerifyOption {
   122       VerifyOption_Default = 0,
   124       // G1
   125       VerifyOption_G1UsePrevMarking = VerifyOption_Default,
   126       VerifyOption_G1UseNextMarking = VerifyOption_G1UsePrevMarking + 1,
   127       VerifyOption_G1UseMarkWord    = VerifyOption_G1UseNextMarking + 1
   128 };
   130 class Universe: AllStatic {
   131   // Ugh.  Universe is much too friendly.
   132   friend class MarkSweep;
   133   friend class oopDesc;
   134   friend class ClassLoader;
   135   friend class Arguments;
   136   friend class SystemDictionary;
   137   friend class VMStructs;
   138   friend class VM_PopulateDumpSharedSpace;
   140   friend jint  universe_init();
   141   friend void  universe2_init();
   142   friend bool  universe_post_init();
   144  private:
   145   // Known classes in the VM
   146   static Klass* _boolArrayKlassObj;
   147   static Klass* _byteArrayKlassObj;
   148   static Klass* _charArrayKlassObj;
   149   static Klass* _intArrayKlassObj;
   150   static Klass* _shortArrayKlassObj;
   151   static Klass* _longArrayKlassObj;
   152   static Klass* _singleArrayKlassObj;
   153   static Klass* _doubleArrayKlassObj;
   154   static Klass* _typeArrayKlassObjs[T_VOID+1];
   156   static Klass* _objectArrayKlassObj;
   158   // Known objects in the VM
   160   // Primitive objects
   161   static oop _int_mirror;
   162   static oop _float_mirror;
   163   static oop _double_mirror;
   164   static oop _byte_mirror;
   165   static oop _bool_mirror;
   166   static oop _char_mirror;
   167   static oop _long_mirror;
   168   static oop _short_mirror;
   169   static oop _void_mirror;
   171   static oop          _main_thread_group;             // Reference to the main thread group object
   172   static oop          _system_thread_group;           // Reference to the system thread group object
   174   static objArrayOop  _the_empty_class_klass_array;   // Canonicalized obj array of type java.lang.Class
   175   static oop          _the_null_string;               // A cache of "null" as a Java string
   176   static oop          _the_min_jint_string;          // A cache of "-2147483648" as a Java string
   177   static LatestMethodOopCache* _finalizer_register_cache; // static method for registering finalizable objects
   178   static LatestMethodOopCache* _loader_addClass_cache;    // method for registering loaded classes in class loader vector
   179   static LatestMethodOopCache* _pd_implies_cache;         // method for checking protection domain attributes
   180   static ActiveMethodOopsCache* _reflect_invoke_cache;    // method for security checks
   181   static oop          _out_of_memory_error_java_heap; // preallocated error object (no backtrace)
   182   static oop          _out_of_memory_error_perm_gen;  // preallocated error object (no backtrace)
   183   static oop          _out_of_memory_error_array_size;// preallocated error object (no backtrace)
   184   static oop          _out_of_memory_error_gc_overhead_limit; // preallocated error object (no backtrace)
   186   static Array<int>*       _the_empty_int_array;    // Canonicalized int array
   187   static Array<u2>*        _the_empty_short_array;  // Canonicalized short array
   188   static Array<Klass*>*  _the_empty_klass_array;  // Canonicalized klass obj array
   189   static Array<Method*>* _the_empty_method_array; // Canonicalized method obj array
   191   static Array<Klass*>*  _the_array_interfaces_array;
   193   // array of preallocated error objects with backtrace
   194   static objArrayOop   _preallocated_out_of_memory_error_array;
   196   // number of preallocated error objects available for use
   197   static volatile jint _preallocated_out_of_memory_error_avail_count;
   199   static oop          _null_ptr_exception_instance;   // preallocated exception object
   200   static oop          _arithmetic_exception_instance; // preallocated exception object
   201   static oop          _virtual_machine_error_instance; // preallocated exception object
   202   // The object used as an exception dummy when exceptions are thrown for
   203   // the vm thread.
   204   static oop          _vm_exception;
   206   // The particular choice of collected heap.
   207   static CollectedHeap* _collectedHeap;
   209   // For UseCompressedOops.
   210   static struct NarrowPtrStruct _narrow_oop;
   211   // For UseCompressedKlassPointers.
   212   static struct NarrowPtrStruct _narrow_klass;
   213   static address _narrow_ptrs_base;
   215   // Aligned size of the metaspace.
   216   static size_t _class_metaspace_size;
   218   // array of dummy objects used with +FullGCAlot
   219   debug_only(static objArrayOop _fullgc_alot_dummy_array;)
   220   // index of next entry to clear
   221   debug_only(static int         _fullgc_alot_dummy_next;)
   223   // Compiler/dispatch support
   224   static int  _base_vtable_size;                      // Java vtbl size of klass Object (in words)
   226   // Initialization
   227   static bool _bootstrapping;                         // true during genesis
   228   static bool _fully_initialized;                     // true after universe_init and initialize_vtables called
   230   // the array of preallocated errors with backtraces
   231   static objArrayOop  preallocated_out_of_memory_errors()     { return _preallocated_out_of_memory_error_array; }
   233   // generate an out of memory error; if possible using an error with preallocated backtrace;
   234   // otherwise return the given default error.
   235   static oop        gen_out_of_memory_error(oop default_err);
   237   // Historic gc information
   238   static size_t _heap_capacity_at_last_gc;
   239   static size_t _heap_used_at_last_gc;
   241   static jint initialize_heap();
   242   static void initialize_basic_type_mirrors(TRAPS);
   243   static void fixup_mirrors(TRAPS);
   245   static void reinitialize_vtable_of(KlassHandle h_k, TRAPS);
   246   static void reinitialize_itables(TRAPS);
   247   static void compute_base_vtable_size();             // compute vtable size of class Object
   249   static void genesis(TRAPS);                         // Create the initial world
   251   // Mirrors for primitive classes (created eagerly)
   252   static oop check_mirror(oop m) {
   253     assert(m != NULL, "mirror not initialized");
   254     return m;
   255   }
   257   static void     set_narrow_oop_base(address base) {
   258     assert(UseCompressedOops, "no compressed oops?");
   259     _narrow_oop._base    = base;
   260   }
   261   static void     set_narrow_klass_base(address base) {
   262     assert(UseCompressedKlassPointers, "no compressed klass ptrs?");
   263     _narrow_klass._base   = base;
   264   }
   265   static void     set_narrow_oop_use_implicit_null_checks(bool use) {
   266     assert(UseCompressedOops, "no compressed ptrs?");
   267     _narrow_oop._use_implicit_null_checks   = use;
   268   }
   269   static bool     reserve_metaspace_helper(bool with_base = false);
   270   static ReservedHeapSpace reserve_heap_metaspace(size_t heap_size, size_t alignment, bool& contiguous);
   272   static size_t  class_metaspace_size() {
   273     return _class_metaspace_size;
   274   }
   275   static void    set_class_metaspace_size(size_t metaspace_size) {
   276     _class_metaspace_size = metaspace_size;
   277   }
   279   // Debugging
   280   static int _verify_count;                           // number of verifies done
   281   // True during call to verify().  Should only be set/cleared in verify().
   282   static bool _verify_in_progress;
   284   static void compute_verify_oop_data();
   286  public:
   287   // Known classes in the VM
   288   static Klass* boolArrayKlassObj()                 { return _boolArrayKlassObj;   }
   289   static Klass* byteArrayKlassObj()                 { return _byteArrayKlassObj;   }
   290   static Klass* charArrayKlassObj()                 { return _charArrayKlassObj;   }
   291   static Klass* intArrayKlassObj()                  { return _intArrayKlassObj;    }
   292   static Klass* shortArrayKlassObj()                { return _shortArrayKlassObj;  }
   293   static Klass* longArrayKlassObj()                 { return _longArrayKlassObj;   }
   294   static Klass* singleArrayKlassObj()               { return _singleArrayKlassObj; }
   295   static Klass* doubleArrayKlassObj()               { return _doubleArrayKlassObj; }
   297   static Klass* objectArrayKlassObj() {
   298     return _objectArrayKlassObj;
   299   }
   301   static Klass* typeArrayKlassObj(BasicType t) {
   302     assert((uint)t < T_VOID+1, err_msg("range check for type: %s", type2name(t)));
   303     assert(_typeArrayKlassObjs[t] != NULL, "domain check");
   304     return _typeArrayKlassObjs[t];
   305   }
   307   // Known objects in the VM
   308   static oop int_mirror()                   { return check_mirror(_int_mirror); }
   309   static oop float_mirror()                 { return check_mirror(_float_mirror); }
   310   static oop double_mirror()                { return check_mirror(_double_mirror); }
   311   static oop byte_mirror()                  { return check_mirror(_byte_mirror); }
   312   static oop bool_mirror()                  { return check_mirror(_bool_mirror); }
   313   static oop char_mirror()                  { return check_mirror(_char_mirror); }
   314   static oop long_mirror()                  { return check_mirror(_long_mirror); }
   315   static oop short_mirror()                 { return check_mirror(_short_mirror); }
   316   static oop void_mirror()                  { return check_mirror(_void_mirror); }
   318   // table of same
   319   static oop _mirrors[T_VOID+1];
   321   static oop java_mirror(BasicType t) {
   322     assert((uint)t < T_VOID+1, "range check");
   323     return check_mirror(_mirrors[t]);
   324   }
   325   static oop      main_thread_group()                 { return _main_thread_group; }
   326   static void set_main_thread_group(oop group)        { _main_thread_group = group;}
   328   static oop      system_thread_group()               { return _system_thread_group; }
   329   static void set_system_thread_group(oop group)      { _system_thread_group = group;}
   331   static objArrayOop  the_empty_class_klass_array ()  { return _the_empty_class_klass_array;   }
   332   static Array<Klass*>* the_array_interfaces_array() { return _the_array_interfaces_array;   }
   333   static oop          the_null_string()               { return _the_null_string;               }
   334   static oop          the_min_jint_string()          { return _the_min_jint_string;          }
   335   static Method*      finalizer_register_method()     { return _finalizer_register_cache->get_Method(); }
   336   static Method*      loader_addClass_method()        { return _loader_addClass_cache->get_Method(); }
   338   static Method*      protection_domain_implies_method() { return _pd_implies_cache->get_Method(); }
   339   static ActiveMethodOopsCache* reflect_invoke_cache() { return _reflect_invoke_cache; }
   341   static oop          null_ptr_exception_instance()   { return _null_ptr_exception_instance;   }
   342   static oop          arithmetic_exception_instance() { return _arithmetic_exception_instance; }
   343   static oop          virtual_machine_error_instance() { return _virtual_machine_error_instance; }
   344   static oop          vm_exception()                  { return _vm_exception; }
   346   static Array<int>*       the_empty_int_array()    { return _the_empty_int_array; }
   347   static Array<u2>*        the_empty_short_array()  { return _the_empty_short_array; }
   348   static Array<Method*>* the_empty_method_array() { return _the_empty_method_array; }
   349   static Array<Klass*>*  the_empty_klass_array()  { return _the_empty_klass_array; }
   351   // OutOfMemoryError support. Returns an error with the required message. The returned error
   352   // may or may not have a backtrace. If error has a backtrace then the stack trace is already
   353   // filled in.
   354   static oop out_of_memory_error_java_heap()          { return gen_out_of_memory_error(_out_of_memory_error_java_heap);  }
   355   static oop out_of_memory_error_perm_gen()           { return gen_out_of_memory_error(_out_of_memory_error_perm_gen);   }
   356   static oop out_of_memory_error_array_size()         { return gen_out_of_memory_error(_out_of_memory_error_array_size); }
   357   static oop out_of_memory_error_gc_overhead_limit()  { return gen_out_of_memory_error(_out_of_memory_error_gc_overhead_limit);  }
   359   // Accessors needed for fast allocation
   360   static Klass** boolArrayKlassObj_addr()           { return &_boolArrayKlassObj;   }
   361   static Klass** byteArrayKlassObj_addr()           { return &_byteArrayKlassObj;   }
   362   static Klass** charArrayKlassObj_addr()           { return &_charArrayKlassObj;   }
   363   static Klass** intArrayKlassObj_addr()            { return &_intArrayKlassObj;    }
   364   static Klass** shortArrayKlassObj_addr()          { return &_shortArrayKlassObj;  }
   365   static Klass** longArrayKlassObj_addr()           { return &_longArrayKlassObj;   }
   366   static Klass** singleArrayKlassObj_addr()         { return &_singleArrayKlassObj; }
   367   static Klass** doubleArrayKlassObj_addr()         { return &_doubleArrayKlassObj; }
   368   static Klass** objectArrayKlassObj_addr()         { return &_objectArrayKlassObj; }
   370   // The particular choice of collected heap.
   371   static CollectedHeap* heap() { return _collectedHeap; }
   373   // For UseCompressedOops
   374   // Narrow Oop encoding mode:
   375   // 0 - Use 32-bits oops without encoding when
   376   //     NarrowOopHeapBaseMin + heap_size < 4Gb
   377   // 1 - Use zero based compressed oops with encoding when
   378   //     NarrowOopHeapBaseMin + heap_size < 32Gb
   379   // 2 - Use compressed oops with heap base + encoding.
   380   enum NARROW_OOP_MODE {
   381     UnscaledNarrowOop  = 0,
   382     ZeroBasedNarrowOop = 1,
   383     HeapBasedNarrowOop = 2
   384   };
   385   static NARROW_OOP_MODE narrow_oop_mode();
   386   static const char* narrow_oop_mode_to_string(NARROW_OOP_MODE mode);
   387   static char*    preferred_heap_base(size_t heap_size, NARROW_OOP_MODE mode);
   388   static char*    preferred_metaspace_base(size_t heap_size, NARROW_OOP_MODE mode);
   389   static address  narrow_oop_base()                       { return  _narrow_oop._base; }
   390   static bool  is_narrow_oop_base(void* addr)             { return (narrow_oop_base() == (address)addr); }
   391   static int      narrow_oop_shift()                      { return  _narrow_oop._shift; }
   392   static bool     narrow_oop_use_implicit_null_checks()   { return  _narrow_oop._use_implicit_null_checks; }
   394   // For UseCompressedKlassPointers
   395   static address  narrow_klass_base()                     { return  _narrow_klass._base; }
   396   static bool  is_narrow_klass_base(void* addr)           { return (narrow_klass_base() == (address)addr); }
   397   static int      narrow_klass_shift()                    { return  _narrow_klass._shift; }
   398   static bool     narrow_klass_use_implicit_null_checks() { return  _narrow_klass._use_implicit_null_checks; }
   400   static address* narrow_ptrs_base_addr()                 { return &_narrow_ptrs_base; }
   401   static void     set_narrow_ptrs_base(address a)         { _narrow_ptrs_base = a; }
   402   static address  narrow_ptrs_base()                      { return _narrow_ptrs_base; }
   404   // this is set in vm_version on sparc (and then reset in universe afaict)
   405   static void     set_narrow_oop_shift(int shift)         {
   406     _narrow_oop._shift   = shift;
   407   }
   409   static void     set_narrow_klass_shift(int shift)       {
   410     assert(shift == 0 || shift == LogKlassAlignmentInBytes, "invalid shift for klass ptrs");
   411     _narrow_klass._shift   = shift;
   412   }
   414   // Reserve Java heap and determine CompressedOops mode
   415   static ReservedSpace reserve_heap(size_t heap_size, size_t alignment);
   417   // Historic gc information
   418   static size_t get_heap_capacity_at_last_gc()         { return _heap_capacity_at_last_gc; }
   419   static size_t get_heap_free_at_last_gc()             { return _heap_capacity_at_last_gc - _heap_used_at_last_gc; }
   420   static size_t get_heap_used_at_last_gc()             { return _heap_used_at_last_gc; }
   421   static void update_heap_info_at_gc();
   423   // Testers
   424   static bool is_bootstrapping()                      { return _bootstrapping; }
   425   static bool is_fully_initialized()                  { return _fully_initialized; }
   427   static inline bool element_type_should_be_aligned(BasicType type);
   428   static inline bool field_type_should_be_aligned(BasicType type);
   429   static bool        on_page_boundary(void* addr);
   430   static bool        should_fill_in_stack_trace(Handle throwable);
   431   static void check_alignment(uintx size, uintx alignment, const char* name);
   433   // Finalizer support.
   434   static void run_finalizers_on_exit();
   436   // Iteration
   438   // Apply "f" to the addresses of all the direct heap pointers maintained
   439   // as static fields of "Universe".
   440   static void oops_do(OopClosure* f, bool do_all = false);
   442   // CDS support
   443   static void serialize(SerializeClosure* f, bool do_all = false);
   445   // Apply "f" to all klasses for basic types (classes not present in
   446   // SystemDictionary).
   447   static void basic_type_classes_do(void f(Klass*));
   449   // For sharing -- fill in a list of known vtable pointers.
   450   static void init_self_patching_vtbl_list(void** list, int count);
   452   // Debugging
   453   static bool verify_in_progress() { return _verify_in_progress; }
   454   static void verify(VerifyOption option, const char* prefix, bool silent = VerifySilently);
   455   static void verify(const char* prefix, bool silent = VerifySilently) {
   456     verify(VerifyOption_Default, prefix, silent);
   457   }
   458   static void verify(bool silent = VerifySilently) {
   459     verify("", silent);
   460   }
   462   static int  verify_count()       { return _verify_count; }
   463   // The default behavior is to call print_on() on gclog_or_tty.
   464   static void print();
   465   // The extended parameter determines which method on the heap will
   466   // be called: print_on() (extended == false) or print_extended_on()
   467   // (extended == true).
   468   static void print_on(outputStream* st, bool extended = false);
   469   static void print_heap_at_SIGBREAK();
   470   static void print_heap_before_gc() { print_heap_before_gc(gclog_or_tty); }
   471   static void print_heap_after_gc()  { print_heap_after_gc(gclog_or_tty); }
   472   static void print_heap_before_gc(outputStream* st, bool ignore_extended = false);
   473   static void print_heap_after_gc(outputStream* st, bool ignore_extended = false);
   475   // Change the number of dummy objects kept reachable by the full gc dummy
   476   // array; this should trigger relocation in a sliding compaction collector.
   477   debug_only(static bool release_fullgc_alot_dummy();)
   478   // The non-oop pattern (see compiledIC.hpp, etc)
   479   static void*   non_oop_word();
   481   // Oop verification (see MacroAssembler::verify_oop)
   482   static uintptr_t verify_oop_mask()          PRODUCT_RETURN0;
   483   static uintptr_t verify_oop_bits()          PRODUCT_RETURN0;
   484   static uintptr_t verify_mark_bits()         PRODUCT_RETURN0;
   485   static uintptr_t verify_mark_mask()         PRODUCT_RETURN0;
   487   // Flushing and deoptimization
   488   static void flush_dependents_on(instanceKlassHandle dependee);
   489   static void flush_dependents_on(Handle call_site, Handle method_handle);
   490 #ifdef HOTSWAP
   491   // Flushing and deoptimization in case of evolution
   492   static void flush_evol_dependents_on(instanceKlassHandle dependee);
   493 #endif // HOTSWAP
   494   // Support for fullspeed debugging
   495   static void flush_dependents_on_method(methodHandle dependee);
   497   // Compiler support
   498   static int base_vtable_size()               { return _base_vtable_size; }
   499 };
   501 class DeferredObjAllocEvent : public CHeapObj<mtInternal> {
   502   private:
   503     oop    _oop;
   504     size_t _bytesize;
   505     jint   _arena_id;
   507   public:
   508     DeferredObjAllocEvent(const oop o, const size_t s, const jint id) {
   509       _oop      = o;
   510       _bytesize = s;
   511       _arena_id = id;
   512     }
   514     ~DeferredObjAllocEvent() {
   515     }
   517     jint   arena_id() { return _arena_id; }
   518     size_t bytesize() { return _bytesize; }
   519     oop    get_oop()  { return _oop; }
   520 };
   522 #endif // SHARE_VM_MEMORY_UNIVERSE_HPP

mercurial