< prev index next >

src/hotspot/share/ci/ciArrayKlass.cpp

Print this page
@@ -22,13 +22,16 @@
   *
   */
  
  #include "precompiled.hpp"
  #include "ci/ciArrayKlass.hpp"
+ #include "ci/ciFlatArrayKlass.hpp"
+ #include "ci/ciInlineKlass.hpp"
  #include "ci/ciObjArrayKlass.hpp"
  #include "ci/ciTypeArrayKlass.hpp"
  #include "ci/ciUtilities.inline.hpp"
+ #include "oops/inlineKlass.inline.hpp"
  #include "memory/universe.hpp"
  
  // ciArrayKlass
  //
  // This class represents a Klass* in the HotSpot virtual machine

@@ -58,11 +61,11 @@
  // What type is obtained when this array is indexed once?
  ciType* ciArrayKlass::element_type() {
    if (is_type_array_klass()) {
      return ciType::make(as_type_array_klass()->element_type());
    } else {
-     return as_obj_array_klass()->element_klass()->as_klass();
+     return element_klass()->as_klass();
    }
  }
  
  
  // ------------------------------------------------------------------

@@ -70,16 +73,18 @@
  //
  // What type is obtained when this array is indexed as many times as possible?
  ciType* ciArrayKlass::base_element_type() {
    if (is_type_array_klass()) {
      return ciType::make(as_type_array_klass()->element_type());
-   } else {
+   } else if (is_obj_array_klass()) {
      ciKlass* ek = as_obj_array_klass()->base_element_klass();
      if (ek->is_type_array_klass()) {
        return ciType::make(ek->as_type_array_klass()->element_type());
      }
      return ek;
+   } else {
+     return as_flat_array_klass()->base_element_klass();
    }
  }
  
  
  // ------------------------------------------------------------------

@@ -95,13 +100,38 @@
  
  // ------------------------------------------------------------------
  // ciArrayKlass::make
  //
  // Make an array klass of the specified element type.
- ciArrayKlass* ciArrayKlass::make(ciType* element_type) {
+ ciArrayKlass* ciArrayKlass::make(ciType* element_type, bool null_free) {
    if (element_type->is_primitive_type()) {
      return ciTypeArrayKlass::make(element_type->basic_type());
    } else {
-     return ciObjArrayKlass::make(element_type->as_klass());
+     ciKlass* klass = element_type->as_klass();
+     if (null_free && klass->is_loaded()) {
+       GUARDED_VM_ENTRY(
+         EXCEPTION_CONTEXT;
+         Klass* ak = InlineKlass::cast(klass->get_Klass())->value_array_klass(THREAD);
+         if (HAS_PENDING_EXCEPTION) {
+           CLEAR_PENDING_EXCEPTION;
+         } else if (ak->is_flatArray_klass()) {
+           return CURRENT_THREAD_ENV->get_flat_array_klass(ak);
+         } else if (ak->is_objArray_klass()) {
+           return CURRENT_THREAD_ENV->get_obj_array_klass(ak);
+         }
+       )
+     }
+     return ciObjArrayKlass::make(klass);
    }
  }
  
+ int ciArrayKlass::array_header_in_bytes() {
+   return get_ArrayKlass()->array_header_in_bytes();
+ }
+ 
+ ciInstance* ciArrayKlass::component_mirror_instance() const {
+   GUARDED_VM_ENTRY(
+     oop component_mirror = ArrayKlass::cast(get_Klass())->component_mirror();
+     return CURRENT_ENV->get_instance(component_mirror);
+   )
+ }
+ 
< prev index next >