< prev index next >

src/hotspot/share/oops/method.hpp

Print this page
*** 91,11 ***
  #endif
    // Entry point for calling both from and to the interpreter.
    address _i2i_entry;           // All-args-on-stack calling convention
    // Entry point for calling from compiled code, to compiled code if it exists
    // or else the interpreter.
!   volatile address _from_compiled_entry;     // Cache of: _code ? _code->entry_point() : _adapter->c2i_entry()
    // The entry point for calling both from and to compiled code is
    // "_code->entry_point()".  Because of tiered compilation and de-opt, this
    // field can come and go.  It can transition from null to not-null at any
    // time (whenever a compile completes).  It can transition from not-null to
    // null only at safepoints (because of a de-opt).
--- 91,13 ---
  #endif
    // Entry point for calling both from and to the interpreter.
    address _i2i_entry;           // All-args-on-stack calling convention
    // Entry point for calling from compiled code, to compiled code if it exists
    // or else the interpreter.
!   volatile address _from_compiled_entry;           // Cache of: _code ? _code->entry_point() : _adapter->c2i_entry()
+   volatile address _from_compiled_inline_ro_entry; // Cache of: _code ? _code->verified_inline_ro_entry_point() : _adapter->c2i_inline_ro_entry()
+   volatile address _from_compiled_inline_entry;    // Cache of: _code ? _code->verified_inline_entry_point()    : _adapter->c2i_inline_entry()
    // The entry point for calling both from and to compiled code is
    // "_code->entry_point()".  Because of tiered compilation and de-opt, this
    // field can come and go.  It can transition from null to not-null at any
    // time (whenever a compile completes).  It can transition from not-null to
    // null only at safepoints (because of a de-opt).

*** 130,10 ***
--- 132,12 ---
    void set_constMethod(ConstMethod* xconst)    { _constMethod = xconst; }
  
  
    static address make_adapters(const methodHandle& mh, TRAPS);
    address from_compiled_entry() const;
+   address from_compiled_inline_ro_entry() const;
+   address from_compiled_inline_entry() const;
    address from_interpreted_entry() const;
  
    // access flag
    AccessFlags access_flags() const               { return _access_flags;  }
    void set_access_flags(AccessFlags flags)       { _access_flags = flags; }

*** 354,10 ***
--- 358,12 ---
    int64_t  compiled_invocation_count() const    { return 0; }
  #endif // not PRODUCT
  
    // nmethod/verified compiler entry
    address verified_code_entry();
+   address verified_inline_code_entry();
+   address verified_inline_ro_code_entry();
    bool check_code() const;      // Not inline to avoid circular ref
    nmethod* code() const;
  
    // Locks NMethodState_lock if not held.
    void unlink_code(nmethod *compare);

*** 376,16 ***
    static void set_code(const methodHandle& mh, nmethod* code);
    void set_adapter_entry(AdapterHandlerEntry* adapter) {
      _adapter = adapter;
    }
    void set_from_compiled_entry(address entry) {
!     _from_compiled_entry =  entry;
    }
  
    address get_i2c_entry();
    address get_c2i_entry();
    address get_c2i_unverified_entry();
    address get_c2i_no_clinit_check_entry();
    AdapterHandlerEntry* adapter() const {
      return _adapter;
    }
    // setup entry points
--- 382,24 ---
    static void set_code(const methodHandle& mh, nmethod* code);
    void set_adapter_entry(AdapterHandlerEntry* adapter) {
      _adapter = adapter;
    }
    void set_from_compiled_entry(address entry) {
!     _from_compiled_entry = entry;
+   }
+   void set_from_compiled_inline_ro_entry(address entry) {
+     _from_compiled_inline_ro_entry = entry;
+   }
+   void set_from_compiled_inline_entry(address entry) {
+     _from_compiled_inline_entry = entry;
    }
  
    address get_i2c_entry();
    address get_c2i_entry();
+   address get_c2i_inline_entry();
    address get_c2i_unverified_entry();
+   address get_c2i_unverified_inline_entry();
    address get_c2i_no_clinit_check_entry();
    AdapterHandlerEntry* adapter() const {
      return _adapter;
    }
    // setup entry points

*** 495,11 ***
    InstanceKlass* method_holder() const         { return constants()->pool_holder(); }
  
    Symbol* klass_name() const;                    // returns the name of the method holder
    BasicType result_type() const                  { return constMethod()->result_type(); }
    bool is_returning_oop() const                  { BasicType r = result_type(); return is_reference_type(r); }
!   bool is_returning_fp() const                   { BasicType r = result_type(); return (r == T_FLOAT || r == T_DOUBLE); }
  
    // Checked exceptions thrown by this method (resolved to mirrors)
    objArrayHandle resolved_checked_exceptions(TRAPS) { return resolved_checked_exceptions_impl(this, THREAD); }
  
    // Access flags
--- 509,11 ---
    InstanceKlass* method_holder() const         { return constants()->pool_holder(); }
  
    Symbol* klass_name() const;                    // returns the name of the method holder
    BasicType result_type() const                  { return constMethod()->result_type(); }
    bool is_returning_oop() const                  { BasicType r = result_type(); return is_reference_type(r); }
!   InlineKlass* returns_inline_type(Thread* thread) const;
  
    // Checked exceptions thrown by this method (resolved to mirrors)
    objArrayHandle resolved_checked_exceptions(TRAPS) { return resolved_checked_exceptions_impl(this, THREAD); }
  
    // Access flags

*** 574,19 ***
    bool is_setter() const;
  
    // returns true if the method does nothing but return a constant of primitive type
    bool is_constant_getter() const;
  
-   // returns true if the method is static OR if the classfile version < 51
-   bool has_valid_initializer_flags() const;
- 
    // returns true if the method name is <clinit> and the method has
    // valid static initializer flags.
!   bool is_static_initializer() const;
  
    // returns true if the method name is <init>
!   bool is_object_initializer() const;
  
    // compiled code support
    // NOTE: code() is inherently racy as deopt can be clearing code
    // simultaneously. Use with caution.
    bool has_compiled_code() const;
--- 588,16 ---
    bool is_setter() const;
  
    // returns true if the method does nothing but return a constant of primitive type
    bool is_constant_getter() const;
  
    // returns true if the method name is <clinit> and the method has
    // valid static initializer flags.
!   bool is_class_initializer() const;
  
    // returns true if the method name is <init>
!   bool is_object_constructor() const;
  
    // compiled code support
    // NOTE: code() is inherently racy as deopt can be clearing code
    // simultaneously. Use with caution.
    bool has_compiled_code() const;

*** 604,11 ***
--- 615,14 ---
  
    // interpreter support
    static ByteSize const_offset()                 { return byte_offset_of(Method, _constMethod       ); }
    static ByteSize access_flags_offset()          { return byte_offset_of(Method, _access_flags      ); }
    static ByteSize from_compiled_offset()         { return byte_offset_of(Method, _from_compiled_entry); }
+   static ByteSize from_compiled_inline_offset()  { return byte_offset_of(Method, _from_compiled_inline_entry); }
+   static ByteSize from_compiled_inline_ro_offset(){ return byte_offset_of(Method, _from_compiled_inline_ro_entry); }
    static ByteSize code_offset()                  { return byte_offset_of(Method, _code); }
+   static ByteSize flags_offset()                 { return byte_offset_of(Method, _flags); }
  
    static ByteSize method_counters_offset()       {
      return byte_offset_of(Method, _method_counters);
    }
  #ifndef PRODUCT

*** 762,10 ***
--- 776,21 ---
    void set_has_injected_profile() { constMethod()->set_has_injected_profile(); }
  
    bool has_reserved_stack_access() const { return constMethod()->reserved_stack_access(); }
    void set_has_reserved_stack_access() { constMethod()->set_reserved_stack_access(); }
  
+   bool is_scalarized_arg(int idx) const;
+ 
+   bool c1_needs_stack_repair() const { return constMethod()->c1_needs_stack_repair(); }
+   void set_c1_needs_stack_repair() { constMethod()->set_c1_needs_stack_repair(); }
+ 
+   bool c2_needs_stack_repair() const { return constMethod()->c2_needs_stack_repair(); }
+   void set_c2_needs_stack_repair() { constMethod()->set_c2_needs_stack_repair(); }
+ 
+   bool mismatch() const { return constMethod()->mismatch(); }
+   void set_mismatch() { constMethod()->set_mismatch(); }
+ 
    JFR_ONLY(DEFINE_TRACE_FLAG_ACCESSOR;)
  
    ConstMethod::MethodType method_type() const {
        return _constMethod->method_type();
    }
< prev index next >