< prev index next >

src/hotspot/share/ci/ciArrayKlass.cpp

Print this page
@@ -1,7 +1,7 @@
  /*
-  * Copyright (c) 1999, 2023, Oracle and/or its affiliates. All rights reserved.
+  * Copyright (c) 1999, 2025, 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
   * under the terms of the GNU General Public License version 2 only, as
   * published by the Free Software Foundation.

@@ -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,47 @@
  
  // ------------------------------------------------------------------
  // 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();
+   assert(!null_free || !klass->is_loaded() || klass->is_inlinetype() || klass->is_abstract() ||
+          klass->is_java_lang_Object(), "only value classes are null free");
+   if (null_free && klass->is_loaded() && klass->is_inlinetype()) {
+     GUARDED_VM_ENTRY(
+       EXCEPTION_CONTEXT;
+       Klass* ak = nullptr;
+       InlineKlass* vk = InlineKlass::cast(klass->get_Klass());
+       if (vk->flat_array()) {
+         // Current limitation: returns only non-atomic flat arrays, atomic layout not supported here
+         ak = vk->flat_array_klass(LayoutKind::NON_ATOMIC_FLAT, THREAD);
+       } else {
+         ak = vk->null_free_reference_array(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 >