hotspot/src/share/vm/runtime/rframe.cpp
author tschatzl
Thu, 16 May 2013 23:51:51 +0200
changeset 17397 609242d28659
parent 8921 14bfe81f2a9d
child 25715 d5a8dbdc5150
permissions -rw-r--r--
8014765: VM exits if MaxTenuringThreshold is set below the default InitialTenuringThreshold, and InitialTenuringThreshold is not set Summary: The VM exits when the condition in the subject line applies. The fix sets InitialTenuringThreshold to MaxTenuringThreshold if it is larger than MaxTenuringThreshold and InitialTenuringThreshold has not been set (is default). Reviewed-by: jwilhelm, jmasa, brutisso, johnc
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
     1
/*
8921
14bfe81f2a9d 7010070: Update all 2010 Oracle-changed OpenJDK files to have the proper copyright dates - second pass
trims
parents: 8076
diff changeset
     2
 * Copyright (c) 1997, 2011, Oracle and/or its affiliates. All rights reserved.
1
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
 *
5547
f4b087cbb361 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 1
diff changeset
    19
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
f4b087cbb361 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 1
diff changeset
    20
 * or visit www.oracle.com if you need additional information or have any
f4b087cbb361 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 1
diff changeset
    21
 * questions.
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    22
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
    23
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
    24
7397
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6418
diff changeset
    25
#include "precompiled.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6418
diff changeset
    26
#include "interpreter/interpreter.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6418
diff changeset
    27
#include "oops/oop.inline.hpp"
8076
96d498ec7ae1 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 7397
diff changeset
    28
#include "oops/symbol.hpp"
7397
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6418
diff changeset
    29
#include "runtime/frame.inline.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6418
diff changeset
    30
#include "runtime/rframe.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6418
diff changeset
    31
#include "runtime/vframe.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6418
diff changeset
    32
#include "runtime/vframe_hp.hpp"
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    33
489c9b5090e2 Initial load
duke
parents:
diff changeset
    34
489c9b5090e2 Initial load
duke
parents:
diff changeset
    35
static RFrame*const  noCaller    = (RFrame*) 0x1;               // no caller (i.e., initial frame)
489c9b5090e2 Initial load
duke
parents:
diff changeset
    36
static RFrame*const  noCallerYet = (RFrame*) 0x0;               // caller not yet computed
489c9b5090e2 Initial load
duke
parents:
diff changeset
    37
489c9b5090e2 Initial load
duke
parents:
diff changeset
    38
RFrame::RFrame(frame fr, JavaThread* thread, RFrame*const callee) :
489c9b5090e2 Initial load
duke
parents:
diff changeset
    39
  _fr(fr), _thread(thread), _callee(callee), _num(callee ? callee->num() + 1 : 0) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    40
  _caller = (RFrame*)noCallerYet;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    41
  _invocations = 0;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    42
  _distance = 0;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    43
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
    44
489c9b5090e2 Initial load
duke
parents:
diff changeset
    45
void RFrame::set_distance(int d) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    46
  assert(is_compiled() || d >= 0, "should be positive");
489c9b5090e2 Initial load
duke
parents:
diff changeset
    47
  _distance = d;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    48
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
    49
489c9b5090e2 Initial load
duke
parents:
diff changeset
    50
InterpretedRFrame::InterpretedRFrame(frame fr, JavaThread* thread, RFrame*const callee)
489c9b5090e2 Initial load
duke
parents:
diff changeset
    51
: RFrame(fr, thread, callee) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    52
  RegisterMap map(thread, false);
489c9b5090e2 Initial load
duke
parents:
diff changeset
    53
  _vf     = javaVFrame::cast(vframe::new_vframe(&_fr, &map, thread));
489c9b5090e2 Initial load
duke
parents:
diff changeset
    54
  _method = methodHandle(thread, _vf->method());
489c9b5090e2 Initial load
duke
parents:
diff changeset
    55
  assert(   _vf->is_interpreted_frame(), "must be interpreted");
489c9b5090e2 Initial load
duke
parents:
diff changeset
    56
  init();
489c9b5090e2 Initial load
duke
parents:
diff changeset
    57
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
    58
489c9b5090e2 Initial load
duke
parents:
diff changeset
    59
InterpretedRFrame::InterpretedRFrame(frame fr, JavaThread* thread, methodHandle m)
489c9b5090e2 Initial load
duke
parents:
diff changeset
    60
: RFrame(fr, thread, NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    61
  RegisterMap map(thread, false);
489c9b5090e2 Initial load
duke
parents:
diff changeset
    62
  _vf     = javaVFrame::cast(vframe::new_vframe(&_fr, &map, thread));
489c9b5090e2 Initial load
duke
parents:
diff changeset
    63
  _method = m;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    64
489c9b5090e2 Initial load
duke
parents:
diff changeset
    65
  assert(   _vf->is_interpreted_frame(),  "must be interpreted");
489c9b5090e2 Initial load
duke
parents:
diff changeset
    66
  init();
489c9b5090e2 Initial load
duke
parents:
diff changeset
    67
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
    68
489c9b5090e2 Initial load
duke
parents:
diff changeset
    69
CompiledRFrame::CompiledRFrame(frame fr, JavaThread* thread, RFrame*const  callee)
489c9b5090e2 Initial load
duke
parents:
diff changeset
    70
: RFrame(fr, thread, callee) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    71
  init();
489c9b5090e2 Initial load
duke
parents:
diff changeset
    72
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
    73
489c9b5090e2 Initial load
duke
parents:
diff changeset
    74
CompiledRFrame::CompiledRFrame(frame fr, JavaThread* thread)
489c9b5090e2 Initial load
duke
parents:
diff changeset
    75
: RFrame(fr, thread, NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    76
  init();
489c9b5090e2 Initial load
duke
parents:
diff changeset
    77
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
    78
489c9b5090e2 Initial load
duke
parents:
diff changeset
    79
DeoptimizedRFrame::DeoptimizedRFrame(frame fr, JavaThread* thread, RFrame*const  callee)
489c9b5090e2 Initial load
duke
parents:
diff changeset
    80
: InterpretedRFrame(fr, thread, callee) {}
489c9b5090e2 Initial load
duke
parents:
diff changeset
    81
489c9b5090e2 Initial load
duke
parents:
diff changeset
    82
RFrame* RFrame::new_RFrame(frame fr, JavaThread* thread, RFrame*const  callee) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    83
  RFrame* rf;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    84
  int dist = callee ? callee->distance() : -1;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    85
  if (fr.is_interpreted_frame()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    86
    rf = new InterpretedRFrame(fr, thread, callee);
489c9b5090e2 Initial load
duke
parents:
diff changeset
    87
    dist++;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    88
  } else if (fr.is_compiled_frame()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    89
    // Even deopted frames look compiled because the deopt
489c9b5090e2 Initial load
duke
parents:
diff changeset
    90
    // is invisible until it happens.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    91
    rf = new CompiledRFrame(fr, thread, callee);
489c9b5090e2 Initial load
duke
parents:
diff changeset
    92
  } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    93
    assert(false, "Unhandled frame type");
489c9b5090e2 Initial load
duke
parents:
diff changeset
    94
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
    95
  rf->set_distance(dist);
489c9b5090e2 Initial load
duke
parents:
diff changeset
    96
  rf->init();
489c9b5090e2 Initial load
duke
parents:
diff changeset
    97
  return rf;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    98
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
    99
489c9b5090e2 Initial load
duke
parents:
diff changeset
   100
RFrame* RFrame::caller() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   101
  if (_caller != noCallerYet) return (_caller == noCaller) ? NULL : _caller;    // already computed caller
489c9b5090e2 Initial load
duke
parents:
diff changeset
   102
489c9b5090e2 Initial load
duke
parents:
diff changeset
   103
  // caller not yet computed; do it now
489c9b5090e2 Initial load
duke
parents:
diff changeset
   104
  if (_fr.is_first_java_frame()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   105
    _caller = (RFrame*)noCaller;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   106
    return NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   107
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   108
489c9b5090e2 Initial load
duke
parents:
diff changeset
   109
  RegisterMap map(_thread, false);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   110
  frame sender = _fr.real_sender(&map);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   111
  if (sender.is_java_frame()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   112
    _caller = new_RFrame(sender, thread(), this);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   113
    return _caller;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   114
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   115
489c9b5090e2 Initial load
duke
parents:
diff changeset
   116
  // Real caller is not java related
489c9b5090e2 Initial load
duke
parents:
diff changeset
   117
  _caller = (RFrame*)noCaller;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   118
  return NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   119
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   120
489c9b5090e2 Initial load
duke
parents:
diff changeset
   121
int InterpretedRFrame::cost() const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   122
  return _method->code_size();    // fix this
489c9b5090e2 Initial load
duke
parents:
diff changeset
   123
  //return _method->estimated_inline_cost(_receiverKlass);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   124
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   125
489c9b5090e2 Initial load
duke
parents:
diff changeset
   126
int CompiledRFrame::cost() const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   127
  nmethod* nm = top_method()->code();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   128
  if (nm != NULL) {
6418
6671edbd230e 6978355: renaming for 6961697
twisti
parents: 5547
diff changeset
   129
    return nm->insts_size();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   130
  } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   131
    return top_method()->code_size();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   132
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   133
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   134
489c9b5090e2 Initial load
duke
parents:
diff changeset
   135
void CompiledRFrame::init() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   136
  RegisterMap map(thread(), false);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   137
  vframe* vf = vframe::new_vframe(&_fr, &map, thread());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   138
  assert(vf->is_compiled_frame(), "must be compiled");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   139
  _nm = compiledVFrame::cast(vf)->code();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   140
  vf = vf->top();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   141
  _vf = javaVFrame::cast(vf);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   142
  _method = methodHandle(thread(), CodeCache::find_nmethod(_fr.pc())->method());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   143
  assert(_method(), "should have found a method");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   144
#ifndef PRODUCT
489c9b5090e2 Initial load
duke
parents:
diff changeset
   145
  _invocations = _method->compiled_invocation_count();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   146
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
   147
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   148
489c9b5090e2 Initial load
duke
parents:
diff changeset
   149
void InterpretedRFrame::init() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   150
  _invocations = _method->invocation_count() + _method->backedge_count();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   151
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   152
489c9b5090e2 Initial load
duke
parents:
diff changeset
   153
void RFrame::print(const char* kind) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   154
#ifndef PRODUCT
489c9b5090e2 Initial load
duke
parents:
diff changeset
   155
#ifdef COMPILER2
489c9b5090e2 Initial load
duke
parents:
diff changeset
   156
  int cnt = top_method()->interpreter_invocation_count();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   157
#else
489c9b5090e2 Initial load
duke
parents:
diff changeset
   158
  int cnt = top_method()->invocation_count();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   159
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
   160
  tty->print("%3d %s ", _num, is_interpreted() ? "I" : "C");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   161
  top_method()->print_short_name(tty);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   162
  tty->print_cr(": inv=%5d(%d) cst=%4d", _invocations, cnt, cost());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   163
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
   164
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   165
489c9b5090e2 Initial load
duke
parents:
diff changeset
   166
void CompiledRFrame::print() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   167
  RFrame::print("comp");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   168
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   169
489c9b5090e2 Initial load
duke
parents:
diff changeset
   170
void InterpretedRFrame::print() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   171
  RFrame::print("int.");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   172
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   173
489c9b5090e2 Initial load
duke
parents:
diff changeset
   174
void DeoptimizedRFrame::print() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   175
  RFrame::print("deopt.");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   176
}