src/share/vm/memory/universe.hpp

Fri, 05 Apr 2013 10:18:36 -0400

author
mullan
date
Fri, 05 Apr 2013 10:18:36 -0400
changeset 5242
b295e132102d
parent 4523
10d5f25a7c67
child 5247
7ee0d5c53c78
permissions
-rw-r--r--

8001330: Improve on checking order
Reviewed-by: acorn, hawtin

     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* const method);
    94   bool is_same_method(Method* const 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   // Narrow Oop encoding mode:
   258   // 0 - Use 32-bits oops without encoding when
   259   //     NarrowOopHeapBaseMin + heap_size < 4Gb
   260   // 1 - Use zero based compressed oops with encoding when
   261   //     NarrowOopHeapBaseMin + heap_size < 32Gb
   262   // 2 - Use compressed oops with heap base + encoding.
   263   enum NARROW_OOP_MODE {
   264     UnscaledNarrowOop  = 0,
   265     ZeroBasedNarrowOop = 1,
   266     HeapBasedNarrowOop = 2
   267   };
   268   static char*    preferred_heap_base(size_t heap_size, NARROW_OOP_MODE mode);
   269   static char*    preferred_metaspace_base(size_t heap_size, NARROW_OOP_MODE mode);
   270   static void     set_narrow_oop_base(address base) {
   271     assert(UseCompressedOops, "no compressed oops?");
   272     _narrow_oop._base    = base;
   273   }
   274   static void     set_narrow_klass_base(address base) {
   275     assert(UseCompressedKlassPointers, "no compressed klass ptrs?");
   276     _narrow_klass._base   = base;
   277   }
   278   static void     set_narrow_oop_use_implicit_null_checks(bool use) {
   279     assert(UseCompressedOops, "no compressed ptrs?");
   280     _narrow_oop._use_implicit_null_checks   = use;
   281   }
   282   static bool     reserve_metaspace_helper(bool with_base = false);
   283   static ReservedHeapSpace reserve_heap_metaspace(size_t heap_size, size_t alignment, bool& contiguous);
   285   static size_t  class_metaspace_size() {
   286     return _class_metaspace_size;
   287   }
   288   static void    set_class_metaspace_size(size_t metaspace_size) {
   289     _class_metaspace_size = metaspace_size;
   290   }
   292   // Debugging
   293   static int _verify_count;                           // number of verifies done
   294   // True during call to verify().  Should only be set/cleared in verify().
   295   static bool _verify_in_progress;
   297   static void compute_verify_oop_data();
   299  public:
   300   // Known classes in the VM
   301   static Klass* boolArrayKlassObj()                 { return _boolArrayKlassObj;   }
   302   static Klass* byteArrayKlassObj()                 { return _byteArrayKlassObj;   }
   303   static Klass* charArrayKlassObj()                 { return _charArrayKlassObj;   }
   304   static Klass* intArrayKlassObj()                  { return _intArrayKlassObj;    }
   305   static Klass* shortArrayKlassObj()                { return _shortArrayKlassObj;  }
   306   static Klass* longArrayKlassObj()                 { return _longArrayKlassObj;   }
   307   static Klass* singleArrayKlassObj()               { return _singleArrayKlassObj; }
   308   static Klass* doubleArrayKlassObj()               { return _doubleArrayKlassObj; }
   310   static Klass* objectArrayKlassObj() {
   311     return _objectArrayKlassObj;
   312   }
   314   static Klass* typeArrayKlassObj(BasicType t) {
   315     assert((uint)t < T_VOID+1, err_msg("range check for type: %s", type2name(t)));
   316     assert(_typeArrayKlassObjs[t] != NULL, "domain check");
   317     return _typeArrayKlassObjs[t];
   318   }
   320   // Known objects in the VM
   321   static oop int_mirror()                   { return check_mirror(_int_mirror); }
   322   static oop float_mirror()                 { return check_mirror(_float_mirror); }
   323   static oop double_mirror()                { return check_mirror(_double_mirror); }
   324   static oop byte_mirror()                  { return check_mirror(_byte_mirror); }
   325   static oop bool_mirror()                  { return check_mirror(_bool_mirror); }
   326   static oop char_mirror()                  { return check_mirror(_char_mirror); }
   327   static oop long_mirror()                  { return check_mirror(_long_mirror); }
   328   static oop short_mirror()                 { return check_mirror(_short_mirror); }
   329   static oop void_mirror()                  { return check_mirror(_void_mirror); }
   331   // table of same
   332   static oop _mirrors[T_VOID+1];
   334   static oop java_mirror(BasicType t) {
   335     assert((uint)t < T_VOID+1, "range check");
   336     return check_mirror(_mirrors[t]);
   337   }
   338   static oop      main_thread_group()                 { return _main_thread_group; }
   339   static void set_main_thread_group(oop group)        { _main_thread_group = group;}
   341   static oop      system_thread_group()               { return _system_thread_group; }
   342   static void set_system_thread_group(oop group)      { _system_thread_group = group;}
   344   static objArrayOop  the_empty_class_klass_array ()  { return _the_empty_class_klass_array;   }
   345   static Array<Klass*>* the_array_interfaces_array() { return _the_array_interfaces_array;   }
   346   static oop          the_null_string()               { return _the_null_string;               }
   347   static oop          the_min_jint_string()          { return _the_min_jint_string;          }
   348   static Method*      finalizer_register_method()     { return _finalizer_register_cache->get_Method(); }
   349   static Method*      loader_addClass_method()        { return _loader_addClass_cache->get_Method(); }
   351   static Method*      protection_domain_implies_method() { return _pd_implies_cache->get_Method(); }
   352   static ActiveMethodOopsCache* reflect_invoke_cache() { return _reflect_invoke_cache; }
   354   static oop          null_ptr_exception_instance()   { return _null_ptr_exception_instance;   }
   355   static oop          arithmetic_exception_instance() { return _arithmetic_exception_instance; }
   356   static oop          virtual_machine_error_instance() { return _virtual_machine_error_instance; }
   357   static oop          vm_exception()                  { return _vm_exception; }
   359   static Array<int>*       the_empty_int_array()    { return _the_empty_int_array; }
   360   static Array<u2>*        the_empty_short_array()  { return _the_empty_short_array; }
   361   static Array<Method*>* the_empty_method_array() { return _the_empty_method_array; }
   362   static Array<Klass*>*  the_empty_klass_array()  { return _the_empty_klass_array; }
   364   // OutOfMemoryError support. Returns an error with the required message. The returned error
   365   // may or may not have a backtrace. If error has a backtrace then the stack trace is already
   366   // filled in.
   367   static oop out_of_memory_error_java_heap()          { return gen_out_of_memory_error(_out_of_memory_error_java_heap);  }
   368   static oop out_of_memory_error_perm_gen()           { return gen_out_of_memory_error(_out_of_memory_error_perm_gen);   }
   369   static oop out_of_memory_error_array_size()         { return gen_out_of_memory_error(_out_of_memory_error_array_size); }
   370   static oop out_of_memory_error_gc_overhead_limit()  { return gen_out_of_memory_error(_out_of_memory_error_gc_overhead_limit);  }
   372   // Accessors needed for fast allocation
   373   static Klass** boolArrayKlassObj_addr()           { return &_boolArrayKlassObj;   }
   374   static Klass** byteArrayKlassObj_addr()           { return &_byteArrayKlassObj;   }
   375   static Klass** charArrayKlassObj_addr()           { return &_charArrayKlassObj;   }
   376   static Klass** intArrayKlassObj_addr()            { return &_intArrayKlassObj;    }
   377   static Klass** shortArrayKlassObj_addr()          { return &_shortArrayKlassObj;  }
   378   static Klass** longArrayKlassObj_addr()           { return &_longArrayKlassObj;   }
   379   static Klass** singleArrayKlassObj_addr()         { return &_singleArrayKlassObj; }
   380   static Klass** doubleArrayKlassObj_addr()         { return &_doubleArrayKlassObj; }
   381   static Klass** objectArrayKlassObj_addr()         { return &_objectArrayKlassObj; }
   383   // The particular choice of collected heap.
   384   static CollectedHeap* heap() { return _collectedHeap; }
   386   // For UseCompressedOops
   387   static address  narrow_oop_base()                       { return  _narrow_oop._base; }
   388   static bool  is_narrow_oop_base(void* addr)             { return (narrow_oop_base() == (address)addr); }
   389   static int      narrow_oop_shift()                      { return  _narrow_oop._shift; }
   390   static bool     narrow_oop_use_implicit_null_checks()   { return  _narrow_oop._use_implicit_null_checks; }
   392   // For UseCompressedKlassPointers
   393   static address  narrow_klass_base()                     { return  _narrow_klass._base; }
   394   static bool  is_narrow_klass_base(void* addr)           { return (narrow_klass_base() == (address)addr); }
   395   static int      narrow_klass_shift()                    { return  _narrow_klass._shift; }
   396   static bool     narrow_klass_use_implicit_null_checks() { return  _narrow_klass._use_implicit_null_checks; }
   398   static address* narrow_ptrs_base_addr()                 { return &_narrow_ptrs_base; }
   399   static void     set_narrow_ptrs_base(address a)         { _narrow_ptrs_base = a; }
   400   static address  narrow_ptrs_base()                      { return _narrow_ptrs_base; }
   402   // this is set in vm_version on sparc (and then reset in universe afaict)
   403   static void     set_narrow_oop_shift(int shift)         {
   404     _narrow_oop._shift   = shift;
   405   }
   407   static void     set_narrow_klass_shift(int shift)       {
   408     assert(shift == 0 || shift == LogKlassAlignmentInBytes, "invalid shift for klass ptrs");
   409     _narrow_klass._shift   = shift;
   410   }
   412   // Reserve Java heap and determine CompressedOops mode
   413   static ReservedSpace reserve_heap(size_t heap_size, size_t alignment);
   415   // Historic gc information
   416   static size_t get_heap_capacity_at_last_gc()         { return _heap_capacity_at_last_gc; }
   417   static size_t get_heap_free_at_last_gc()             { return _heap_capacity_at_last_gc - _heap_used_at_last_gc; }
   418   static size_t get_heap_used_at_last_gc()             { return _heap_used_at_last_gc; }
   419   static void update_heap_info_at_gc();
   421   // Testers
   422   static bool is_bootstrapping()                      { return _bootstrapping; }
   423   static bool is_fully_initialized()                  { return _fully_initialized; }
   425   static inline bool element_type_should_be_aligned(BasicType type);
   426   static inline bool field_type_should_be_aligned(BasicType type);
   427   static bool        on_page_boundary(void* addr);
   428   static bool        should_fill_in_stack_trace(Handle throwable);
   429   static void check_alignment(uintx size, uintx alignment, const char* name);
   431   // Finalizer support.
   432   static void run_finalizers_on_exit();
   434   // Iteration
   436   // Apply "f" to the addresses of all the direct heap pointers maintained
   437   // as static fields of "Universe".
   438   static void oops_do(OopClosure* f, bool do_all = false);
   440   // CDS support
   441   static void serialize(SerializeClosure* f, bool do_all = false);
   443   // Apply "f" to all klasses for basic types (classes not present in
   444   // SystemDictionary).
   445   static void basic_type_classes_do(void f(Klass*));
   447   // For sharing -- fill in a list of known vtable pointers.
   448   static void init_self_patching_vtbl_list(void** list, int count);
   450   // Debugging
   451   static bool verify_in_progress() { return _verify_in_progress; }
   452   static void verify(bool silent, VerifyOption option);
   453   static void verify(bool silent) {
   454     verify(silent, VerifyOption_Default /* option */);
   455   }
   456   static void verify() {
   457     verify(false /* silent */);
   458   }
   460   static int  verify_count()       { return _verify_count; }
   461   // The default behavior is to call print_on() on gclog_or_tty.
   462   static void print();
   463   // The extended parameter determines which method on the heap will
   464   // be called: print_on() (extended == false) or print_extended_on()
   465   // (extended == true).
   466   static void print_on(outputStream* st, bool extended = false);
   467   static void print_heap_at_SIGBREAK();
   468   static void print_heap_before_gc() { print_heap_before_gc(gclog_or_tty); }
   469   static void print_heap_after_gc()  { print_heap_after_gc(gclog_or_tty); }
   470   static void print_heap_before_gc(outputStream* st, bool ignore_extended = false);
   471   static void print_heap_after_gc(outputStream* st, bool ignore_extended = false);
   473   // Change the number of dummy objects kept reachable by the full gc dummy
   474   // array; this should trigger relocation in a sliding compaction collector.
   475   debug_only(static bool release_fullgc_alot_dummy();)
   476   // The non-oop pattern (see compiledIC.hpp, etc)
   477   static void*   non_oop_word();
   479   // Oop verification (see MacroAssembler::verify_oop)
   480   static uintptr_t verify_oop_mask()          PRODUCT_RETURN0;
   481   static uintptr_t verify_oop_bits()          PRODUCT_RETURN0;
   482   static uintptr_t verify_mark_bits()         PRODUCT_RETURN0;
   483   static uintptr_t verify_mark_mask()         PRODUCT_RETURN0;
   485   // Flushing and deoptimization
   486   static void flush_dependents_on(instanceKlassHandle dependee);
   487   static void flush_dependents_on(Handle call_site, Handle method_handle);
   488 #ifdef HOTSWAP
   489   // Flushing and deoptimization in case of evolution
   490   static void flush_evol_dependents_on(instanceKlassHandle dependee);
   491 #endif // HOTSWAP
   492   // Support for fullspeed debugging
   493   static void flush_dependents_on_method(methodHandle dependee);
   495   // Compiler support
   496   static int base_vtable_size()               { return _base_vtable_size; }
   497 };
   499 class DeferredObjAllocEvent : public CHeapObj<mtInternal> {
   500   private:
   501     oop    _oop;
   502     size_t _bytesize;
   503     jint   _arena_id;
   505   public:
   506     DeferredObjAllocEvent(const oop o, const size_t s, const jint id) {
   507       _oop      = o;
   508       _bytesize = s;
   509       _arena_id = id;
   510     }
   512     ~DeferredObjAllocEvent() {
   513     }
   515     jint   arena_id() { return _arena_id; }
   516     size_t bytesize() { return _bytesize; }
   517     oop    get_oop()  { return _oop; }
   518 };
   520 #endif // SHARE_VM_MEMORY_UNIVERSE_HPP

mercurial