1.1 --- a/src/cpu/sparc/vm/methodHandles_sparc.cpp Sun Jan 22 14:03:20 2012 -0800 1.2 +++ b/src/cpu/sparc/vm/methodHandles_sparc.cpp Tue Jan 24 15:41:17 2012 +0100 1.3 @@ -1,5 +1,5 @@ 1.4 /* 1.5 - * Copyright (c) 2008, 2011, Oracle and/or its affiliates. All rights reserved. 1.6 + * Copyright (c) 2008, 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 @@ -1000,6 +1000,24 @@ 1.11 BLOCK_COMMENT("} move_return_value"); 1.12 } 1.13 1.14 +#ifdef ASSERT 1.15 +void MethodHandles::RicochetFrame::describe(const frame* fr, FrameValues& values, int frame_no) { 1.16 + RicochetFrame* rf = new RicochetFrame(*fr); 1.17 + 1.18 + // ricochet slots (kept in registers for sparc) 1.19 + values.describe(frame_no, rf->register_addr(I5_savedSP), err_msg("exact_sender_sp reg for #%d", frame_no)); 1.20 + values.describe(frame_no, rf->register_addr(L5_conversion), err_msg("conversion reg for #%d", frame_no)); 1.21 + values.describe(frame_no, rf->register_addr(L4_saved_args_base), err_msg("saved_args_base reg for #%d", frame_no)); 1.22 + values.describe(frame_no, rf->register_addr(L3_saved_args_layout), err_msg("saved_args_layout reg for #%d", frame_no)); 1.23 + values.describe(frame_no, rf->register_addr(L2_saved_target), err_msg("saved_target reg for #%d", frame_no)); 1.24 + values.describe(frame_no, rf->register_addr(L1_continuation), err_msg("continuation reg for #%d", frame_no)); 1.25 + 1.26 + // relevant ricochet targets (in caller frame) 1.27 + values.describe(-1, rf->saved_args_base(), err_msg("*saved_args_base for #%d", frame_no)); 1.28 + values.describe(-1, (intptr_t *)(STACK_BIAS+(uintptr_t)rf->exact_sender_sp()), err_msg("*exact_sender_sp+STACK_BIAS for #%d", frame_no)); 1.29 +} 1.30 +#endif // ASSERT 1.31 + 1.32 #ifndef PRODUCT 1.33 extern "C" void print_method_handle(oop mh); 1.34 void trace_method_handle_stub(const char* adaptername,