diff --git a/src/cpu/sparc/vm/frame_sparc.inline.hpp b/src/cpu/sparc/vm/frame_sparc.inline.hpp index bc97771ff1b2fca02534f33172cf37974c070704..4d11edf2a3a8d9eb3c50e2f670a25e9497aab6f1 100644 --- a/src/cpu/sparc/vm/frame_sparc.inline.hpp +++ b/src/cpu/sparc/vm/frame_sparc.inline.hpp @@ -59,7 +59,7 @@ inline bool frame::is_younger(intptr_t* id) const { assert(this->id() != NULL && inline bool frame::is_older(intptr_t* id) const { assert(this->id() != NULL && id != NULL, "NULL frame id"); return this->id() > id ; } -inline int frame::frame_size() const { return sender_sp() - sp(); } +inline int frame::frame_size(RegisterMap* map) const { return sender_sp() - sp(); } inline intptr_t* frame::link() const { return (intptr_t *)(fp()[FP->sp_offset_in_saved_window()] + STACK_BIAS); } diff --git a/src/cpu/x86/vm/frame_x86.cpp b/src/cpu/x86/vm/frame_x86.cpp index 4df2c039dc1fa16618467200dbdcb6a02c86b95b..dc0ca4af509c5feca1bc30b7ad64674f07ae811b 100644 --- a/src/cpu/x86/vm/frame_x86.cpp +++ b/src/cpu/x86/vm/frame_x86.cpp @@ -237,9 +237,8 @@ bool frame::is_interpreted_frame() const { return Interpreter::contains(pc()); } -int frame::frame_size() const { - RegisterMap map(JavaThread::current(), false); - frame sender = this->sender(&map); +int frame::frame_size(RegisterMap* map) const { + frame sender = this->sender(map); return sender.sp() - sp(); } diff --git a/src/share/vm/runtime/frame.hpp b/src/share/vm/runtime/frame.hpp index 35372751894857cca2aba70315bbeef519a379ed..7513ca1f4b2a84b27fe3913d5be84e2a5eb0d114 100644 --- a/src/share/vm/runtime/frame.hpp +++ b/src/share/vm/runtime/frame.hpp @@ -117,7 +117,7 @@ class frame VALUE_OBJ_CLASS_SPEC { bool can_be_deoptimized() const; // returns the frame size in stack slots - int frame_size() const; + int frame_size(RegisterMap* map) const; // returns the sending frame frame sender(RegisterMap* map) const; diff --git a/src/share/vm/runtime/vframe.cpp b/src/share/vm/runtime/vframe.cpp index ce5a71517f34e5c56fcebe26b9a42b9d337351f1..6474e6fabf8f204569705663c4deb949648a96b2 100644 --- a/src/share/vm/runtime/vframe.cpp +++ b/src/share/vm/runtime/vframe.cpp @@ -559,7 +559,8 @@ void javaVFrame::print_value() const { } // Check frame size and print warning if it looks suspiciously large if (fr().sp() != NULL) { - uint size = fr().frame_size(); + RegisterMap map = *register_map(); + uint size = fr().frame_size(&map); #ifdef _LP64 if (size > 8*K) warning("SUSPICIOUSLY LARGE FRAME (%d)", size); #else