hotspot/src/share/vm/code/debugInfoRec.hpp
author duke
Sat, 01 Dec 2007 00:00:00 +0000
changeset 1 489c9b5090e2
child 3600 27aa4477d039
permissions -rw-r--r--
Initial load
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 1998-2005 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
//** The DebugInformationRecorder collects debugging information
489c9b5090e2 Initial load
duke
parents:
diff changeset
    26
//   for a compiled method.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    27
//   Debugging information is used for:
489c9b5090e2 Initial load
duke
parents:
diff changeset
    28
//   - garbage collecting compiled frames
489c9b5090e2 Initial load
duke
parents:
diff changeset
    29
//   - stack tracing across compiled frames
489c9b5090e2 Initial load
duke
parents:
diff changeset
    30
//   - deoptimizating compiled frames
489c9b5090e2 Initial load
duke
parents:
diff changeset
    31
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
    32
//   The implementation requires the compiler to use the recorder
489c9b5090e2 Initial load
duke
parents:
diff changeset
    33
//   in the following order:
489c9b5090e2 Initial load
duke
parents:
diff changeset
    34
//   1) Describe debug information for safepoints at increasing addresses.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    35
//      a) Add safepoint entry (use add_safepoint or add_non_safepoint)
489c9b5090e2 Initial load
duke
parents:
diff changeset
    36
//      b) Describe scopes for that safepoint
489c9b5090e2 Initial load
duke
parents:
diff changeset
    37
//         - create locals if needed (use create_scope_values)
489c9b5090e2 Initial load
duke
parents:
diff changeset
    38
//         - create expressions if needed (use create_scope_values)
489c9b5090e2 Initial load
duke
parents:
diff changeset
    39
//         - create monitor stack if needed (use create_monitor_values)
489c9b5090e2 Initial load
duke
parents:
diff changeset
    40
//         - describe scope (use describe_scope)
489c9b5090e2 Initial load
duke
parents:
diff changeset
    41
//         "repeat last four steps for all scopes"
489c9b5090e2 Initial load
duke
parents:
diff changeset
    42
//         "outer most scope first and inner most scope last"
489c9b5090e2 Initial load
duke
parents:
diff changeset
    43
//         NB: nodes from create_scope_values and create_locations
489c9b5090e2 Initial load
duke
parents:
diff changeset
    44
//             can be reused for simple sharing.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    45
//         - mark the end of the scopes (end_safepoint or end_non_safepoint)
489c9b5090e2 Initial load
duke
parents:
diff changeset
    46
//   2) Use oop_size, data_size, pcs_size to create the nmethod and
489c9b5090e2 Initial load
duke
parents:
diff changeset
    47
//      finally migrate the debugging information into the nmethod
489c9b5090e2 Initial load
duke
parents:
diff changeset
    48
//      by calling copy_to.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    49
489c9b5090e2 Initial load
duke
parents:
diff changeset
    50
class DebugToken; // Opaque datatype for stored:
489c9b5090e2 Initial load
duke
parents:
diff changeset
    51
                  //  - GrowableArray<ScopeValue*>
489c9b5090e2 Initial load
duke
parents:
diff changeset
    52
                  //  - GrowableArray<MonitorValue*>
489c9b5090e2 Initial load
duke
parents:
diff changeset
    53
489c9b5090e2 Initial load
duke
parents:
diff changeset
    54
// Alias for InvocationEntryBci.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    55
// Both constants are used for a pseudo-BCI which refers
489c9b5090e2 Initial load
duke
parents:
diff changeset
    56
// to the state just _before_ a method is entered.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    57
// SynchronizationEntryBCI is used where the emphasis
489c9b5090e2 Initial load
duke
parents:
diff changeset
    58
// is on the implicit monitorenter of a synchronized method.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    59
const int SynchronizationEntryBCI = InvocationEntryBci;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    60
489c9b5090e2 Initial load
duke
parents:
diff changeset
    61
class DIR_Chunk; // private class, a nugget of collected information
489c9b5090e2 Initial load
duke
parents:
diff changeset
    62
489c9b5090e2 Initial load
duke
parents:
diff changeset
    63
class DebugInformationRecorder: public ResourceObj {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    64
 public:
489c9b5090e2 Initial load
duke
parents:
diff changeset
    65
  // constructor
489c9b5090e2 Initial load
duke
parents:
diff changeset
    66
  DebugInformationRecorder(OopRecorder* oop_recorder);
489c9b5090e2 Initial load
duke
parents:
diff changeset
    67
489c9b5090e2 Initial load
duke
parents:
diff changeset
    68
  // adds an oopmap at a specific offset
489c9b5090e2 Initial load
duke
parents:
diff changeset
    69
  void add_oopmap(int pc_offset, OopMap* map);
489c9b5090e2 Initial load
duke
parents:
diff changeset
    70
489c9b5090e2 Initial load
duke
parents:
diff changeset
    71
  // adds a jvm mapping at pc-offset, for a safepoint only
489c9b5090e2 Initial load
duke
parents:
diff changeset
    72
  void add_safepoint(int pc_offset, OopMap* map);
489c9b5090e2 Initial load
duke
parents:
diff changeset
    73
489c9b5090e2 Initial load
duke
parents:
diff changeset
    74
  // adds a jvm mapping at pc-offset, for a non-safepoint (profile point)
489c9b5090e2 Initial load
duke
parents:
diff changeset
    75
  void add_non_safepoint(int pc_offset);
489c9b5090e2 Initial load
duke
parents:
diff changeset
    76
489c9b5090e2 Initial load
duke
parents:
diff changeset
    77
  // Describes debugging information for a scope at the given pc_offset.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    78
  // Calls must be in non-decreasing order of pc_offset.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    79
  // If there are several calls at a single pc_offset,
489c9b5090e2 Initial load
duke
parents:
diff changeset
    80
  // then they occur in the same order as they were performed by the JVM,
489c9b5090e2 Initial load
duke
parents:
diff changeset
    81
  // with the most recent (innermost) call being described last.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    82
  // For a safepoint, the pc_offset must have been mentioned
489c9b5090e2 Initial load
duke
parents:
diff changeset
    83
  // previously by add_safepoint.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    84
  // Otherwise, the pc_offset must have been mentioned previously
489c9b5090e2 Initial load
duke
parents:
diff changeset
    85
  // by add_non_safepoint, and the locals, expressions, and monitors
489c9b5090e2 Initial load
duke
parents:
diff changeset
    86
  // must all be null.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    87
  void describe_scope(int         pc_offset,
489c9b5090e2 Initial load
duke
parents:
diff changeset
    88
                      ciMethod*   method,
489c9b5090e2 Initial load
duke
parents:
diff changeset
    89
                      int         bci,
489c9b5090e2 Initial load
duke
parents:
diff changeset
    90
                      DebugToken* locals      = NULL,
489c9b5090e2 Initial load
duke
parents:
diff changeset
    91
                      DebugToken* expressions = NULL,
489c9b5090e2 Initial load
duke
parents:
diff changeset
    92
                      DebugToken* monitors    = NULL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
    93
489c9b5090e2 Initial load
duke
parents:
diff changeset
    94
489c9b5090e2 Initial load
duke
parents:
diff changeset
    95
  void dump_object_pool(GrowableArray<ScopeValue*>* objects);
489c9b5090e2 Initial load
duke
parents:
diff changeset
    96
489c9b5090e2 Initial load
duke
parents:
diff changeset
    97
  // This call must follow every add_safepoint,
489c9b5090e2 Initial load
duke
parents:
diff changeset
    98
  // after any intervening describe_scope calls.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    99
  void end_safepoint(int pc_offset)      { end_scopes(pc_offset, true); }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   100
  void end_non_safepoint(int pc_offset)  { end_scopes(pc_offset, false); }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   101
489c9b5090e2 Initial load
duke
parents:
diff changeset
   102
  // helper fuctions for describe_scope to enable sharing
489c9b5090e2 Initial load
duke
parents:
diff changeset
   103
  DebugToken* create_scope_values(GrowableArray<ScopeValue*>* values);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   104
  DebugToken* create_monitor_values(GrowableArray<MonitorValue*>* monitors);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   105
489c9b5090e2 Initial load
duke
parents:
diff changeset
   106
  // returns the size of the generated scopeDescs.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   107
  int data_size();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   108
  int pcs_size();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   109
  int oop_size() { return oop_recorder()->oop_size(); }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   110
489c9b5090e2 Initial load
duke
parents:
diff changeset
   111
  // copy the generated debugging information to nmethod
489c9b5090e2 Initial load
duke
parents:
diff changeset
   112
  void copy_to(nmethod* nm);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   113
489c9b5090e2 Initial load
duke
parents:
diff changeset
   114
  // verifies the debug information
489c9b5090e2 Initial load
duke
parents:
diff changeset
   115
  void verify(const nmethod* code);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   116
489c9b5090e2 Initial load
duke
parents:
diff changeset
   117
  static void print_statistics() PRODUCT_RETURN;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   118
489c9b5090e2 Initial load
duke
parents:
diff changeset
   119
  // Method for setting oopmaps to temporarily preserve old handling of oopmaps
489c9b5090e2 Initial load
duke
parents:
diff changeset
   120
  OopMapSet *_oopmaps;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   121
  void set_oopmaps(OopMapSet *oopmaps) { _oopmaps = oopmaps; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   122
489c9b5090e2 Initial load
duke
parents:
diff changeset
   123
  OopRecorder* oop_recorder() { return _oop_recorder; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   124
489c9b5090e2 Initial load
duke
parents:
diff changeset
   125
  int last_pc_offset() { return last_pc()->pc_offset(); }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   126
489c9b5090e2 Initial load
duke
parents:
diff changeset
   127
  bool recording_non_safepoints() { return _recording_non_safepoints; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   128
489c9b5090e2 Initial load
duke
parents:
diff changeset
   129
 private:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   130
  friend class ScopeDesc;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   131
  friend class vframeStreamCommon;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   132
  friend class DIR_Chunk;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   133
489c9b5090e2 Initial load
duke
parents:
diff changeset
   134
  // True if we are recording non-safepoint scopes.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   135
  // This flag is set if DebugNonSafepoints is true, or if
489c9b5090e2 Initial load
duke
parents:
diff changeset
   136
  // JVMTI post_compiled_method_load events are enabled.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   137
  const bool _recording_non_safepoints;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   138
489c9b5090e2 Initial load
duke
parents:
diff changeset
   139
  DebugInfoWriteStream* _stream;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   140
489c9b5090e2 Initial load
duke
parents:
diff changeset
   141
  DebugInfoWriteStream* stream() const { return _stream; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   142
489c9b5090e2 Initial load
duke
parents:
diff changeset
   143
  OopRecorder* _oop_recorder;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   144
489c9b5090e2 Initial load
duke
parents:
diff changeset
   145
  // Scopes that have been described so far.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   146
  GrowableArray<DIR_Chunk*>* _all_chunks;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   147
  GrowableArray<DIR_Chunk*>* _shared_chunks;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   148
  DIR_Chunk* _next_chunk;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   149
  DIR_Chunk* _next_chunk_limit;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   150
489c9b5090e2 Initial load
duke
parents:
diff changeset
   151
#ifdef ASSERT
489c9b5090e2 Initial load
duke
parents:
diff changeset
   152
  enum { rs_null, rs_safepoint, rs_non_safepoint };
489c9b5090e2 Initial load
duke
parents:
diff changeset
   153
  int _recording_state;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   154
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
   155
489c9b5090e2 Initial load
duke
parents:
diff changeset
   156
  PcDesc* _pcs;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   157
  int     _pcs_size;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   158
  int     _pcs_length;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   159
  // Note:  Would use GrowableArray<PcDesc>, but structs are not supported.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   160
489c9b5090e2 Initial load
duke
parents:
diff changeset
   161
  // PC of most recent real safepoint before the current one,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   162
  // updated after end_scopes.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   163
  int _prev_safepoint_pc;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   164
489c9b5090e2 Initial load
duke
parents:
diff changeset
   165
  PcDesc* last_pc() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   166
    guarantee(_pcs_length > 0, "a safepoint must be declared already");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   167
    return &_pcs[_pcs_length-1];
489c9b5090e2 Initial load
duke
parents:
diff changeset
   168
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   169
  PcDesc* prev_pc() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   170
    guarantee(_pcs_length > 1, "a safepoint must be declared already");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   171
    return &_pcs[_pcs_length-2];
489c9b5090e2 Initial load
duke
parents:
diff changeset
   172
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   173
  void add_new_pc_offset(int pc_offset);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   174
  void end_scopes(int pc_offset, bool is_safepoint);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   175
489c9b5090e2 Initial load
duke
parents:
diff changeset
   176
  int  serialize_monitor_values(GrowableArray<MonitorValue*>* monitors);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   177
  int  serialize_scope_values(GrowableArray<ScopeValue*>* values);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   178
  int  find_sharable_decode_offset(int stream_offset);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   179
489c9b5090e2 Initial load
duke
parents:
diff changeset
   180
 public:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   181
  enum { serialized_null = 0 };
489c9b5090e2 Initial load
duke
parents:
diff changeset
   182
};