src/share/vm/oops/arrayKlassKlass.cpp

Mon, 25 Jun 2012 21:33:35 -0400

author
coleenp
date
Mon, 25 Jun 2012 21:33:35 -0400
changeset 3875
246d977b51f2
parent 2658
c7f3d0b4570f
permissions
-rw-r--r--

7178670: runtime/7158800/BadUtf8.java fails in SymbolTable::rehash_table
Summary: Cannot delete _buckets and HashtableEntries in shared space (CDS)
Reviewed-by: acorn, kvn, dlong, dcubed, kamg

     1 /*
     2  * Copyright (c) 1997, 2011, 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 #include "precompiled.hpp"
    26 #include "classfile/javaClasses.hpp"
    27 #include "gc_implementation/shared/markSweep.inline.hpp"
    28 #include "oops/arrayKlassKlass.hpp"
    29 #include "oops/oop.inline.hpp"
    30 #include "runtime/handles.inline.hpp"
    31 #ifndef SERIALGC
    32 #include "gc_implementation/parNew/parOopClosures.inline.hpp"
    33 #include "gc_implementation/parallelScavenge/psPromotionManager.inline.hpp"
    34 #include "gc_implementation/parallelScavenge/psScavenge.inline.hpp"
    35 #include "memory/cardTableRS.hpp"
    36 #include "oops/oop.pcgc.inline.hpp"
    37 #endif
    40 klassOop arrayKlassKlass::create_klass(TRAPS) {
    41   arrayKlassKlass o;
    42   KlassHandle h_this_klass(THREAD, Universe::klassKlassObj());
    43   KlassHandle k = base_create_klass(h_this_klass, header_size(), o.vtbl_value(), CHECK_NULL);
    44   // Make sure size calculation is right
    45   assert(k()->size() == align_object_size(header_size()), "wrong size for object");
    46   java_lang_Class::create_mirror(k, CHECK_NULL); // Allocate mirror, make links
    47   return k();
    48 }
    50 bool arrayKlassKlass::oop_is_parsable(oop obj) const {
    51   assert(obj->is_klass(), "must be klass");
    52   arrayKlass* ak = arrayKlass::cast(klassOop(obj));
    53   return (!ak->null_vtbl()) && ak->object_is_parsable();
    54 }
    56 void arrayKlassKlass::oop_follow_contents(oop obj) {
    57   assert(obj->is_klass(), "must be klass");
    58   arrayKlass* ak = arrayKlass::cast(klassOop(obj));
    59   MarkSweep::mark_and_push(ak->adr_component_mirror());
    60   MarkSweep::mark_and_push(ak->adr_lower_dimension());
    61   MarkSweep::mark_and_push(ak->adr_higher_dimension());
    62   {
    63     HandleMark hm;
    64     ak->vtable()->oop_follow_contents();
    65   }
    66   klassKlass::oop_follow_contents(obj);
    67 }
    69 #ifndef SERIALGC
    70 void arrayKlassKlass::oop_follow_contents(ParCompactionManager* cm,
    71                                           oop obj) {
    72   assert(obj->is_klass(), "must be klass");
    73   arrayKlass* ak = arrayKlass::cast(klassOop(obj));
    74   PSParallelCompact::mark_and_push(cm, ak->adr_component_mirror());
    75   PSParallelCompact::mark_and_push(cm, ak->adr_lower_dimension());
    76   PSParallelCompact::mark_and_push(cm, ak->adr_higher_dimension());
    77   {
    78     HandleMark hm;
    79     ak->vtable()->oop_follow_contents(cm);
    80   }
    81   klassKlass::oop_follow_contents(cm, obj);
    82 }
    83 #endif // SERIALGC
    86 int arrayKlassKlass::oop_adjust_pointers(oop obj) {
    87   assert(obj->is_klass(), "must be klass");
    88   arrayKlass* ak = arrayKlass::cast(klassOop(obj));
    89   MarkSweep::adjust_pointer(ak->adr_component_mirror());
    90   MarkSweep::adjust_pointer(ak->adr_lower_dimension());
    91   MarkSweep::adjust_pointer(ak->adr_higher_dimension());
    92   {
    93     HandleMark hm;
    94     ak->vtable()->oop_adjust_pointers();
    95   }
    96   return klassKlass::oop_adjust_pointers(obj);
    97 }
   100 int arrayKlassKlass::oop_oop_iterate(oop obj, OopClosure* blk) {
   101   assert(obj->is_klass(), "must be klass");
   102   arrayKlass* ak = arrayKlass::cast(klassOop(obj));
   103   blk->do_oop(ak->adr_component_mirror());
   104   blk->do_oop(ak->adr_lower_dimension());
   105   blk->do_oop(ak->adr_higher_dimension());
   106   ak->vtable()->oop_oop_iterate(blk);
   107   return klassKlass::oop_oop_iterate(obj, blk);
   108 }
   111 int arrayKlassKlass::oop_oop_iterate_m(oop obj, OopClosure* blk, MemRegion mr) {
   112   assert(obj->is_klass(), "must be klass");
   113   arrayKlass* ak = arrayKlass::cast(klassOop(obj));
   114   oop* addr = ak->adr_component_mirror();
   115   if (mr.contains(addr)) blk->do_oop(addr);
   116   addr = ak->adr_lower_dimension();
   117   if (mr.contains(addr)) blk->do_oop(addr);
   118   addr = ak->adr_higher_dimension();
   119   if (mr.contains(addr)) blk->do_oop(addr);
   120   ak->vtable()->oop_oop_iterate_m(blk, mr);
   121   return klassKlass::oop_oop_iterate_m(obj, blk, mr);
   122 }
   124 #ifndef SERIALGC
   125 void arrayKlassKlass::oop_push_contents(PSPromotionManager* pm, oop obj) {
   126   assert(obj->blueprint()->oop_is_arrayKlass(),"must be an array klass");
   127   arrayKlass* ak = arrayKlass::cast(klassOop(obj));
   128   oop* p = ak->adr_component_mirror();
   129   if (PSScavenge::should_scavenge(p)) {
   130     pm->claim_or_forward_depth(p);
   131   }
   132   klassKlass::oop_push_contents(pm, obj);
   133 }
   135 int arrayKlassKlass::oop_update_pointers(ParCompactionManager* cm, oop obj) {
   136   assert(obj->is_klass(), "must be klass");
   137   arrayKlass* ak = arrayKlass::cast(klassOop(obj));
   138   PSParallelCompact::adjust_pointer(ak->adr_component_mirror());
   139   PSParallelCompact::adjust_pointer(ak->adr_lower_dimension());
   140   PSParallelCompact::adjust_pointer(ak->adr_higher_dimension());
   141   {
   142     HandleMark hm;
   143     ak->vtable()->oop_update_pointers(cm);
   144   }
   145   return klassKlass::oop_update_pointers(cm, obj);
   146 }
   147 #endif // SERIALGC
   149 // Printing
   151 void arrayKlassKlass::oop_print_on(oop obj, outputStream* st) {
   152   assert(obj->is_klass(), "must be klass");
   153   klassKlass::oop_print_on(obj, st);
   154 }
   156 void arrayKlassKlass::oop_print_value_on(oop obj, outputStream* st) {
   157   assert(obj->is_klass(), "must be klass");
   158   arrayKlass* ak = arrayKlass::cast(klassOop(obj));
   159   for(int index = 0; index < ak->dimension(); index++) {
   160     st->print("[]");
   161   }
   162 }
   165 const char* arrayKlassKlass::internal_name() const {
   166   return "{array class}";
   167 }
   169 void arrayKlassKlass::oop_verify_on(oop obj, outputStream* st) {
   170   klassKlass::oop_verify_on(obj, st);
   172   arrayKlass* ak = arrayKlass::cast(klassOop(obj));
   173   if (!obj->partially_loaded()) {
   174     if (ak->component_mirror() != NULL)
   175       guarantee(ak->component_mirror()->klass(), "should have a class");
   176     if (ak->lower_dimension() != NULL)
   177       guarantee(ak->lower_dimension()->klass(), "should have a class");
   178     if (ak->higher_dimension() != NULL)
   179       guarantee(ak->higher_dimension()->klass(), "should have a class");
   180   }
   181 }

mercurial