< prev index next >

src/hotspot/share/prims/jvmtiClassFileReconstituter.cpp

Print this page
@@ -1,7 +1,7 @@
  /*
-  * Copyright (c) 2005, 2023, Oracle and/or its affiliates. All rights reserved.
+  * Copyright (c) 2005, 2024, 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,10 +22,11 @@
   *
   */
  
  #include "precompiled.hpp"
  #include "classfile/symbolTable.hpp"
+ #include "classfile/vmClasses.hpp"
  #include "interpreter/bytecodeStream.hpp"
  #include "memory/universe.hpp"
  #include "oops/constantPool.inline.hpp"
  #include "oops/fieldStreams.inline.hpp"
  #include "oops/instanceKlass.inline.hpp"

@@ -83,11 +84,11 @@
      // JVMSpec|         u2 descriptor_index;
      // JVMSpec|         u2 attributes_count;
      // JVMSpec|         attribute_info attributes[attributes_count];
      // JVMSpec|   }
  
-     write_u2(access_flags.get_flags() & JVM_RECOGNIZED_FIELD_MODIFIERS);
+     write_u2(access_flags.get_flags());
      write_u2(name_index);
      write_u2(signature_index);
      u2 attr_count = 0;
      if (initial_value_index != 0) {
        ++attr_count;

@@ -484,10 +485,30 @@
      u2 class_cp_index = permitted_subclasses->at(i);
      write_u2(class_cp_index);
    }
  }
  
+ // LoadableDescriptors {
+ //   u2 attribute_name_index;
+ //   u4 attribute_length;
+ //   u2 number_of_descriptors;
+ //   u2 descriptors[number_of_descriptors];
+ // }
+ void JvmtiClassFileReconstituter::write_loadable_descriptors_attribute() {
+   Array<u2>* loadable_descriptors = ik()->loadable_descriptors();
+   int number_of_descriptors = loadable_descriptors->length();
+   int length = sizeof(u2) * (1 + number_of_descriptors); // '1 +' is for number_of_descriptors field
+ 
+   write_attribute_name_index("LoadableDescriptors");
+   write_u4(length);
+   write_u2(checked_cast<u2>(number_of_descriptors));
+   for (int i = 0; i < number_of_descriptors; i++) {
+     u2 utf8_index = loadable_descriptors->at(i);
+     write_u2(utf8_index);
+   }
+ }
+ 
  //  Record {
  //    u2 attribute_name_index;
  //    u4 attribute_length;
  //    u2 components_count;
  //    component_info components[components_count];

@@ -823,10 +844,13 @@
      ++attr_count;
    }
    if (ik()->permitted_subclasses() != Universe::the_empty_short_array()) {
      ++attr_count;
    }
+   if (ik()->loadable_descriptors() != Universe::the_empty_short_array()) {
+     ++attr_count;
+   }
    if (ik()->record_components() != nullptr) {
      ++attr_count;
    }
  
    write_u2(attr_count);

@@ -853,10 +877,13 @@
      write_nest_members_attribute();
    }
    if (ik()->permitted_subclasses() != Universe::the_empty_short_array()) {
      write_permitted_subclasses_attribute();
    }
+   if (ik()->loadable_descriptors() != Universe::the_empty_short_array()) {
+     write_loadable_descriptors_attribute();
+   }
    if (ik()->record_components() != nullptr) {
      write_record_attribute();
    }
    if (cpool()->operands() != nullptr) {
      write_bootstrapmethod_attribute();

@@ -931,12 +958,11 @@
    // JVMSpec|           cp_info constant_pool[constant_pool_count-1];
    write_u2(checked_cast<u2>(cpool()->length()));
    copy_cpool_bytes(writeable_address(cpool_size()));
  
    // JVMSpec|           u2 access_flags;
-   write_u2(ik()->access_flags().get_flags() & JVM_RECOGNIZED_CLASS_MODIFIERS);
- 
+   write_u2(ik()->access_flags().get_flags() & (JVM_RECOGNIZED_CLASS_MODIFIERS));
    // JVMSpec|           u2 this_class;
    // JVMSpec|           u2 super_class;
    write_u2(class_symbol_to_cpool_index(ik()->name()));
    Klass* super_class = ik()->super();
    write_u2(super_class == nullptr? 0 :  // zero for java.lang.Object

@@ -1042,11 +1068,11 @@
        bool is_wide = false;
        switch (code) {
        case Bytecodes::_getstatic       :  // fall through
        case Bytecodes::_putstatic       :  // fall through
        case Bytecodes::_getfield        :  // fall through
-       case Bytecodes::_putfield        :  {
+       case Bytecodes::_putfield        : {
          int field_index = Bytes::get_native_u2(bcp+1);
          u2 pool_index = mh->constants()->resolved_field_entry_at(field_index)->constant_pool_index();
          assert(pool_index < mh->constants()->length(), "sanity check");
          Bytes::put_Java_u2((address)(p+1), pool_index);     // java byte ordering
          break;
< prev index next >