src/share/vm/runtime/frame.cpp

changeset 3433
eaa9557116a2
parent 3238
b20d64f83668
child 3445
82e5a84b7436
     1.1 --- a/src/share/vm/runtime/frame.cpp	Fri Jan 13 12:58:26 2012 -0800
     1.2 +++ b/src/share/vm/runtime/frame.cpp	Wed Jan 18 16:18:31 2012 +0100
     1.3 @@ -1,5 +1,5 @@
     1.4  /*
     1.5 - * Copyright (c) 1997, 2011, Oracle and/or its affiliates. All rights reserved.
     1.6 + * Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved.
     1.7   * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
     1.8   *
     1.9   * This code is free software; you can redistribute it and/or modify it
    1.10 @@ -1334,24 +1334,21 @@
    1.11  
    1.12  
    1.13  void frame::describe(FrameValues& values, int frame_no) {
    1.14 +  intptr_t* frame_pointer = real_fp();
    1.15    if (is_entry_frame() || is_compiled_frame() || is_interpreted_frame() || is_native_frame()) {
    1.16      // Label values common to most frames
    1.17      values.describe(-1, unextended_sp(), err_msg("unextended_sp for #%d", frame_no));
    1.18      values.describe(-1, sp(), err_msg("sp for #%d", frame_no));
    1.19 -    if (is_compiled_frame()) {
    1.20 -      values.describe(-1, sp() + _cb->frame_size(), err_msg("computed fp for #%d", frame_no));
    1.21 -    } else {
    1.22 -      values.describe(-1, fp(), err_msg("fp for #%d", frame_no));
    1.23 -    }
    1.24 +    values.describe(-1, frame_pointer, err_msg("frame pointer for #%d", frame_no));
    1.25    }
    1.26    if (is_interpreted_frame()) {
    1.27      methodOop m = interpreter_frame_method();
    1.28      int bci = interpreter_frame_bci();
    1.29  
    1.30      // Label the method and current bci
    1.31 -    values.describe(-1, MAX2(sp(), fp()),
    1.32 +    values.describe(-1, MAX2(sp(), frame_pointer),
    1.33                      FormatBuffer<1024>("#%d method %s @ %d", frame_no, m->name_and_sig_as_C_string(), bci), 2);
    1.34 -    values.describe(-1, MAX2(sp(), fp()),
    1.35 +    values.describe(-1, MAX2(sp(), frame_pointer),
    1.36                      err_msg("- %d locals %d max stack", m->max_locals(), m->max_stack()), 1);
    1.37      if (m->max_locals() > 0) {
    1.38        intptr_t* l0 = interpreter_frame_local_at(0);
    1.39 @@ -1383,18 +1380,18 @@
    1.40      }
    1.41    } else if (is_entry_frame()) {
    1.42      // For now just label the frame
    1.43 -    values.describe(-1, MAX2(sp(), fp()), err_msg("#%d entry frame", frame_no), 2);
    1.44 +    values.describe(-1, MAX2(sp(), frame_pointer), err_msg("#%d entry frame", frame_no), 2);
    1.45    } else if (is_compiled_frame()) {
    1.46      // For now just label the frame
    1.47      nmethod* nm = cb()->as_nmethod_or_null();
    1.48 -    values.describe(-1, MAX2(sp(), fp()),
    1.49 +    values.describe(-1, MAX2(sp(), frame_pointer),
    1.50                      FormatBuffer<1024>("#%d nmethod " INTPTR_FORMAT " for method %s%s", frame_no,
    1.51                                         nm, nm->method()->name_and_sig_as_C_string(),
    1.52                                         is_deoptimized_frame() ? " (deoptimized" : ""), 2);
    1.53    } else if (is_native_frame()) {
    1.54      // For now just label the frame
    1.55      nmethod* nm = cb()->as_nmethod_or_null();
    1.56 -    values.describe(-1, MAX2(sp(), fp()),
    1.57 +    values.describe(-1, MAX2(sp(), frame_pointer),
    1.58                      FormatBuffer<1024>("#%d nmethod " INTPTR_FORMAT " for native method %s", frame_no,
    1.59                                         nm, nm->method()->name_and_sig_as_C_string()), 2);
    1.60    }

mercurial