# HG changeset patch # User coleenp # Date 1361298819 18000 # Node ID 1048edb5434a441c4b8ed82f915d5baccd4f47ef # Parent 5cd2fac2ae707ae46a2d3adcd9485b5c6a9df586# Parent 56c364daccc3ce0fef1984f312848337bb8fd727 Merge diff -r 5cd2fac2ae70 -r 1048edb5434a src/share/vm/oops/method.hpp --- a/src/share/vm/oops/method.hpp Tue Feb 19 08:51:56 2013 -0500 +++ b/src/share/vm/oops/method.hpp Tue Feb 19 13:33:39 2013 -0500 @@ -456,6 +456,8 @@ void print_codes_on(int from, int to, outputStream* st) const PRODUCT_RETURN; // method parameters + bool has_method_parameters() const + { return constMethod()->has_method_parameters(); } int method_parameters_length() const { return constMethod()->method_parameters_length(); } MethodParametersElement* method_parameters_start() const diff -r 5cd2fac2ae70 -r 1048edb5434a src/share/vm/prims/jvmtiRedefineClasses.cpp --- a/src/share/vm/prims/jvmtiRedefineClasses.cpp Tue Feb 19 08:51:56 2013 -0500 +++ b/src/share/vm/prims/jvmtiRedefineClasses.cpp Tue Feb 19 13:33:39 2013 -0500 @@ -1558,6 +1558,18 @@ } break; } } // end for each bytecode + + // We also need to rewrite the parameter name indexes, if there is + // method parameter data present + if(method->has_method_parameters()) { + const int len = method->method_parameters_length(); + MethodParametersElement* elem = method->method_parameters_start(); + + for (int i = 0; i < len; i++) { + const u2 cp_index = elem[i].name_cp_index; + elem[i].name_cp_index = find_new_index(cp_index); + } + } } // end rewrite_cp_refs_in_method()