< prev index next >

src/hotspot/cpu/x86/frame_x86.inline.hpp

Print this page

 15  * You should have received a copy of the GNU General Public License version
 16  * 2 along with this work; if not, write to the Free Software Foundation,
 17  * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
 18  *
 19  * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
 20  * or visit www.oracle.com if you need additional information or have any
 21  * questions.
 22  *
 23  */
 24 
 25 #ifndef CPU_X86_FRAME_X86_INLINE_HPP
 26 #define CPU_X86_FRAME_X86_INLINE_HPP
 27 
 28 #include "code/codeBlob.inline.hpp"
 29 #include "code/codeCache.inline.hpp"
 30 #include "code/vmreg.inline.hpp"
 31 #include "compiler/oopMap.inline.hpp"
 32 #include "interpreter/interpreter.hpp"
 33 #include "runtime/sharedRuntime.hpp"
 34 #include "runtime/registerMap.hpp"



 35 
 36 // Inline functions for Intel frames:
 37 
 38 // Constructors:
 39 
 40 inline frame::frame() {
 41   _pc = nullptr;
 42   _sp = nullptr;
 43   _unextended_sp = nullptr;
 44   _fp = nullptr;
 45   _cb = nullptr;
 46   _deopt_state = unknown;
 47   _oop_map = nullptr;
 48   _on_heap = false;
 49   DEBUG_ONLY(_frame_index = -1;)
 50 }
 51 
 52 inline void frame::init(intptr_t* sp, intptr_t* fp, address pc) {
 53   _sp = sp;
 54   _unextended_sp = sp;

368   if (is_entry_frame())       return sender_for_entry_frame(map);
369   if (is_upcall_stub_frame()) return sender_for_upcall_stub_frame(map);
370   if (is_interpreted_frame()) return sender_for_interpreter_frame(map);
371 
372   assert(_cb == CodeCache::find_blob(pc()), "Must be the same");
373   if (_cb != nullptr) return sender_for_compiled_frame(map);
374 
375   // Must be native-compiled frame, i.e. the marshaling code for native
376   // methods that exists in the core system.
377   return frame(sender_sp(), link(), sender_pc());
378 }
379 
380 inline frame frame::sender_for_compiled_frame(RegisterMap* map) const {
381   assert(map != nullptr, "map must be set");
382 
383   // frame owned by optimizing compiler
384   assert(_cb->frame_size() > 0, "must have non-zero frame size");
385   intptr_t* sender_sp = unextended_sp() + _cb->frame_size();
386   assert(sender_sp == real_fp(), "");
387 
388   // On Intel the return_address is always the word on the stack
389   address sender_pc = (address) *(sender_sp-1);

390 
391   // This is the saved value of EBP which may or may not really be an FP.
392   // It is only an FP if the sender is an interpreter frame (or C1?).
393   // saved_fp_addr should be correct even for a bottom thawed frame (with a return barrier)
394   intptr_t** saved_fp_addr = (intptr_t**) (sender_sp - frame::sender_sp_offset);
395 
















396   if (map->update_map()) {
397     // Tell GC to use argument oopmaps for some runtime stubs that need it.
398     // For C1, the runtime stub might not have oop maps, so set this flag
399     // outside of update_register_map.
400     if (!_cb->is_nmethod()) { // compiled frames do not use callee-saved registers
401       map->set_include_argument_oops(_cb->caller_must_gc_arguments(map->thread()));


















402       if (oop_map() != nullptr) {
403         _oop_map->update_register_map(this, map);
404       }
405     } else {
406       assert(!_cb->caller_must_gc_arguments(map->thread()), "");
407       assert(!map->include_argument_oops(), "");
408       assert(oop_map() == nullptr || !oop_map()->has_any(OopMapValue::callee_saved_value), "callee-saved value in compiled frame");
409     }
410 
411     // Since the prolog does the save and restore of EBP there is no oopmap
412     // for it so we must fill in its location as if there was an oopmap entry
413     // since if our caller was compiled code there could be live jvm state in it.
414     update_map_with_saved_link(map, saved_fp_addr);
415   }
416 
417   assert(sender_sp != sp(), "must have changed");
418 
419   if (Continuation::is_return_barrier_entry(sender_pc)) {
420     if (map->walk_cont()) { // about to walk into an h-stack
421       return Continuation::top_frame(*this, map);

 15  * You should have received a copy of the GNU General Public License version
 16  * 2 along with this work; if not, write to the Free Software Foundation,
 17  * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
 18  *
 19  * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
 20  * or visit www.oracle.com if you need additional information or have any
 21  * questions.
 22  *
 23  */
 24 
 25 #ifndef CPU_X86_FRAME_X86_INLINE_HPP
 26 #define CPU_X86_FRAME_X86_INLINE_HPP
 27 
 28 #include "code/codeBlob.inline.hpp"
 29 #include "code/codeCache.inline.hpp"
 30 #include "code/vmreg.inline.hpp"
 31 #include "compiler/oopMap.inline.hpp"
 32 #include "interpreter/interpreter.hpp"
 33 #include "runtime/sharedRuntime.hpp"
 34 #include "runtime/registerMap.hpp"
 35 #ifdef COMPILER1
 36 #include "c1/c1_Runtime1.hpp"
 37 #endif
 38 
 39 // Inline functions for Intel frames:
 40 
 41 // Constructors:
 42 
 43 inline frame::frame() {
 44   _pc = nullptr;
 45   _sp = nullptr;
 46   _unextended_sp = nullptr;
 47   _fp = nullptr;
 48   _cb = nullptr;
 49   _deopt_state = unknown;
 50   _oop_map = nullptr;
 51   _on_heap = false;
 52   DEBUG_ONLY(_frame_index = -1;)
 53 }
 54 
 55 inline void frame::init(intptr_t* sp, intptr_t* fp, address pc) {
 56   _sp = sp;
 57   _unextended_sp = sp;

371   if (is_entry_frame())       return sender_for_entry_frame(map);
372   if (is_upcall_stub_frame()) return sender_for_upcall_stub_frame(map);
373   if (is_interpreted_frame()) return sender_for_interpreter_frame(map);
374 
375   assert(_cb == CodeCache::find_blob(pc()), "Must be the same");
376   if (_cb != nullptr) return sender_for_compiled_frame(map);
377 
378   // Must be native-compiled frame, i.e. the marshaling code for native
379   // methods that exists in the core system.
380   return frame(sender_sp(), link(), sender_pc());
381 }
382 
383 inline frame frame::sender_for_compiled_frame(RegisterMap* map) const {
384   assert(map != nullptr, "map must be set");
385 
386   // frame owned by optimizing compiler
387   assert(_cb->frame_size() > 0, "must have non-zero frame size");
388   intptr_t* sender_sp = unextended_sp() + _cb->frame_size();
389   assert(sender_sp == real_fp(), "");
390 
391 #ifdef ASSERT
392   address sender_pc_copy = (address) *(sender_sp-1);
393 #endif
394 
395   // This is the saved value of EBP which may or may not really be an FP.
396   // It is only an FP if the sender is an interpreter frame (or C1?).
397   // saved_fp_addr should be correct even for a bottom thawed frame (with a return barrier)
398   intptr_t** saved_fp_addr = (intptr_t**) (sender_sp - frame::sender_sp_offset);
399 
400   // Repair the sender sp if the frame has been extended
401   sender_sp = repair_sender_sp(sender_sp, saved_fp_addr);
402 
403   // On Intel the return_address is always the word on the stack
404   address sender_pc = (address) *(sender_sp-1);
405 
406 #ifdef ASSERT
407   if (sender_pc != sender_pc_copy) {
408     // When extending the stack in the callee method entry to make room for unpacking of value
409     // type args, we keep a copy of the sender pc at the expected location in the callee frame.
410     // If the sender pc is patched due to deoptimization, the copy is not consistent anymore.
411     nmethod* nm = CodeCache::find_blob(sender_pc)->as_nmethod();
412     assert(sender_pc == nm->deopt_mh_handler_begin() || sender_pc == nm->deopt_handler_begin(), "unexpected sender pc");
413   }
414 #endif
415 
416   if (map->update_map()) {
417     // Tell GC to use argument oopmaps for some runtime stubs that need it.
418     // For C1, the runtime stub might not have oop maps, so set this flag
419     // outside of update_register_map.
420     bool c1_buffering = false;
421 #ifdef COMPILER1
422     nmethod* nm = _cb->as_nmethod_or_null();
423     if (nm != nullptr && nm->is_compiled_by_c1() && nm->method()->has_scalarized_args() &&
424         pc() < nm->verified_inline_entry_point()) {
425       // The VEP and VIEP(RO) of C1-compiled methods call buffer_inline_args_xxx
426       // before doing any argument shuffling, so we need to scan the oops
427       // as the caller passes them.
428       c1_buffering = true;
429 #ifdef ASSERT
430       NativeCall* call = nativeCall_before(pc());
431       address dest = call->destination();
432       assert(dest == Runtime1::entry_for(C1StubId::buffer_inline_args_no_receiver_id) ||
433              dest == Runtime1::entry_for(C1StubId::buffer_inline_args_id), "unexpected safepoint in entry point");
434 #endif
435     }
436 #endif
437     if (!_cb->is_nmethod() || c1_buffering) { // compiled frames do not use callee-saved registers
438       bool caller_args = _cb->caller_must_gc_arguments(map->thread()) || c1_buffering;
439       map->set_include_argument_oops(caller_args);
440       if (oop_map() != nullptr) {
441         _oop_map->update_register_map(this, map);
442       }
443     } else {
444       assert(!_cb->caller_must_gc_arguments(map->thread()), "");
445       assert(!map->include_argument_oops(), "");
446       assert(oop_map() == nullptr || !oop_map()->has_any(OopMapValue::callee_saved_value), "callee-saved value in compiled frame");
447     }
448 
449     // Since the prolog does the save and restore of EBP there is no oopmap
450     // for it so we must fill in its location as if there was an oopmap entry
451     // since if our caller was compiled code there could be live jvm state in it.
452     update_map_with_saved_link(map, saved_fp_addr);
453   }
454 
455   assert(sender_sp != sp(), "must have changed");
456 
457   if (Continuation::is_return_barrier_entry(sender_pc)) {
458     if (map->walk_cont()) { // about to walk into an h-stack
459       return Continuation::top_frame(*this, map);
< prev index next >