diff src/share/vm/ci/ciObjArrayKlass.cpp @ 6725:da91efe96a93

6964458: Reimplement class meta-data storage to use native memory Summary: Remove PermGen, allocate meta-data in metaspace linked to class loaders, rewrite GC walking, rewrite and rename metadata to be C++ classes Reviewed-by: jmasa, stefank, never, coleenp, kvn, brutisso, mgerdin, dholmes, jrose, twisti, roland Contributed-by: jmasa <jon.masamitsu@oracle.com>, stefank <stefan.karlsson@oracle.com>, mgerdin <mikael.gerdin@oracle.com>, never <tom.rodriguez@oracle.com>
author coleenp
date Sat, 01 Sep 2012 13:25:18 -0400
parents ddd894528dbc
children d8ce2825b193
line wrap: on
line diff
--- a/src/share/vm/ci/ciObjArrayKlass.cpp	Fri Aug 31 16:39:35 2012 -0700
+++ b/src/share/vm/ci/ciObjArrayKlass.cpp	Sat Sep 01 13:25:18 2012 -0400
@@ -1,5 +1,5 @@
 /*
- * Copyright (c) 1999, 2011, Oracle and/or its affiliates. All rights reserved.
+ * Copyright (c) 1999, 2012, Oracle and/or its affiliates. All rights reserved.
  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
  *
  * This code is free software; you can redistribute it and/or modify it
@@ -25,14 +25,13 @@
 #include "precompiled.hpp"
 #include "ci/ciInstanceKlass.hpp"
 #include "ci/ciObjArrayKlass.hpp"
-#include "ci/ciObjArrayKlassKlass.hpp"
 #include "ci/ciSymbol.hpp"
 #include "ci/ciUtilities.hpp"
 #include "oops/objArrayKlass.hpp"
 
 // ciObjArrayKlass
 //
-// This class represents a klassOop in the HotSpot virtual machine
+// This class represents a Klass* in the HotSpot virtual machine
 // whose Klass part is an objArrayKlass.
 
 // ------------------------------------------------------------------
@@ -41,8 +40,8 @@
 // Constructor for loaded object array klasses.
 ciObjArrayKlass::ciObjArrayKlass(KlassHandle h_k) : ciArrayKlass(h_k) {
   assert(get_Klass()->oop_is_objArray(), "wrong type");
-  klassOop element_klassOop = get_objArrayKlass()->bottom_klass();
-  _base_element_klass = CURRENT_ENV->get_object(element_klassOop)->as_klass();
+  Klass* element_Klass = get_objArrayKlass()->bottom_klass();
+  _base_element_klass = CURRENT_ENV->get_klass(element_Klass);
   assert(_base_element_klass->is_instance_klass() ||
          _base_element_klass->is_type_array_klass(), "bad base klass");
   if (dimension() == 1) {
@@ -63,8 +62,7 @@
                                  ciKlass* base_element_klass,
                                  int dimension)
   : ciArrayKlass(array_name,
-                 dimension,
-                 ciObjArrayKlassKlass::make()) {
+                 dimension, T_OBJECT) {
     _base_element_klass = base_element_klass;
     assert(_base_element_klass->is_instance_klass() ||
            _base_element_klass->is_type_array_klass(), "bad base klass");
@@ -85,8 +83,8 @@
     // Produce the element klass.
     if (is_loaded()) {
       VM_ENTRY_MARK;
-      klassOop element_klassOop = get_objArrayKlass()->element_klass();
-      _element_klass = CURRENT_THREAD_ENV->get_object(element_klassOop)->as_klass();
+      Klass* element_Klass = get_objArrayKlass()->element_klass();
+      _element_klass = CURRENT_THREAD_ENV->get_klass(element_Klass);
     } else {
       VM_ENTRY_MARK;
       // We are an unloaded array klass.  Attempt to fetch our
@@ -154,13 +152,13 @@
   if (element_klass->is_loaded()) {
     EXCEPTION_CONTEXT;
     // The element klass is loaded
-    klassOop array = element_klass->get_Klass()->array_klass(THREAD);
+    Klass* array = element_klass->get_Klass()->array_klass(THREAD);
     if (HAS_PENDING_EXCEPTION) {
       CLEAR_PENDING_EXCEPTION;
       CURRENT_THREAD_ENV->record_out_of_memory_failure();
       return ciEnv::unloaded_ciobjarrayklass();
     }
-    return CURRENT_THREAD_ENV->get_object(array)->as_obj_array_klass();
+    return CURRENT_THREAD_ENV->get_obj_array_klass(array);
   }
 
   // The array klass was unable to be made or the element klass was
@@ -179,6 +177,5 @@
 //
 // Make an array klass corresponding to the specified primitive type.
 ciObjArrayKlass* ciObjArrayKlass::make(ciKlass* element_klass) {
-  assert(element_klass->is_java_klass(), "wrong kind of klass");
   GUARDED_VM_ENTRY(return make_impl(element_klass);)
 }