src/hotspot/cpu/zero/cppInterpreter_zero.cpp
author stefank
Tue, 26 Nov 2019 10:47:46 +0100
changeset 59290 97d13893ec3c
parent 57777 90ead0febf56
permissions -rw-r--r--
8234748: Clean up atomic and orderAccess includes Reviewed-by: dholmes
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
     1
/*
53582
881c5fbeb849 8218041: Assorted wrong/missing includes
rehn
parents: 52450
diff changeset
     2
 * Copyright (c) 2003, 2019, Oracle and/or its affiliates. All rights reserved.
9136
94ebba447157 7035870: JSR 292: Zero support
twisti
parents: 8725
diff changeset
     3
 * Copyright 2007, 2008, 2009, 2010, 2011 Red Hat, Inc.
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
     4
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
     5
 *
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
     6
 * This code is free software; you can redistribute it and/or modify it
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
     7
 * under the terms of the GNU General Public License version 2 only, as
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
     8
 * published by the Free Software Foundation.
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
     9
 *
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
    10
 * This code is distributed in the hope that it will be useful, but WITHOUT
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
    11
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
    12
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
    13
 * version 2 for more details (a copy is included in the LICENSE file that
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
    14
 * accompanied this code).
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
    15
 *
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
    16
 * You should have received a copy of the GNU General Public License version
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
    17
 * 2 along with this work; if not, write to the Free Software Foundation,
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
    18
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
    19
 *
5547
f4b087cbb361 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 5427
diff changeset
    20
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
f4b087cbb361 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 5427
diff changeset
    21
 * or visit www.oracle.com if you need additional information or have any
f4b087cbb361 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 5427
diff changeset
    22
 * questions.
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
    23
 *
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
    24
 */
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
    25
7397
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 5885
diff changeset
    26
#include "precompiled.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 5885
diff changeset
    27
#include "asm/assembler.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 5885
diff changeset
    28
#include "interpreter/bytecodeHistogram.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 5885
diff changeset
    29
#include "interpreter/cppInterpreter.hpp"
35214
d86005e0b4c2 8074457: Remove the non-Zero CPP Interpreter
coleenp
parents: 34169
diff changeset
    30
#include "interpreter/cppInterpreterGenerator.hpp"
7397
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 5885
diff changeset
    31
#include "interpreter/interpreter.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 5885
diff changeset
    32
#include "interpreter/interpreterRuntime.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 5885
diff changeset
    33
#include "oops/arrayOop.hpp"
49390
95f0b54a3024 8199220: Zero build broken after 8195103, 8191102 and 8189871
enevill
parents: 49192
diff changeset
    34
#include "oops/cpCache.inline.hpp"
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13391
diff changeset
    35
#include "oops/methodData.hpp"
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13391
diff changeset
    36
#include "oops/method.hpp"
7397
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 5885
diff changeset
    37
#include "oops/oop.inline.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 5885
diff changeset
    38
#include "prims/jvmtiExport.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 5885
diff changeset
    39
#include "prims/jvmtiThreadState.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 5885
diff changeset
    40
#include "runtime/arguments.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 5885
diff changeset
    41
#include "runtime/deoptimization.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 5885
diff changeset
    42
#include "runtime/frame.inline.hpp"
53582
881c5fbeb849 8218041: Assorted wrong/missing includes
rehn
parents: 52450
diff changeset
    43
#include "runtime/handles.inline.hpp"
49449
ef5d5d343e2a 8199263: Split interfaceSupport.hpp to not require including .inline.hpp files
coleenp
parents: 49390
diff changeset
    44
#include "runtime/interfaceSupport.inline.hpp"
49192
6734eeef4283 8198474: Move JNIHandles::resolve into jniHandles.inline.hpp
kbarrett
parents: 47906
diff changeset
    45
#include "runtime/jniHandles.inline.hpp"
7397
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 5885
diff changeset
    46
#include "runtime/sharedRuntime.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 5885
diff changeset
    47
#include "runtime/stubRoutines.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 5885
diff changeset
    48
#include "runtime/synchronizer.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 5885
diff changeset
    49
#include "runtime/timer.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 5885
diff changeset
    50
#include "runtime/vframeArray.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 5885
diff changeset
    51
#include "stack_zero.inline.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 5885
diff changeset
    52
#include "utilities/debug.hpp"
15482
470d0b0c09f1 8005915: Unify SERIALGC and INCLUDE_ALTERNATE_GCS
jprovino
parents: 14622
diff changeset
    53
#include "utilities/macros.hpp"
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
    54
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
    55
#ifdef CC_INTERP
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
    56
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
    57
#define fixup_after_potential_safepoint()       \
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
    58
  method = istate->method()
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
    59
9136
94ebba447157 7035870: JSR 292: Zero support
twisti
parents: 8725
diff changeset
    60
#define CALL_VM_NOCHECK_NOFIX(func)             \
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
    61
  thread->set_last_Java_frame();                \
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
    62
  func;                                         \
9136
94ebba447157 7035870: JSR 292: Zero support
twisti
parents: 8725
diff changeset
    63
  thread->reset_last_Java_frame();
94ebba447157 7035870: JSR 292: Zero support
twisti
parents: 8725
diff changeset
    64
94ebba447157 7035870: JSR 292: Zero support
twisti
parents: 8725
diff changeset
    65
#define CALL_VM_NOCHECK(func)                   \
94ebba447157 7035870: JSR 292: Zero support
twisti
parents: 8725
diff changeset
    66
  CALL_VM_NOCHECK_NOFIX(func)                   \
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
    67
  fixup_after_potential_safepoint()
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
    68
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13391
diff changeset
    69
int CppInterpreter::normal_entry(Method* method, intptr_t UNUSED, TRAPS) {
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
    70
  JavaThread *thread = (JavaThread *) THREAD;
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
    71
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
    72
  // Allocate and initialize our frame.
5427
08c6b2b940f7 6951784: Zero deoptimizer changes
twisti
parents: 5418
diff changeset
    73
  InterpreterFrame *frame = InterpreterFrame::build(method, CHECK_0);
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
    74
  thread->push_zero_frame(frame);
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
    75
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
    76
  // Execute those bytecodes!
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
    77
  main_loop(0, THREAD);
5427
08c6b2b940f7 6951784: Zero deoptimizer changes
twisti
parents: 5418
diff changeset
    78
08c6b2b940f7 6951784: Zero deoptimizer changes
twisti
parents: 5418
diff changeset
    79
  // No deoptimized frames on the stack
08c6b2b940f7 6951784: Zero deoptimizer changes
twisti
parents: 5418
diff changeset
    80
  return 0;
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
    81
}
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
    82
37480
291ee208fb72 8132051: Better byte behavior
coleenp
parents: 36181
diff changeset
    83
intptr_t narrow(BasicType type, intptr_t result) {
291ee208fb72 8132051: Better byte behavior
coleenp
parents: 36181
diff changeset
    84
  // mask integer result to narrower return type.
291ee208fb72 8132051: Better byte behavior
coleenp
parents: 36181
diff changeset
    85
  switch (type) {
291ee208fb72 8132051: Better byte behavior
coleenp
parents: 36181
diff changeset
    86
    case T_BOOLEAN:
291ee208fb72 8132051: Better byte behavior
coleenp
parents: 36181
diff changeset
    87
      return result&1;
291ee208fb72 8132051: Better byte behavior
coleenp
parents: 36181
diff changeset
    88
    case T_BYTE:
291ee208fb72 8132051: Better byte behavior
coleenp
parents: 36181
diff changeset
    89
      return (intptr_t)(jbyte)result;
291ee208fb72 8132051: Better byte behavior
coleenp
parents: 36181
diff changeset
    90
    case T_CHAR:
291ee208fb72 8132051: Better byte behavior
coleenp
parents: 36181
diff changeset
    91
      return (intptr_t)(uintptr_t)(jchar)result;
291ee208fb72 8132051: Better byte behavior
coleenp
parents: 36181
diff changeset
    92
    case T_SHORT:
291ee208fb72 8132051: Better byte behavior
coleenp
parents: 36181
diff changeset
    93
      return (intptr_t)(jshort)result;
291ee208fb72 8132051: Better byte behavior
coleenp
parents: 36181
diff changeset
    94
    case T_OBJECT:  // nothing to do fall through
37481
95af21ea8eb0 8146518: Zero interpreter broken with better byte behaviours
coleenp
parents: 37480
diff changeset
    95
    case T_ARRAY:
37480
291ee208fb72 8132051: Better byte behavior
coleenp
parents: 36181
diff changeset
    96
    case T_LONG:
291ee208fb72 8132051: Better byte behavior
coleenp
parents: 36181
diff changeset
    97
    case T_INT:
291ee208fb72 8132051: Better byte behavior
coleenp
parents: 36181
diff changeset
    98
    case T_FLOAT:
291ee208fb72 8132051: Better byte behavior
coleenp
parents: 36181
diff changeset
    99
    case T_DOUBLE:
291ee208fb72 8132051: Better byte behavior
coleenp
parents: 36181
diff changeset
   100
    case T_VOID:
291ee208fb72 8132051: Better byte behavior
coleenp
parents: 36181
diff changeset
   101
      return result;
291ee208fb72 8132051: Better byte behavior
coleenp
parents: 36181
diff changeset
   102
    default  : ShouldNotReachHere();
291ee208fb72 8132051: Better byte behavior
coleenp
parents: 36181
diff changeset
   103
  }
291ee208fb72 8132051: Better byte behavior
coleenp
parents: 36181
diff changeset
   104
}
291ee208fb72 8132051: Better byte behavior
coleenp
parents: 36181
diff changeset
   105
291ee208fb72 8132051: Better byte behavior
coleenp
parents: 36181
diff changeset
   106
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   107
void CppInterpreter::main_loop(int recurse, TRAPS) {
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   108
  JavaThread *thread = (JavaThread *) THREAD;
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   109
  ZeroStack *stack = thread->zero_stack();
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   110
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   111
  // If we are entering from a deopt we may need to call
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   112
  // ourself a few times in order to get to our frame.
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   113
  if (recurse)
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   114
    main_loop(recurse - 1, THREAD);
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   115
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   116
  InterpreterFrame *frame = thread->top_zero_frame()->as_interpreter_frame();
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   117
  interpreterState istate = frame->interpreter_state();
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13391
diff changeset
   118
  Method* method = istate->method();
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   119
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   120
  intptr_t *result = NULL;
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   121
  int result_slots = 0;
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   122
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   123
  while (true) {
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   124
    // We can set up the frame anchor with everything we want at
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   125
    // this point as we are thread_in_Java and no safepoints can
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   126
    // occur until we go to vm mode.  We do have to clear flags
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   127
    // on return from vm but that is it.
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   128
    thread->set_last_Java_frame();
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   129
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   130
    // Call the interpreter
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   131
    if (JvmtiExport::can_post_interpreter_events())
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   132
      BytecodeInterpreter::runWithChecks(istate);
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   133
    else
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   134
      BytecodeInterpreter::run(istate);
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   135
    fixup_after_potential_safepoint();
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   136
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   137
    // Clear the frame anchor
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   138
    thread->reset_last_Java_frame();
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   139
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   140
    // Examine the message from the interpreter to decide what to do
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   141
    if (istate->msg() == BytecodeInterpreter::call_method) {
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13391
diff changeset
   142
      Method* callee = istate->callee();
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   143
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   144
      // Trim back the stack to put the parameters at the top
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   145
      stack->set_sp(istate->stack() + 1);
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   146
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   147
      // Make the call
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   148
      Interpreter::invoke_method(callee, istate->callee_entry_point(), THREAD);
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   149
      fixup_after_potential_safepoint();
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   150
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   151
      // Convert the result
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   152
      istate->set_stack(stack->sp() - 1);
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   153
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   154
      // Restore the stack
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   155
      stack->set_sp(istate->stack_limit() + 1);
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   156
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   157
      // Resume the interpreter
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   158
      istate->set_msg(BytecodeInterpreter::method_resume);
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   159
    }
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   160
    else if (istate->msg() == BytecodeInterpreter::more_monitors) {
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   161
      int monitor_words = frame::interpreter_frame_monitor_size();
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   162
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   163
      // Allocate the space
5335
4319cb12ddfe 6941224: Improved stack overflow handling for Zero
twisti
parents: 5229
diff changeset
   164
      stack->overflow_check(monitor_words, THREAD);
4319cb12ddfe 6941224: Improved stack overflow handling for Zero
twisti
parents: 5229
diff changeset
   165
      if (HAS_PENDING_EXCEPTION)
4319cb12ddfe 6941224: Improved stack overflow handling for Zero
twisti
parents: 5229
diff changeset
   166
        break;
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   167
      stack->alloc(monitor_words * wordSize);
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   168
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   169
      // Move the expression stack contents
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   170
      for (intptr_t *p = istate->stack() + 1; p < istate->stack_base(); p++)
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   171
        *(p - monitor_words) = *p;
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   172
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   173
      // Move the expression stack pointers
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   174
      istate->set_stack_limit(istate->stack_limit() - monitor_words);
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   175
      istate->set_stack(istate->stack() - monitor_words);
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   176
      istate->set_stack_base(istate->stack_base() - monitor_words);
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   177
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   178
      // Zero the new monitor so the interpreter can find it.
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   179
      ((BasicObjectLock *) istate->stack_base())->set_obj(NULL);
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   180
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   181
      // Resume the interpreter
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   182
      istate->set_msg(BytecodeInterpreter::got_monitors);
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   183
    }
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   184
    else if (istate->msg() == BytecodeInterpreter::return_from_method) {
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   185
      // Copy the result into the caller's frame
37481
95af21ea8eb0 8146518: Zero interpreter broken with better byte behaviours
coleenp
parents: 37480
diff changeset
   186
      result_slots = type2size[method->result_type()];
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   187
      assert(result_slots >= 0 && result_slots <= 2, "what?");
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   188
      result = istate->stack() + result_slots;
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   189
      break;
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   190
    }
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   191
    else if (istate->msg() == BytecodeInterpreter::throwing_exception) {
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   192
      assert(HAS_PENDING_EXCEPTION, "should do");
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   193
      break;
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   194
    }
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   195
    else if (istate->msg() == BytecodeInterpreter::do_osr) {
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   196
      // Unwind the current frame
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   197
      thread->pop_zero_frame();
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   198
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   199
      // Remove any extension of the previous frame
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   200
      int extra_locals = method->max_locals() - method->size_of_parameters();
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   201
      stack->set_sp(stack->sp() + extra_locals);
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   202
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   203
      // Jump into the OSR method
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   204
      Interpreter::invoke_osr(
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   205
        method, istate->osr_entry(), istate->osr_buf(), THREAD);
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   206
      return;
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   207
    }
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   208
    else {
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   209
      ShouldNotReachHere();
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   210
    }
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   211
  }
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   212
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   213
  // Unwind the current frame
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   214
  thread->pop_zero_frame();
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   215
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   216
  // Pop our local variables
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   217
  stack->set_sp(stack->sp() + method->max_locals());
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   218
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   219
  // Push our result
37480
291ee208fb72 8132051: Better byte behavior
coleenp
parents: 36181
diff changeset
   220
  for (int i = 0; i < result_slots; i++) {
291ee208fb72 8132051: Better byte behavior
coleenp
parents: 36181
diff changeset
   221
    // Adjust result to smaller
38063
93b9ff8b977e 8154210: Zero: Better byte behaviour
aph
parents: 37486
diff changeset
   222
    union {
93b9ff8b977e 8154210: Zero: Better byte behaviour
aph
parents: 37486
diff changeset
   223
      intptr_t res;
93b9ff8b977e 8154210: Zero: Better byte behaviour
aph
parents: 37486
diff changeset
   224
      jint res_jint;
93b9ff8b977e 8154210: Zero: Better byte behaviour
aph
parents: 37486
diff changeset
   225
    };
93b9ff8b977e 8154210: Zero: Better byte behaviour
aph
parents: 37486
diff changeset
   226
    res = result[-i];
37480
291ee208fb72 8132051: Better byte behavior
coleenp
parents: 36181
diff changeset
   227
    if (result_slots == 1) {
38063
93b9ff8b977e 8154210: Zero: Better byte behaviour
aph
parents: 37486
diff changeset
   228
      BasicType t = method->result_type();
93b9ff8b977e 8154210: Zero: Better byte behaviour
aph
parents: 37486
diff changeset
   229
      if (is_subword_type(t)) {
93b9ff8b977e 8154210: Zero: Better byte behaviour
aph
parents: 37486
diff changeset
   230
        res_jint = (jint)narrow(t, res_jint);
93b9ff8b977e 8154210: Zero: Better byte behaviour
aph
parents: 37486
diff changeset
   231
      }
37480
291ee208fb72 8132051: Better byte behavior
coleenp
parents: 36181
diff changeset
   232
    }
291ee208fb72 8132051: Better byte behavior
coleenp
parents: 36181
diff changeset
   233
    stack->push(res);
291ee208fb72 8132051: Better byte behavior
coleenp
parents: 36181
diff changeset
   234
  }
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   235
}
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   236
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13391
diff changeset
   237
int CppInterpreter::native_entry(Method* method, intptr_t UNUSED, TRAPS) {
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   238
  // Make sure method is native and not abstract
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   239
  assert(method->is_native() && !method->is_abstract(), "should be");
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   240
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   241
  JavaThread *thread = (JavaThread *) THREAD;
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   242
  ZeroStack *stack = thread->zero_stack();
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   243
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   244
  // Allocate and initialize our frame
5427
08c6b2b940f7 6951784: Zero deoptimizer changes
twisti
parents: 5418
diff changeset
   245
  InterpreterFrame *frame = InterpreterFrame::build(method, CHECK_0);
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   246
  thread->push_zero_frame(frame);
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   247
  interpreterState istate = frame->interpreter_state();
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   248
  intptr_t *locals = istate->locals();
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   249
4448
d6ec2737186c 6896043: first round of zero fixes
twisti
parents: 4013
diff changeset
   250
  // Update the invocation counter
d6ec2737186c 6896043: first round of zero fixes
twisti
parents: 4013
diff changeset
   251
  if ((UseCompiler || CountCompiledCalls) && !method->is_synchronized()) {
17314
28fab19f2ccd 8013067: Zero builds are broken after 8010862.
jiangli
parents: 15943
diff changeset
   252
    MethodCounters* mcs = method->method_counters();
28fab19f2ccd 8013067: Zero builds are broken after 8010862.
jiangli
parents: 15943
diff changeset
   253
    if (mcs == NULL) {
28fab19f2ccd 8013067: Zero builds are broken after 8010862.
jiangli
parents: 15943
diff changeset
   254
      CALL_VM_NOCHECK(mcs = InterpreterRuntime::build_method_counters(thread, method));
28fab19f2ccd 8013067: Zero builds are broken after 8010862.
jiangli
parents: 15943
diff changeset
   255
      if (HAS_PENDING_EXCEPTION)
28fab19f2ccd 8013067: Zero builds are broken after 8010862.
jiangli
parents: 15943
diff changeset
   256
        goto unwind_and_return;
28fab19f2ccd 8013067: Zero builds are broken after 8010862.
jiangli
parents: 15943
diff changeset
   257
    }
28fab19f2ccd 8013067: Zero builds are broken after 8010862.
jiangli
parents: 15943
diff changeset
   258
    InvocationCounter *counter = mcs->invocation_counter();
4448
d6ec2737186c 6896043: first round of zero fixes
twisti
parents: 4013
diff changeset
   259
    counter->increment();
22836
e7e511228518 8024468: PPC64 (part 201): cppInterpreter: implement bytecode profiling
goetz
parents: 19336
diff changeset
   260
    if (counter->reached_InvocationLimit(mcs->backedge_counter())) {
4448
d6ec2737186c 6896043: first round of zero fixes
twisti
parents: 4013
diff changeset
   261
      CALL_VM_NOCHECK(
d6ec2737186c 6896043: first round of zero fixes
twisti
parents: 4013
diff changeset
   262
        InterpreterRuntime::frequency_counter_overflow(thread, NULL));
d6ec2737186c 6896043: first round of zero fixes
twisti
parents: 4013
diff changeset
   263
      if (HAS_PENDING_EXCEPTION)
d6ec2737186c 6896043: first round of zero fixes
twisti
parents: 4013
diff changeset
   264
        goto unwind_and_return;
d6ec2737186c 6896043: first round of zero fixes
twisti
parents: 4013
diff changeset
   265
    }
d6ec2737186c 6896043: first round of zero fixes
twisti
parents: 4013
diff changeset
   266
  }
d6ec2737186c 6896043: first round of zero fixes
twisti
parents: 4013
diff changeset
   267
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   268
  // Lock if necessary
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   269
  BasicObjectLock *monitor;
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   270
  monitor = NULL;
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   271
  if (method->is_synchronized()) {
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   272
    monitor = (BasicObjectLock*) istate->stack_base();
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   273
    oop lockee = monitor->obj();
57777
90ead0febf56 8229258: Rework markOop and markOopDesc into a simpler mark word value carrier
stefank
parents: 54523
diff changeset
   274
    markWord disp = lockee->mark().set_unlocked();
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   275
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   276
    monitor->lock()->set_displaced_header(disp);
57777
90ead0febf56 8229258: Rework markOop and markOopDesc into a simpler mark word value carrier
stefank
parents: 54523
diff changeset
   277
    if (lockee->cas_set_mark(markWord::from_pointer(monitor), disp) != disp) {
90ead0febf56 8229258: Rework markOop and markOopDesc into a simpler mark word value carrier
stefank
parents: 54523
diff changeset
   278
      if (thread->is_lock_owned((address) disp.clear_lock_bits().to_pointer())) {
90ead0febf56 8229258: Rework markOop and markOopDesc into a simpler mark word value carrier
stefank
parents: 54523
diff changeset
   279
        monitor->lock()->set_displaced_header(markWord::from_pointer(NULL));
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   280
      }
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   281
      else {
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   282
        CALL_VM_NOCHECK(InterpreterRuntime::monitorenter(thread, monitor));
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   283
        if (HAS_PENDING_EXCEPTION)
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   284
          goto unwind_and_return;
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   285
      }
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   286
    }
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   287
  }
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   288
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   289
  // Get the signature handler
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   290
  InterpreterRuntime::SignatureHandler *handler; {
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   291
    address handlerAddr = method->signature_handler();
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   292
    if (handlerAddr == NULL) {
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   293
      CALL_VM_NOCHECK(InterpreterRuntime::prepare_native_call(thread, method));
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   294
      if (HAS_PENDING_EXCEPTION)
4568
d18b14983811 6908267: Zero fails to unlock synchronized native methods on exception
never
parents: 4448
diff changeset
   295
        goto unlock_unwind_and_return;
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   296
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   297
      handlerAddr = method->signature_handler();
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   298
      assert(handlerAddr != NULL, "eh?");
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   299
    }
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   300
    if (handlerAddr == (address) InterpreterRuntime::slow_signature_handler) {
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   301
      CALL_VM_NOCHECK(handlerAddr =
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   302
        InterpreterRuntime::slow_signature_handler(thread, method, NULL,NULL));
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   303
      if (HAS_PENDING_EXCEPTION)
4568
d18b14983811 6908267: Zero fails to unlock synchronized native methods on exception
never
parents: 4448
diff changeset
   304
        goto unlock_unwind_and_return;
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   305
    }
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   306
    handler = \
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   307
      InterpreterRuntime::SignatureHandler::from_handlerAddr(handlerAddr);
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   308
  }
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   309
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   310
  // Get the native function entry point
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   311
  address function;
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   312
  function = method->native_function();
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   313
  assert(function != NULL, "should be set if signature handler is");
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   314
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   315
  // Build the argument list
5335
4319cb12ddfe 6941224: Improved stack overflow handling for Zero
twisti
parents: 5229
diff changeset
   316
  stack->overflow_check(handler->argument_count() * 2, THREAD);
4319cb12ddfe 6941224: Improved stack overflow handling for Zero
twisti
parents: 5229
diff changeset
   317
  if (HAS_PENDING_EXCEPTION)
4319cb12ddfe 6941224: Improved stack overflow handling for Zero
twisti
parents: 5229
diff changeset
   318
    goto unlock_unwind_and_return;
4319cb12ddfe 6941224: Improved stack overflow handling for Zero
twisti
parents: 5229
diff changeset
   319
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   320
  void **arguments;
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   321
  void *mirror; {
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   322
    arguments =
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   323
      (void **) stack->alloc(handler->argument_count() * sizeof(void **));
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   324
    void **dst = arguments;
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   325
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   326
    void *env = thread->jni_environment();
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   327
    *(dst++) = &env;
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   328
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   329
    if (method->is_static()) {
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   330
      istate->set_oop_temp(
8725
8c1e3dd5fe1b 7017732: move static fields into Class to prepare for perm gen removal
never
parents: 7397
diff changeset
   331
        method->constants()->pool_holder()->java_mirror());
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   332
      mirror = istate->oop_temp_addr();
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   333
      *(dst++) = &mirror;
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   334
    }
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   335
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   336
    intptr_t *src = locals;
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   337
    for (int i = dst - arguments; i < handler->argument_count(); i++) {
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   338
      ffi_type *type = handler->argument_type(i);
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   339
      if (type == &ffi_type_pointer) {
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   340
        if (*src) {
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   341
          stack->push((intptr_t) src);
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   342
          *(dst++) = stack->sp();
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   343
        }
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   344
        else {
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   345
          *(dst++) = src;
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   346
        }
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   347
        src--;
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   348
      }
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   349
      else if (type->size == 4) {
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   350
        *(dst++) = src--;
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   351
      }
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   352
      else if (type->size == 8) {
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   353
        src--;
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   354
        *(dst++) = src--;
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   355
      }
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   356
      else {
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   357
        ShouldNotReachHere();
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   358
      }
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   359
    }
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   360
  }
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   361
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   362
  // Set up the Java frame anchor
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   363
  thread->set_last_Java_frame();
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   364
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   365
  // Change the thread state to _thread_in_native
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   366
  ThreadStateTransition::transition_from_java(thread, _thread_in_native);
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   367
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   368
  // Make the call
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   369
  intptr_t result[4 - LogBytesPerWord];
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   370
  ffi_call(handler->cif(), (void (*)()) function, result, arguments);
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   371
54498
4eefc9f3313c 8222300: Zero build broken after JDK-8222231
aoqi
parents: 53582
diff changeset
   372
  // Change the thread state back to _thread_in_Java and ensure it
4eefc9f3313c 8222300: Zero build broken after JDK-8222231
aoqi
parents: 53582
diff changeset
   373
  // is seen by the GC thread.
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   374
  // ThreadStateTransition::transition_from_native() cannot be used
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   375
  // here because it does not check for asynchronous exceptions.
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   376
  // We have to manage the transition ourself.
54498
4eefc9f3313c 8222300: Zero build broken after JDK-8222231
aoqi
parents: 53582
diff changeset
   377
  thread->set_thread_state_fence(_thread_in_native_trans);
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   378
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   379
  // Handle safepoint operations, pending suspend requests,
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   380
  // and pending asynchronous exceptions.
52450
2790da836dc3 8211403: Rename SafepointMechanism::poll(...)
rehn
parents: 50429
diff changeset
   381
  if (SafepointMechanism::should_block(thread) ||
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   382
      thread->has_special_condition_for_native_trans()) {
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   383
    JavaThread::check_special_condition_for_native_trans(thread);
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   384
    CHECK_UNHANDLED_OOPS_ONLY(thread->clear_unhandled_oops());
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   385
  }
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   386
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   387
  // Finally we can change the thread state to _thread_in_Java.
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   388
  thread->set_thread_state(_thread_in_Java);
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   389
  fixup_after_potential_safepoint();
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   390
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   391
  // Clear the frame anchor
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   392
  thread->reset_last_Java_frame();
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   393
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   394
  // If the result was an oop then unbox it and store it in
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   395
  // oop_temp where the garbage collector can see it before
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   396
  // we release the handle it might be protected by.
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   397
  if (handler->result_type() == &ffi_type_pointer) {
44406
a46a6c4d1dd9 8176100: [REDO][REDO] G1 Needs pre barrier on dereference of weak JNI handles
mgerdin
parents: 44093
diff changeset
   398
    if (result[0] == 0) {
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   399
      istate->set_oop_temp(NULL);
44406
a46a6c4d1dd9 8176100: [REDO][REDO] G1 Needs pre barrier on dereference of weak JNI handles
mgerdin
parents: 44093
diff changeset
   400
    } else {
a46a6c4d1dd9 8176100: [REDO][REDO] G1 Needs pre barrier on dereference of weak JNI handles
mgerdin
parents: 44093
diff changeset
   401
      jobject handle = reinterpret_cast<jobject>(result[0]);
a46a6c4d1dd9 8176100: [REDO][REDO] G1 Needs pre barrier on dereference of weak JNI handles
mgerdin
parents: 44093
diff changeset
   402
      istate->set_oop_temp(JNIHandles::resolve(handle));
a46a6c4d1dd9 8176100: [REDO][REDO] G1 Needs pre barrier on dereference of weak JNI handles
mgerdin
parents: 44093
diff changeset
   403
    }
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   404
  }
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   405
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   406
  // Reset handle block
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   407
  thread->active_handles()->clear();
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   408
4568
d18b14983811 6908267: Zero fails to unlock synchronized native methods on exception
never
parents: 4448
diff changeset
   409
 unlock_unwind_and_return:
d18b14983811 6908267: Zero fails to unlock synchronized native methods on exception
never
parents: 4448
diff changeset
   410
d18b14983811 6908267: Zero fails to unlock synchronized native methods on exception
never
parents: 4448
diff changeset
   411
  // Unlock if necessary
d18b14983811 6908267: Zero fails to unlock synchronized native methods on exception
never
parents: 4448
diff changeset
   412
  if (monitor) {
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   413
    BasicLock *lock = monitor->lock();
57777
90ead0febf56 8229258: Rework markOop and markOopDesc into a simpler mark word value carrier
stefank
parents: 54523
diff changeset
   414
    markWord header = lock->displaced_header();
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   415
    oop rcvr = monitor->obj();
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   416
    monitor->set_obj(NULL);
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   417
57777
90ead0febf56 8229258: Rework markOop and markOopDesc into a simpler mark word value carrier
stefank
parents: 54523
diff changeset
   418
    if (header.to_pointer() != NULL) {
90ead0febf56 8229258: Rework markOop and markOopDesc into a simpler mark word value carrier
stefank
parents: 54523
diff changeset
   419
      markWord old_header = markWord::encode(lock);
47634
6a0c42c40cd1 8188220: Remove Atomic::*_ptr() uses and overloads from hotspot
coleenp
parents: 47216
diff changeset
   420
      if (rcvr->cas_set_mark(header, old_header) != old_header) {
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   421
        monitor->set_obj(rcvr); {
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   422
          HandleMark hm(thread);
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   423
          CALL_VM_NOCHECK(InterpreterRuntime::monitorexit(thread, monitor));
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   424
        }
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   425
      }
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   426
    }
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   427
  }
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   428
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   429
 unwind_and_return:
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   430
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   431
  // Unwind the current activation
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   432
  thread->pop_zero_frame();
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   433
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   434
  // Pop our parameters
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   435
  stack->set_sp(stack->sp() + method->size_of_parameters());
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   436
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   437
  // Push our result
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   438
  if (!HAS_PENDING_EXCEPTION) {
37481
95af21ea8eb0 8146518: Zero interpreter broken with better byte behaviours
coleenp
parents: 37480
diff changeset
   439
    BasicType type = method->result_type();
4897
d5dd3852bf8d 6926048: Improve Zero performance
kvn
parents: 4568
diff changeset
   440
    stack->set_sp(stack->sp() - type2size[type]);
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   441
4897
d5dd3852bf8d 6926048: Improve Zero performance
kvn
parents: 4568
diff changeset
   442
    switch (type) {
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   443
    case T_VOID:
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   444
      break;
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   445
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   446
    case T_BOOLEAN:
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   447
#ifndef VM_LITTLE_ENDIAN
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   448
      result[0] <<= (BitsPerWord - BitsPerByte);
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   449
#endif
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   450
      SET_LOCALS_INT(*(jboolean *) result != 0, 0);
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   451
      break;
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   452
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   453
    case T_CHAR:
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   454
#ifndef VM_LITTLE_ENDIAN
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   455
      result[0] <<= (BitsPerWord - BitsPerShort);
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   456
#endif
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   457
      SET_LOCALS_INT(*(jchar *) result, 0);
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   458
      break;
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   459
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   460
    case T_BYTE:
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   461
#ifndef VM_LITTLE_ENDIAN
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   462
      result[0] <<= (BitsPerWord - BitsPerByte);
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   463
#endif
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   464
      SET_LOCALS_INT(*(jbyte *) result, 0);
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   465
      break;
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   466
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   467
    case T_SHORT:
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   468
#ifndef VM_LITTLE_ENDIAN
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   469
      result[0] <<= (BitsPerWord - BitsPerShort);
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   470
#endif
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   471
      SET_LOCALS_INT(*(jshort *) result, 0);
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   472
      break;
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   473
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   474
    case T_INT:
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   475
#ifndef VM_LITTLE_ENDIAN
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   476
      result[0] <<= (BitsPerWord - BitsPerInt);
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   477
#endif
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   478
      SET_LOCALS_INT(*(jint *) result, 0);
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   479
      break;
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   480
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   481
    case T_LONG:
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   482
      SET_LOCALS_LONG(*(jlong *) result, 0);
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   483
      break;
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   484
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   485
    case T_FLOAT:
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   486
      SET_LOCALS_FLOAT(*(jfloat *) result, 0);
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   487
      break;
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   488
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   489
    case T_DOUBLE:
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   490
      SET_LOCALS_DOUBLE(*(jdouble *) result, 0);
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   491
      break;
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   492
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   493
    case T_OBJECT:
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   494
    case T_ARRAY:
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   495
      SET_LOCALS_OBJECT(istate->oop_temp(), 0);
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   496
      break;
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   497
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   498
    default:
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   499
      ShouldNotReachHere();
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   500
    }
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   501
  }
5427
08c6b2b940f7 6951784: Zero deoptimizer changes
twisti
parents: 5418
diff changeset
   502
08c6b2b940f7 6951784: Zero deoptimizer changes
twisti
parents: 5418
diff changeset
   503
  // No deoptimized frames on the stack
08c6b2b940f7 6951784: Zero deoptimizer changes
twisti
parents: 5418
diff changeset
   504
  return 0;
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   505
}
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   506
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13391
diff changeset
   507
int CppInterpreter::accessor_entry(Method* method, intptr_t UNUSED, TRAPS) {
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   508
  JavaThread *thread = (JavaThread *) THREAD;
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   509
  ZeroStack *stack = thread->zero_stack();
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   510
  intptr_t *locals = stack->sp();
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   511
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   512
  // Drop into the slow path if we need a safepoint check
52450
2790da836dc3 8211403: Rename SafepointMechanism::poll(...)
rehn
parents: 50429
diff changeset
   513
  if (SafepointMechanism::should_block(THREAD)) {
5427
08c6b2b940f7 6951784: Zero deoptimizer changes
twisti
parents: 5418
diff changeset
   514
    return normal_entry(method, 0, THREAD);
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   515
  }
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   516
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   517
  // Load the object pointer and drop into the slow path
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   518
  // if we have a NullPointerException
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   519
  oop object = LOCALS_OBJECT(0);
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   520
  if (object == NULL) {
5427
08c6b2b940f7 6951784: Zero deoptimizer changes
twisti
parents: 5418
diff changeset
   521
    return normal_entry(method, 0, THREAD);
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   522
  }
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   523
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   524
  // Read the field index from the bytecode, which looks like this:
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   525
  //  0:  aload_0
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   526
  //  1:  getfield
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   527
  //  2:    index
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   528
  //  3:    index
34169
b0b7187852b7 8140650: Method::is_accessor should cover getters and setters for all types
shade
parents: 33070
diff changeset
   529
  //  4:  ireturn/areturn/freturn/lreturn/dreturn
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   530
  // NB this is not raw bytecode: index is in machine order
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   531
  u1 *code = method->code_base();
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   532
  assert(code[0] == Bytecodes::_aload_0 &&
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   533
         code[1] == Bytecodes::_getfield &&
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   534
         (code[4] == Bytecodes::_ireturn ||
34169
b0b7187852b7 8140650: Method::is_accessor should cover getters and setters for all types
shade
parents: 33070
diff changeset
   535
          code[4] == Bytecodes::_freturn ||
b0b7187852b7 8140650: Method::is_accessor should cover getters and setters for all types
shade
parents: 33070
diff changeset
   536
          code[4] == Bytecodes::_lreturn ||
b0b7187852b7 8140650: Method::is_accessor should cover getters and setters for all types
shade
parents: 33070
diff changeset
   537
          code[4] == Bytecodes::_dreturn ||
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   538
          code[4] == Bytecodes::_areturn), "should do");
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   539
  u2 index = Bytes::get_native_u2(&code[2]);
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   540
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   541
  // Get the entry from the constant pool cache, and drop into
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   542
  // the slow path if it has not been resolved
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13391
diff changeset
   543
  ConstantPoolCache* cache = method->constants()->cache();
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   544
  ConstantPoolCacheEntry* entry = cache->entry_at(index);
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   545
  if (!entry->is_resolved(Bytecodes::_getfield)) {
5427
08c6b2b940f7 6951784: Zero deoptimizer changes
twisti
parents: 5418
diff changeset
   546
    return normal_entry(method, 0, THREAD);
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   547
  }
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   548
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   549
  // Get the result and push it onto the stack
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   550
  switch (entry->flag_state()) {
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   551
  case ltos:
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   552
  case dtos:
5427
08c6b2b940f7 6951784: Zero deoptimizer changes
twisti
parents: 5418
diff changeset
   553
    stack->overflow_check(1, CHECK_0);
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   554
    stack->alloc(wordSize);
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   555
    break;
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   556
  }
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   557
  if (entry->is_volatile()) {
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   558
    switch (entry->flag_state()) {
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   559
    case ctos:
14294
130e947dfbe6 8000780: make Zero build and run with JDK8
twisti
parents: 13728
diff changeset
   560
      SET_LOCALS_INT(object->char_field_acquire(entry->f2_as_index()), 0);
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   561
      break;
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   562
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   563
    case btos:
37480
291ee208fb72 8132051: Better byte behavior
coleenp
parents: 36181
diff changeset
   564
    case ztos:
14294
130e947dfbe6 8000780: make Zero build and run with JDK8
twisti
parents: 13728
diff changeset
   565
      SET_LOCALS_INT(object->byte_field_acquire(entry->f2_as_index()), 0);
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   566
      break;
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   567
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   568
    case stos:
14294
130e947dfbe6 8000780: make Zero build and run with JDK8
twisti
parents: 13728
diff changeset
   569
      SET_LOCALS_INT(object->short_field_acquire(entry->f2_as_index()), 0);
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   570
      break;
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   571
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   572
    case itos:
14294
130e947dfbe6 8000780: make Zero build and run with JDK8
twisti
parents: 13728
diff changeset
   573
      SET_LOCALS_INT(object->int_field_acquire(entry->f2_as_index()), 0);
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   574
      break;
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   575
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   576
    case ltos:
14294
130e947dfbe6 8000780: make Zero build and run with JDK8
twisti
parents: 13728
diff changeset
   577
      SET_LOCALS_LONG(object->long_field_acquire(entry->f2_as_index()), 0);
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   578
      break;
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   579
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   580
    case ftos:
14294
130e947dfbe6 8000780: make Zero build and run with JDK8
twisti
parents: 13728
diff changeset
   581
      SET_LOCALS_FLOAT(object->float_field_acquire(entry->f2_as_index()), 0);
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   582
      break;
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   583
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   584
    case dtos:
14294
130e947dfbe6 8000780: make Zero build and run with JDK8
twisti
parents: 13728
diff changeset
   585
      SET_LOCALS_DOUBLE(object->double_field_acquire(entry->f2_as_index()), 0);
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   586
      break;
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   587
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   588
    case atos:
14294
130e947dfbe6 8000780: make Zero build and run with JDK8
twisti
parents: 13728
diff changeset
   589
      SET_LOCALS_OBJECT(object->obj_field_acquire(entry->f2_as_index()), 0);
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   590
      break;
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   591
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   592
    default:
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   593
      ShouldNotReachHere();
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   594
    }
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   595
  }
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   596
  else {
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   597
    switch (entry->flag_state()) {
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   598
    case ctos:
14294
130e947dfbe6 8000780: make Zero build and run with JDK8
twisti
parents: 13728
diff changeset
   599
      SET_LOCALS_INT(object->char_field(entry->f2_as_index()), 0);
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   600
      break;
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   601
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   602
    case btos:
37480
291ee208fb72 8132051: Better byte behavior
coleenp
parents: 36181
diff changeset
   603
    case ztos:
14294
130e947dfbe6 8000780: make Zero build and run with JDK8
twisti
parents: 13728
diff changeset
   604
      SET_LOCALS_INT(object->byte_field(entry->f2_as_index()), 0);
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   605
      break;
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   606
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   607
    case stos:
14294
130e947dfbe6 8000780: make Zero build and run with JDK8
twisti
parents: 13728
diff changeset
   608
      SET_LOCALS_INT(object->short_field(entry->f2_as_index()), 0);
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   609
      break;
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   610
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   611
    case itos:
14294
130e947dfbe6 8000780: make Zero build and run with JDK8
twisti
parents: 13728
diff changeset
   612
      SET_LOCALS_INT(object->int_field(entry->f2_as_index()), 0);
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   613
      break;
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   614
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   615
    case ltos:
14294
130e947dfbe6 8000780: make Zero build and run with JDK8
twisti
parents: 13728
diff changeset
   616
      SET_LOCALS_LONG(object->long_field(entry->f2_as_index()), 0);
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   617
      break;
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   618
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   619
    case ftos:
14294
130e947dfbe6 8000780: make Zero build and run with JDK8
twisti
parents: 13728
diff changeset
   620
      SET_LOCALS_FLOAT(object->float_field(entry->f2_as_index()), 0);
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   621
      break;
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   622
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   623
    case dtos:
14294
130e947dfbe6 8000780: make Zero build and run with JDK8
twisti
parents: 13728
diff changeset
   624
      SET_LOCALS_DOUBLE(object->double_field(entry->f2_as_index()), 0);
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   625
      break;
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   626
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   627
    case atos:
14294
130e947dfbe6 8000780: make Zero build and run with JDK8
twisti
parents: 13728
diff changeset
   628
      SET_LOCALS_OBJECT(object->obj_field(entry->f2_as_index()), 0);
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   629
      break;
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   630
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   631
    default:
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   632
      ShouldNotReachHere();
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   633
    }
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   634
  }
5427
08c6b2b940f7 6951784: Zero deoptimizer changes
twisti
parents: 5418
diff changeset
   635
08c6b2b940f7 6951784: Zero deoptimizer changes
twisti
parents: 5418
diff changeset
   636
  // No deoptimized frames on the stack
08c6b2b940f7 6951784: Zero deoptimizer changes
twisti
parents: 5418
diff changeset
   637
  return 0;
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   638
}
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   639
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13391
diff changeset
   640
int CppInterpreter::empty_entry(Method* method, intptr_t UNUSED, TRAPS) {
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   641
  JavaThread *thread = (JavaThread *) THREAD;
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   642
  ZeroStack *stack = thread->zero_stack();
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   643
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   644
  // Drop into the slow path if we need a safepoint check
52450
2790da836dc3 8211403: Rename SafepointMechanism::poll(...)
rehn
parents: 50429
diff changeset
   645
  if (SafepointMechanism::should_block(THREAD)) {
5427
08c6b2b940f7 6951784: Zero deoptimizer changes
twisti
parents: 5418
diff changeset
   646
    return normal_entry(method, 0, THREAD);
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   647
  }
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   648
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   649
  // Pop our parameters
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   650
  stack->set_sp(stack->sp() + method->size_of_parameters());
5427
08c6b2b940f7 6951784: Zero deoptimizer changes
twisti
parents: 5418
diff changeset
   651
08c6b2b940f7 6951784: Zero deoptimizer changes
twisti
parents: 5418
diff changeset
   652
  // No deoptimized frames on the stack
08c6b2b940f7 6951784: Zero deoptimizer changes
twisti
parents: 5418
diff changeset
   653
  return 0;
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   654
}
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   655
9136
94ebba447157 7035870: JSR 292: Zero support
twisti
parents: 8725
diff changeset
   656
// The new slots will be inserted before slot insert_before.
94ebba447157 7035870: JSR 292: Zero support
twisti
parents: 8725
diff changeset
   657
// Slots < insert_before will have the same slot number after the insert.
94ebba447157 7035870: JSR 292: Zero support
twisti
parents: 8725
diff changeset
   658
// Slots >= insert_before will become old_slot + num_slots.
94ebba447157 7035870: JSR 292: Zero support
twisti
parents: 8725
diff changeset
   659
void CppInterpreter::insert_vmslots(int insert_before, int num_slots, TRAPS) {
94ebba447157 7035870: JSR 292: Zero support
twisti
parents: 8725
diff changeset
   660
  JavaThread *thread = (JavaThread *) THREAD;
94ebba447157 7035870: JSR 292: Zero support
twisti
parents: 8725
diff changeset
   661
  ZeroStack *stack = thread->zero_stack();
94ebba447157 7035870: JSR 292: Zero support
twisti
parents: 8725
diff changeset
   662
94ebba447157 7035870: JSR 292: Zero support
twisti
parents: 8725
diff changeset
   663
  // Allocate the space
94ebba447157 7035870: JSR 292: Zero support
twisti
parents: 8725
diff changeset
   664
  stack->overflow_check(num_slots, CHECK);
94ebba447157 7035870: JSR 292: Zero support
twisti
parents: 8725
diff changeset
   665
  stack->alloc(num_slots * wordSize);
94ebba447157 7035870: JSR 292: Zero support
twisti
parents: 8725
diff changeset
   666
  intptr_t *vmslots = stack->sp();
94ebba447157 7035870: JSR 292: Zero support
twisti
parents: 8725
diff changeset
   667
94ebba447157 7035870: JSR 292: Zero support
twisti
parents: 8725
diff changeset
   668
  // Shuffle everything up
94ebba447157 7035870: JSR 292: Zero support
twisti
parents: 8725
diff changeset
   669
  for (int i = 0; i < insert_before; i++)
94ebba447157 7035870: JSR 292: Zero support
twisti
parents: 8725
diff changeset
   670
    SET_VMSLOTS_SLOT(VMSLOTS_SLOT(i + num_slots), i);
94ebba447157 7035870: JSR 292: Zero support
twisti
parents: 8725
diff changeset
   671
}
94ebba447157 7035870: JSR 292: Zero support
twisti
parents: 8725
diff changeset
   672
94ebba447157 7035870: JSR 292: Zero support
twisti
parents: 8725
diff changeset
   673
void CppInterpreter::remove_vmslots(int first_slot, int num_slots, TRAPS) {
94ebba447157 7035870: JSR 292: Zero support
twisti
parents: 8725
diff changeset
   674
  JavaThread *thread = (JavaThread *) THREAD;
94ebba447157 7035870: JSR 292: Zero support
twisti
parents: 8725
diff changeset
   675
  ZeroStack *stack = thread->zero_stack();
94ebba447157 7035870: JSR 292: Zero support
twisti
parents: 8725
diff changeset
   676
  intptr_t *vmslots = stack->sp();
94ebba447157 7035870: JSR 292: Zero support
twisti
parents: 8725
diff changeset
   677
94ebba447157 7035870: JSR 292: Zero support
twisti
parents: 8725
diff changeset
   678
  // Move everything down
94ebba447157 7035870: JSR 292: Zero support
twisti
parents: 8725
diff changeset
   679
  for (int i = first_slot - 1; i >= 0; i--)
94ebba447157 7035870: JSR 292: Zero support
twisti
parents: 8725
diff changeset
   680
    SET_VMSLOTS_SLOT(VMSLOTS_SLOT(i), i + num_slots);
94ebba447157 7035870: JSR 292: Zero support
twisti
parents: 8725
diff changeset
   681
94ebba447157 7035870: JSR 292: Zero support
twisti
parents: 8725
diff changeset
   682
  // Deallocate the space
94ebba447157 7035870: JSR 292: Zero support
twisti
parents: 8725
diff changeset
   683
  stack->set_sp(stack->sp() + num_slots);
94ebba447157 7035870: JSR 292: Zero support
twisti
parents: 8725
diff changeset
   684
}
94ebba447157 7035870: JSR 292: Zero support
twisti
parents: 8725
diff changeset
   685
94ebba447157 7035870: JSR 292: Zero support
twisti
parents: 8725
diff changeset
   686
BasicType CppInterpreter::result_type_of_handle(oop method_handle) {
94ebba447157 7035870: JSR 292: Zero support
twisti
parents: 8725
diff changeset
   687
  oop method_type = java_lang_invoke_MethodHandle::type(method_handle);
94ebba447157 7035870: JSR 292: Zero support
twisti
parents: 8725
diff changeset
   688
  oop return_type = java_lang_invoke_MethodType::rtype(method_type);
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13391
diff changeset
   689
  return java_lang_Class::as_BasicType(return_type, (Klass* *) NULL);
9136
94ebba447157 7035870: JSR 292: Zero support
twisti
parents: 8725
diff changeset
   690
}
94ebba447157 7035870: JSR 292: Zero support
twisti
parents: 8725
diff changeset
   691
94ebba447157 7035870: JSR 292: Zero support
twisti
parents: 8725
diff changeset
   692
intptr_t* CppInterpreter::calculate_unwind_sp(ZeroStack* stack,
94ebba447157 7035870: JSR 292: Zero support
twisti
parents: 8725
diff changeset
   693
                                              oop method_handle) {
94ebba447157 7035870: JSR 292: Zero support
twisti
parents: 8725
diff changeset
   694
  oop method_type = java_lang_invoke_MethodHandle::type(method_handle);
13391
30245956af37 7023639: JSR 292 method handle invocation needs a fast path for compiled code
twisti
parents: 12726
diff changeset
   695
  int argument_slots = java_lang_invoke_MethodType::ptype_slot_count(method_type);
9136
94ebba447157 7035870: JSR 292: Zero support
twisti
parents: 8725
diff changeset
   696
94ebba447157 7035870: JSR 292: Zero support
twisti
parents: 8725
diff changeset
   697
  return stack->sp() + argument_slots;
94ebba447157 7035870: JSR 292: Zero support
twisti
parents: 8725
diff changeset
   698
}
94ebba447157 7035870: JSR 292: Zero support
twisti
parents: 8725
diff changeset
   699
54523
5df03f58d25b 8222297: IRT_ENTRY/IRT_LEAF etc are the same as JRT
coleenp
parents: 54498
diff changeset
   700
JRT_ENTRY(void, CppInterpreter::throw_exception(JavaThread* thread,
9136
94ebba447157 7035870: JSR 292: Zero support
twisti
parents: 8725
diff changeset
   701
                                                Symbol*     name,
94ebba447157 7035870: JSR 292: Zero support
twisti
parents: 8725
diff changeset
   702
                                                char*       message))
94ebba447157 7035870: JSR 292: Zero support
twisti
parents: 8725
diff changeset
   703
  THROW_MSG(name, message);
54523
5df03f58d25b 8222297: IRT_ENTRY/IRT_LEAF etc are the same as JRT
coleenp
parents: 54498
diff changeset
   704
JRT_END
9136
94ebba447157 7035870: JSR 292: Zero support
twisti
parents: 8725
diff changeset
   705
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13391
diff changeset
   706
InterpreterFrame *InterpreterFrame::build(Method* const method, TRAPS) {
5335
4319cb12ddfe 6941224: Improved stack overflow handling for Zero
twisti
parents: 5229
diff changeset
   707
  JavaThread *thread = (JavaThread *) THREAD;
4319cb12ddfe 6941224: Improved stack overflow handling for Zero
twisti
parents: 5229
diff changeset
   708
  ZeroStack *stack = thread->zero_stack();
4319cb12ddfe 6941224: Improved stack overflow handling for Zero
twisti
parents: 5229
diff changeset
   709
4319cb12ddfe 6941224: Improved stack overflow handling for Zero
twisti
parents: 5229
diff changeset
   710
  // Calculate the size of the frame we'll build, including
4319cb12ddfe 6941224: Improved stack overflow handling for Zero
twisti
parents: 5229
diff changeset
   711
  // any adjustments to the caller's frame that we'll make.
4319cb12ddfe 6941224: Improved stack overflow handling for Zero
twisti
parents: 5229
diff changeset
   712
  int extra_locals  = 0;
4319cb12ddfe 6941224: Improved stack overflow handling for Zero
twisti
parents: 5229
diff changeset
   713
  int monitor_words = 0;
4319cb12ddfe 6941224: Improved stack overflow handling for Zero
twisti
parents: 5229
diff changeset
   714
  int stack_words   = 0;
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   715
5335
4319cb12ddfe 6941224: Improved stack overflow handling for Zero
twisti
parents: 5229
diff changeset
   716
  if (!method->is_native()) {
4319cb12ddfe 6941224: Improved stack overflow handling for Zero
twisti
parents: 5229
diff changeset
   717
    extra_locals = method->max_locals() - method->size_of_parameters();
4319cb12ddfe 6941224: Improved stack overflow handling for Zero
twisti
parents: 5229
diff changeset
   718
    stack_words  = method->max_stack();
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   719
  }
5335
4319cb12ddfe 6941224: Improved stack overflow handling for Zero
twisti
parents: 5229
diff changeset
   720
  if (method->is_synchronized()) {
4319cb12ddfe 6941224: Improved stack overflow handling for Zero
twisti
parents: 5229
diff changeset
   721
    monitor_words = frame::interpreter_frame_monitor_size();
4319cb12ddfe 6941224: Improved stack overflow handling for Zero
twisti
parents: 5229
diff changeset
   722
  }
4319cb12ddfe 6941224: Improved stack overflow handling for Zero
twisti
parents: 5229
diff changeset
   723
  stack->overflow_check(
4319cb12ddfe 6941224: Improved stack overflow handling for Zero
twisti
parents: 5229
diff changeset
   724
    extra_locals + header_words + monitor_words + stack_words, CHECK_NULL);
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   725
5335
4319cb12ddfe 6941224: Improved stack overflow handling for Zero
twisti
parents: 5229
diff changeset
   726
  // Adjust the caller's stack frame to accomodate any additional
4319cb12ddfe 6941224: Improved stack overflow handling for Zero
twisti
parents: 5229
diff changeset
   727
  // local variables we have contiguously with our parameters.
4319cb12ddfe 6941224: Improved stack overflow handling for Zero
twisti
parents: 5229
diff changeset
   728
  for (int i = 0; i < extra_locals; i++)
4319cb12ddfe 6941224: Improved stack overflow handling for Zero
twisti
parents: 5229
diff changeset
   729
    stack->push(0);
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   730
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   731
  intptr_t *locals;
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   732
  if (method->is_native())
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   733
    locals = stack->sp() + (method->size_of_parameters() - 1);
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   734
  else
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   735
    locals = stack->sp() + (method->max_locals() - 1);
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   736
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   737
  stack->push(0); // next_frame, filled in later
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   738
  intptr_t *fp = stack->sp();
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   739
  assert(fp - stack->sp() == next_frame_off, "should be");
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   740
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   741
  stack->push(INTERPRETER_FRAME);
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   742
  assert(fp - stack->sp() == frame_type_off, "should be");
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   743
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   744
  interpreterState istate =
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   745
    (interpreterState) stack->alloc(sizeof(BytecodeInterpreter));
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   746
  assert(fp - stack->sp() == istate_off, "should be");
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   747
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   748
  istate->set_locals(locals);
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   749
  istate->set_method(method);
38074
8475fdc6dcc3 8154580: Save mirror in interpreter frame to enable cleanups of CLDClosure
coleenp
parents: 38063
diff changeset
   750
  istate->set_mirror(method->method_holder()->java_mirror());
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   751
  istate->set_self_link(istate);
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   752
  istate->set_prev_link(NULL);
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   753
  istate->set_thread(thread);
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   754
  istate->set_bcp(method->is_native() ? NULL : method->code_base());
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   755
  istate->set_constants(method->constants()->cache());
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   756
  istate->set_msg(BytecodeInterpreter::method_entry);
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   757
  istate->set_oop_temp(NULL);
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   758
  istate->set_mdx(NULL);
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   759
  istate->set_callee(NULL);
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   760
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   761
  istate->set_monitor_base((BasicObjectLock *) stack->sp());
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   762
  if (method->is_synchronized()) {
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   763
    BasicObjectLock *monitor =
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   764
      (BasicObjectLock *) stack->alloc(monitor_words * wordSize);
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   765
    oop object;
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   766
    if (method->is_static())
8725
8c1e3dd5fe1b 7017732: move static fields into Class to prepare for perm gen removal
never
parents: 7397
diff changeset
   767
      object = method->constants()->pool_holder()->java_mirror();
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   768
    else
26142
038e0f01b4a9 8055231: ZERO variant build is broken
coleenp
parents: 25950
diff changeset
   769
      object = (oop) (void*)locals[0];
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   770
    monitor->set_obj(object);
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   771
  }
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   772
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   773
  istate->set_stack_base(stack->sp());
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   774
  istate->set_stack(stack->sp() - 1);
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   775
  if (stack_words)
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   776
    stack->alloc(stack_words * wordSize);
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   777
  istate->set_stack_limit(stack->sp() - 1);
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   778
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   779
  return (InterpreterFrame *) fp;
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   780
}
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   781
5335
4319cb12ddfe 6941224: Improved stack overflow handling for Zero
twisti
parents: 5229
diff changeset
   782
InterpreterFrame *InterpreterFrame::build(int size, TRAPS) {
4319cb12ddfe 6941224: Improved stack overflow handling for Zero
twisti
parents: 5229
diff changeset
   783
  ZeroStack *stack = ((JavaThread *) THREAD)->zero_stack();
4319cb12ddfe 6941224: Improved stack overflow handling for Zero
twisti
parents: 5229
diff changeset
   784
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   785
  int size_in_words = size >> LogBytesPerWord;
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   786
  assert(size_in_words * wordSize == size, "unaligned");
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   787
  assert(size_in_words >= header_words, "too small");
5335
4319cb12ddfe 6941224: Improved stack overflow handling for Zero
twisti
parents: 5229
diff changeset
   788
  stack->overflow_check(size_in_words, CHECK_NULL);
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   789
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   790
  stack->push(0); // next_frame, filled in later
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   791
  intptr_t *fp = stack->sp();
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   792
  assert(fp - stack->sp() == next_frame_off, "should be");
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   793
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   794
  stack->push(INTERPRETER_FRAME);
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   795
  assert(fp - stack->sp() == frame_type_off, "should be");
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   796
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   797
  interpreterState istate =
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   798
    (interpreterState) stack->alloc(sizeof(BytecodeInterpreter));
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   799
  assert(fp - stack->sp() == istate_off, "should be");
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   800
  istate->set_self_link(NULL); // mark invalid
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   801
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   802
  stack->alloc((size_in_words - header_words) * wordSize);
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   803
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   804
  return (InterpreterFrame *) fp;
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   805
}
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   806
21198
dd647e8d1d72 8026328: Setting a breakpoint on invokedynamic crashes the JVM
twisti
parents: 19336
diff changeset
   807
address CppInterpreter::return_entry(TosState state, int length, Bytecodes::Code code) {
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   808
  ShouldNotCallThis();
19336
ddceb0657500 8022956: Clang: enable return type warnings on BSD
twisti
parents: 17314
diff changeset
   809
  return NULL;
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   810
}
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   811
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   812
address CppInterpreter::deopt_entry(TosState state, int length) {
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   813
  return NULL;
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   814
}
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   815
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   816
// Helper for figuring out if frames are interpreter frames
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   817
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   818
bool CppInterpreter::contains(address pc) {
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   819
  return false; // make frame::print_value_on work
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   820
}
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents:
diff changeset
   821
#endif // CC_INTERP