hotspot/src/share/vm/prims/jvmtiClassFileReconstituter.hpp
author ysr
Thu, 03 Dec 2009 15:01:57 -0800
changeset 4461 c17c526d36ef
parent 1 489c9b5090e2
child 5547 f4b087cbb361
permissions -rw-r--r--
6906727: UseCompressedOops: some card-marking fixes related to object arrays Summary: Introduced a new write_ref_array(HeapWords* start, size_t count) method that does the requisite MemRegion range calculation so (some of the) clients of the erstwhile write_ref_array(MemRegion mr) do not need to worry. This removed all external uses of array_size(), which was also simplified and made private. Asserts were added to catch other possible issues. Further, less essential, fixes stemming from this investigation are deferred to CR 6904516 (to follow shortly in hs17). Reviewed-by: kvn, coleenp, jmasa
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
     1
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
     2
 * Copyright 2005-2006 Sun Microsystems, Inc.  All Rights Reserved.
489c9b5090e2 Initial load
duke
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
489c9b5090e2 Initial load
duke
parents:
diff changeset
     4
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
489c9b5090e2 Initial load
duke
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
489c9b5090e2 Initial load
duke
parents:
diff changeset
     7
 * published by the Free Software Foundation.
489c9b5090e2 Initial load
duke
parents:
diff changeset
     8
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
     9
 * This code is distributed in the hope that it will be useful, but WITHOUT
489c9b5090e2 Initial load
duke
parents:
diff changeset
    10
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
489c9b5090e2 Initial load
duke
parents:
diff changeset
    11
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
489c9b5090e2 Initial load
duke
parents:
diff changeset
    12
 * version 2 for more details (a copy is included in the LICENSE file that
489c9b5090e2 Initial load
duke
parents:
diff changeset
    13
 * accompanied this code).
489c9b5090e2 Initial load
duke
parents:
diff changeset
    14
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
    15
 * You should have received a copy of the GNU General Public License version
489c9b5090e2 Initial load
duke
parents:
diff changeset
    16
 * 2 along with this work; if not, write to the Free Software Foundation,
489c9b5090e2 Initial load
duke
parents:
diff changeset
    17
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    18
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
    19
 * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
489c9b5090e2 Initial load
duke
parents:
diff changeset
    20
 * CA 95054 USA or visit www.sun.com if you need additional information or
489c9b5090e2 Initial load
duke
parents:
diff changeset
    21
 * have any questions.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    22
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
    23
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
    24
489c9b5090e2 Initial load
duke
parents:
diff changeset
    25
489c9b5090e2 Initial load
duke
parents:
diff changeset
    26
class JvmtiConstantPoolReconstituter : public StackObj {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    27
 private:
489c9b5090e2 Initial load
duke
parents:
diff changeset
    28
  int                  _cpool_size;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    29
  SymbolHashMap*       _symmap;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    30
  SymbolHashMap*       _classmap;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    31
  constantPoolHandle   _cpool;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    32
  instanceKlassHandle  _ikh;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    33
  jvmtiError           _err;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    34
489c9b5090e2 Initial load
duke
parents:
diff changeset
    35
 protected:
489c9b5090e2 Initial load
duke
parents:
diff changeset
    36
  instanceKlassHandle  ikh()     { return _ikh; };
489c9b5090e2 Initial load
duke
parents:
diff changeset
    37
  constantPoolHandle   cpool()   { return _cpool; };
489c9b5090e2 Initial load
duke
parents:
diff changeset
    38
489c9b5090e2 Initial load
duke
parents:
diff changeset
    39
  u2 symbol_to_cpool_index(symbolOop sym) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    40
    return _symmap->symbol_to_value(sym);
489c9b5090e2 Initial load
duke
parents:
diff changeset
    41
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
    42
489c9b5090e2 Initial load
duke
parents:
diff changeset
    43
  u2 class_symbol_to_cpool_index(symbolOop sym) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    44
    return _classmap->symbol_to_value(sym);
489c9b5090e2 Initial load
duke
parents:
diff changeset
    45
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
    46
489c9b5090e2 Initial load
duke
parents:
diff changeset
    47
 public:
489c9b5090e2 Initial load
duke
parents:
diff changeset
    48
  // Calls to this constructor must be proceeded by a ResourceMark
489c9b5090e2 Initial load
duke
parents:
diff changeset
    49
  // and a HandleMark
489c9b5090e2 Initial load
duke
parents:
diff changeset
    50
  JvmtiConstantPoolReconstituter(instanceKlassHandle ikh){
489c9b5090e2 Initial load
duke
parents:
diff changeset
    51
    set_error(JVMTI_ERROR_NONE);
489c9b5090e2 Initial load
duke
parents:
diff changeset
    52
    _ikh = ikh;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    53
    _cpool = constantPoolHandle(Thread::current(), ikh->constants());
489c9b5090e2 Initial load
duke
parents:
diff changeset
    54
    _symmap = new SymbolHashMap();
489c9b5090e2 Initial load
duke
parents:
diff changeset
    55
    _classmap = new SymbolHashMap();
489c9b5090e2 Initial load
duke
parents:
diff changeset
    56
    _cpool_size = _cpool->hash_entries_to(_symmap, _classmap);
489c9b5090e2 Initial load
duke
parents:
diff changeset
    57
    if (_cpool_size == 0) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    58
      set_error(JVMTI_ERROR_OUT_OF_MEMORY);
489c9b5090e2 Initial load
duke
parents:
diff changeset
    59
    } else if (_cpool_size < 0) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    60
      set_error(JVMTI_ERROR_INTERNAL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
    61
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
    62
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
    63
489c9b5090e2 Initial load
duke
parents:
diff changeset
    64
  ~JvmtiConstantPoolReconstituter() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    65
    if (_symmap != NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    66
      os::free(_symmap);
489c9b5090e2 Initial load
duke
parents:
diff changeset
    67
      _symmap = NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    68
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
    69
    if (_classmap != NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    70
      os::free(_classmap);
489c9b5090e2 Initial load
duke
parents:
diff changeset
    71
      _classmap = NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    72
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
    73
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
    74
489c9b5090e2 Initial load
duke
parents:
diff changeset
    75
489c9b5090e2 Initial load
duke
parents:
diff changeset
    76
  void       set_error(jvmtiError err)    { _err = err; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
    77
  jvmtiError get_error()                  { return _err; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
    78
489c9b5090e2 Initial load
duke
parents:
diff changeset
    79
  int cpool_size()                        { return _cpool_size; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
    80
489c9b5090e2 Initial load
duke
parents:
diff changeset
    81
  void copy_cpool_bytes(unsigned char *cpool_bytes) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    82
    if (cpool_bytes == NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    83
      assert(cpool_bytes != NULL, "cpool_bytes pointer must not be NULL");
489c9b5090e2 Initial load
duke
parents:
diff changeset
    84
      return;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    85
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
    86
    cpool()->copy_cpool_bytes(cpool_size(), _symmap, cpool_bytes);
489c9b5090e2 Initial load
duke
parents:
diff changeset
    87
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
    88
};
489c9b5090e2 Initial load
duke
parents:
diff changeset
    89
489c9b5090e2 Initial load
duke
parents:
diff changeset
    90
489c9b5090e2 Initial load
duke
parents:
diff changeset
    91
class JvmtiClassFileReconstituter : public JvmtiConstantPoolReconstituter {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    92
 private:
489c9b5090e2 Initial load
duke
parents:
diff changeset
    93
  size_t               _buffer_size;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    94
  u1*                  _buffer;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    95
  u1*                  _buffer_ptr;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    96
  Thread*              _thread;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    97
489c9b5090e2 Initial load
duke
parents:
diff changeset
    98
  enum {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    99
    // initial size should be power of two
489c9b5090e2 Initial load
duke
parents:
diff changeset
   100
    initial_buffer_size = 1024
489c9b5090e2 Initial load
duke
parents:
diff changeset
   101
  };
489c9b5090e2 Initial load
duke
parents:
diff changeset
   102
489c9b5090e2 Initial load
duke
parents:
diff changeset
   103
  inline Thread* thread() { return _thread; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   104
489c9b5090e2 Initial load
duke
parents:
diff changeset
   105
  void write_class_file_format();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   106
  void write_field_infos();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   107
  void write_method_infos();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   108
  void write_method_info(methodHandle method);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   109
  void write_code_attribute(methodHandle method);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   110
  void write_exceptions_attribute(constMethodHandle const_method);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   111
  void write_synthetic_attribute();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   112
  void write_class_attributes();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   113
  void write_source_file_attribute();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   114
  void write_source_debug_extension_attribute();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   115
  u2 line_number_table_entries(methodHandle method);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   116
  void write_line_number_table_attribute(methodHandle method, u2 num_entries);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   117
  void write_stackmap_table_attribute(methodHandle method, int stackmap_table_len);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   118
  u2 inner_classes_attribute_length();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   119
  void write_inner_classes_attribute(int length);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   120
  void write_signature_attribute(u2 generic_signaure_index);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   121
  void write_attribute_name_index(const char* name);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   122
  void write_annotations_attribute(const char* attr_name, typeArrayHandle annos);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   123
489c9b5090e2 Initial load
duke
parents:
diff changeset
   124
  address writeable_address(size_t size);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   125
  void write_u1(u1 x);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   126
  void write_u2(u2 x);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   127
  void write_u4(u4 x);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   128
  void write_u8(u8 x);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   129
489c9b5090e2 Initial load
duke
parents:
diff changeset
   130
 public:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   131
  // Calls to this constructor must be proceeded by a ResourceMark
489c9b5090e2 Initial load
duke
parents:
diff changeset
   132
  // and a HandleMark
489c9b5090e2 Initial load
duke
parents:
diff changeset
   133
  JvmtiClassFileReconstituter(instanceKlassHandle ikh) :
489c9b5090e2 Initial load
duke
parents:
diff changeset
   134
                                      JvmtiConstantPoolReconstituter(ikh) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   135
    _buffer_size = initial_buffer_size;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   136
    _buffer = _buffer_ptr = NEW_RESOURCE_ARRAY(u1, _buffer_size);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   137
    _thread = Thread::current();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   138
    write_class_file_format();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   139
  };
489c9b5090e2 Initial load
duke
parents:
diff changeset
   140
489c9b5090e2 Initial load
duke
parents:
diff changeset
   141
  size_t class_file_size()    { return _buffer_ptr - _buffer; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   142
489c9b5090e2 Initial load
duke
parents:
diff changeset
   143
  u1* class_file_bytes()      { return _buffer; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   144
489c9b5090e2 Initial load
duke
parents:
diff changeset
   145
  static void copy_bytecodes(methodHandle method, unsigned char* bytecodes);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   146
};