src/share/vm/ci/ciObjectFactory.hpp

Tue, 18 Jun 2013 12:31:07 -0700

author
johnc
date
Tue, 18 Jun 2013 12:31:07 -0700
changeset 5277
01522ca68fc7
parent 4267
bd7a7ce2e264
child 5628
f98f5d48f511
permissions
-rw-r--r--

8015237: Parallelize string table scanning during strong root processing
Summary: Parallelize the scanning of the intern string table by having each GC worker claim a given number of buckets. Changes were also reviewed by Per Liden <per.liden@oracle.com>.
Reviewed-by: tschatzl, stefank, twisti

     1 /*
     2  * Copyright (c) 1999, 2012, 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_CI_CIOBJECTFACTORY_HPP
    26 #define SHARE_VM_CI_CIOBJECTFACTORY_HPP
    28 #include "ci/ciClassList.hpp"
    29 #include "ci/ciObject.hpp"
    30 #include "utilities/growableArray.hpp"
    32 // ciObjectFactory
    33 //
    34 // This class handles requests for the creation of new instances
    35 // of ciObject and its subclasses.  It contains a caching mechanism
    36 // which ensures that for each oop, at most one ciObject is created.
    37 // This invariant allows efficient implementation of ciObject.
    38 class ciObjectFactory : public ResourceObj {
    39   friend class VMStructs;
    40   friend class ciEnv;
    42 private:
    43   static volatile bool _initialized;
    44   static GrowableArray<ciMetadata*>* _shared_ci_metadata;
    45   static ciSymbol*                 _shared_ci_symbols[];
    46   static int                       _shared_ident_limit;
    48   Arena*                    _arena;
    49   GrowableArray<ciMetadata*>*        _ci_metadata;
    50   GrowableArray<ciMethod*>* _unloaded_methods;
    51   GrowableArray<ciKlass*>* _unloaded_klasses;
    52   GrowableArray<ciInstance*>* _unloaded_instances;
    53   GrowableArray<ciReturnAddress*>* _return_addresses;
    54   GrowableArray<ciSymbol*>* _symbols;  // keep list of symbols created
    55   int                       _next_ident;
    57 public:
    58   struct NonPermObject : public ResourceObj {
    59     ciObject*      _object;
    60     NonPermObject* _next;
    62     inline NonPermObject(NonPermObject* &bucket, oop key, ciObject* object);
    63     ciObject*     object()  { return _object; }
    64     NonPermObject* &next()  { return _next; }
    65   };
    66 private:
    67   enum { NON_PERM_BUCKETS = 61 };
    68   NonPermObject* _non_perm_bucket[NON_PERM_BUCKETS];
    69   int _non_perm_count;
    71   int find(Metadata* key, GrowableArray<ciMetadata*>* objects);
    72   bool is_found_at(int index, Metadata* key, GrowableArray<ciMetadata*>* objects);
    73   void insert(int index, ciMetadata* obj, GrowableArray<ciMetadata*>* objects);
    75   ciObject* create_new_object(oop o);
    76   ciMetadata* create_new_object(Metadata* o);
    78   static bool is_equal(NonPermObject* p, oop key) {
    79     return p->object()->get_oop() == key;
    80   }
    82   NonPermObject* &find_non_perm(oop key);
    83   void insert_non_perm(NonPermObject* &where, oop key, ciObject* obj);
    85   void init_ident_of(ciBaseObject* obj);
    87   Arena* arena() { return _arena; }
    89   void print_contents_impl();
    91   ciInstance* get_unloaded_instance(ciInstanceKlass* klass);
    93 public:
    94   static bool is_initialized() { return _initialized; }
    96   static void initialize();
    97   void init_shared_objects();
    98   void remove_symbols();
   100   ciObjectFactory(Arena* arena, int expected_size);
   102   // Get the ciObject corresponding to some oop.
   103   ciObject* get(oop key);
   104   ciMetadata* get_metadata(Metadata* key);
   105   ciSymbol* get_symbol(Symbol* key);
   107   // Get the ciSymbol corresponding to one of the vmSymbols.
   108   static ciSymbol* vm_symbol_at(int index);
   110   // Get the ciMethod representing an unloaded/unfound method.
   111   ciMethod* get_unloaded_method(ciInstanceKlass* holder,
   112                                 ciSymbol*        name,
   113                                 ciSymbol*        signature,
   114                                 ciInstanceKlass* accessor);
   116   // Get a ciKlass representing an unloaded klass.
   117   ciKlass* get_unloaded_klass(ciKlass* accessing_klass,
   118                               ciSymbol* name,
   119                               bool create_if_not_found);
   121   // Get a ciInstance representing an unresolved klass mirror.
   122   ciInstance* get_unloaded_klass_mirror(ciKlass* type);
   124   // Get a ciInstance representing an unresolved method handle constant.
   125   ciInstance* get_unloaded_method_handle_constant(ciKlass*  holder,
   126                                                   ciSymbol* name,
   127                                                   ciSymbol* signature,
   128                                                   int       ref_kind);
   130   // Get a ciInstance representing an unresolved method type constant.
   131   ciInstance* get_unloaded_method_type_constant(ciSymbol* signature);
   134   // Get the ciMethodData representing the methodData for a method
   135   // with none.
   136   ciMethodData* get_empty_methodData();
   138   ciReturnAddress* get_return_address(int bci);
   140   GrowableArray<ciMetadata*>* get_ci_metadata() const { return _ci_metadata; }
   141   // RedefineClasses support
   142   void metadata_do(void f(Metadata*));
   144   void print_contents();
   145   void print();
   146 };
   148 #endif // SHARE_VM_CI_CIOBJECTFACTORY_HPP

mercurial