src/hotspot/share/c1/c1_LIRAssembler.cpp
author mdoerr
Tue, 05 Nov 2019 11:53:46 +0100
changeset 58932 8623f75be895
parent 55105 9ad765641e8f
permissions -rw-r--r--
8233081: C1: PatchingStub for field access copies too much Reviewed-by: thartmann, dlong
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
     1
/*
50102
454fa295105c 8202976: Add C1 lea patching support for x86
pliden
parents: 49754
diff changeset
     2
 * Copyright (c) 2000, 2018, Oracle and/or its affiliates. All rights reserved.
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
489c9b5090e2 Initial load
duke
parents:
diff changeset
     4
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
489c9b5090e2 Initial load
duke
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
489c9b5090e2 Initial load
duke
parents:
diff changeset
     7
 * published by the Free Software Foundation.
489c9b5090e2 Initial load
duke
parents:
diff changeset
     8
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
     9
 * This code is distributed in the hope that it will be useful, but WITHOUT
489c9b5090e2 Initial load
duke
parents:
diff changeset
    10
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
489c9b5090e2 Initial load
duke
parents:
diff changeset
    11
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
489c9b5090e2 Initial load
duke
parents:
diff changeset
    12
 * version 2 for more details (a copy is included in the LICENSE file that
489c9b5090e2 Initial load
duke
parents:
diff changeset
    13
 * accompanied this code).
489c9b5090e2 Initial load
duke
parents:
diff changeset
    14
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
    15
 * You should have received a copy of the GNU General Public License version
489c9b5090e2 Initial load
duke
parents:
diff changeset
    16
 * 2 along with this work; if not, write to the Free Software Foundation,
489c9b5090e2 Initial load
duke
parents:
diff changeset
    17
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    18
 *
5547
f4b087cbb361 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 5334
diff changeset
    19
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
f4b087cbb361 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 5334
diff changeset
    20
 * or visit www.oracle.com if you need additional information or have any
f4b087cbb361 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 5334
diff changeset
    21
 * questions.
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    22
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
    23
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
    24
7397
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6745
diff changeset
    25
#include "precompiled.hpp"
50380
bec342339138 8204195: Clean up macroAssembler.inline.hpp and other inline.hpp files included in .hpp files
coleenp
parents: 50102
diff changeset
    26
#include "asm/assembler.inline.hpp"
7397
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6745
diff changeset
    27
#include "c1/c1_Compilation.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6745
diff changeset
    28
#include "c1/c1_Instruction.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6745
diff changeset
    29
#include "c1/c1_InstructionPrinter.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6745
diff changeset
    30
#include "c1/c1_LIRAssembler.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6745
diff changeset
    31
#include "c1/c1_MacroAssembler.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6745
diff changeset
    32
#include "c1/c1_ValueStack.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6745
diff changeset
    33
#include "ci/ciInstance.hpp"
49754
ee93c1087584 8201362: Remove CollectedHeap::barrier_set()
pliden
parents: 49449
diff changeset
    34
#include "gc/shared/barrierSet.hpp"
25949
34557722059b 6424123: JVM crashes on failed 'strdup' call
zgu
parents: 25715
diff changeset
    35
#include "runtime/os.hpp"
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    36
489c9b5090e2 Initial load
duke
parents:
diff changeset
    37
void LIR_Assembler::patching_epilog(PatchingStub* patch, LIR_PatchCode patch_code, Register obj, CodeEmitInfo* info) {
32203
01a3716ed455 8131682: C1 should use multibyte nops everywhere
shade
parents: 32082
diff changeset
    38
  // We must have enough patching space so that call can be inserted.
01a3716ed455 8131682: C1 should use multibyte nops everywhere
shade
parents: 32082
diff changeset
    39
  // We cannot use fat nops here, since the concurrent code rewrite may transiently
01a3716ed455 8131682: C1 should use multibyte nops everywhere
shade
parents: 32082
diff changeset
    40
  // create the illegal instruction sequence.
34500
3c82f7ac03e6 8138896: C1: NativeGeneralJump is mixed up with NativeCall in C1 patching code
mdoerr
parents: 34220
diff changeset
    41
  while ((intx) _masm->pc() - (intx) patch->pc_start() < NativeGeneralJump::instruction_size) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    42
    _masm->nop();
489c9b5090e2 Initial load
duke
parents:
diff changeset
    43
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
    44
  patch->install(_masm, patch_code, obj, info);
24669
14439491d407 8031475: Missing oopmap in patching stubs
neliasso
parents: 24018
diff changeset
    45
  append_code_stub(patch);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    46
489c9b5090e2 Initial load
duke
parents:
diff changeset
    47
#ifdef ASSERT
6745
a34ef8968a84 6986046: C1 valuestack cleanup
roland
parents: 6453
diff changeset
    48
  Bytecodes::Code code = info->scope()->method()->java_code_at_bci(info->stack()->bci());
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    49
  if (patch->id() == PatchingStub::access_field_id) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    50
    switch (code) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    51
      case Bytecodes::_putstatic:
489c9b5090e2 Initial load
duke
parents:
diff changeset
    52
      case Bytecodes::_getstatic:
489c9b5090e2 Initial load
duke
parents:
diff changeset
    53
      case Bytecodes::_putfield:
489c9b5090e2 Initial load
duke
parents:
diff changeset
    54
      case Bytecodes::_getfield:
489c9b5090e2 Initial load
duke
parents:
diff changeset
    55
        break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    56
      default:
489c9b5090e2 Initial load
duke
parents:
diff changeset
    57
        ShouldNotReachHere();
489c9b5090e2 Initial load
duke
parents:
diff changeset
    58
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
    59
  } else if (patch->id() == PatchingStub::load_klass_id) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    60
    switch (code) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    61
      case Bytecodes::_new:
489c9b5090e2 Initial load
duke
parents:
diff changeset
    62
      case Bytecodes::_anewarray:
489c9b5090e2 Initial load
duke
parents:
diff changeset
    63
      case Bytecodes::_multianewarray:
489c9b5090e2 Initial load
duke
parents:
diff changeset
    64
      case Bytecodes::_instanceof:
489c9b5090e2 Initial load
duke
parents:
diff changeset
    65
      case Bytecodes::_checkcast:
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13487
diff changeset
    66
        break;
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13487
diff changeset
    67
      default:
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13487
diff changeset
    68
        ShouldNotReachHere();
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13487
diff changeset
    69
    }
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13487
diff changeset
    70
  } else if (patch->id() == PatchingStub::load_mirror_id) {
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13487
diff changeset
    71
    switch (code) {
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13487
diff changeset
    72
      case Bytecodes::_putstatic:
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13487
diff changeset
    73
      case Bytecodes::_getstatic:
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    74
      case Bytecodes::_ldc:
489c9b5090e2 Initial load
duke
parents:
diff changeset
    75
      case Bytecodes::_ldc_w:
489c9b5090e2 Initial load
duke
parents:
diff changeset
    76
        break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    77
      default:
489c9b5090e2 Initial load
duke
parents:
diff changeset
    78
        ShouldNotReachHere();
489c9b5090e2 Initial load
duke
parents:
diff changeset
    79
    }
19710
2f8ca425504e 7199175: JSR 292: C1 needs patching when invokedynamic/invokehandle call site is not linked
roland
parents: 13886
diff changeset
    80
  } else if (patch->id() == PatchingStub::load_appendix_id) {
2f8ca425504e 7199175: JSR 292: C1 needs patching when invokedynamic/invokehandle call site is not linked
roland
parents: 13886
diff changeset
    81
    Bytecodes::Code bc_raw = info->scope()->method()->raw_code_at_bci(info->stack()->bci());
2f8ca425504e 7199175: JSR 292: C1 needs patching when invokedynamic/invokehandle call site is not linked
roland
parents: 13886
diff changeset
    82
    assert(Bytecodes::has_optional_appendix(bc_raw), "unexpected appendix resolution");
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    83
  } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    84
    ShouldNotReachHere();
489c9b5090e2 Initial load
duke
parents:
diff changeset
    85
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
    86
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
    87
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
    88
19710
2f8ca425504e 7199175: JSR 292: C1 needs patching when invokedynamic/invokehandle call site is not linked
roland
parents: 13886
diff changeset
    89
PatchingStub::PatchID LIR_Assembler::patching_id(CodeEmitInfo* info) {
2f8ca425504e 7199175: JSR 292: C1 needs patching when invokedynamic/invokehandle call site is not linked
roland
parents: 13886
diff changeset
    90
  IRScope* scope = info->scope();
2f8ca425504e 7199175: JSR 292: C1 needs patching when invokedynamic/invokehandle call site is not linked
roland
parents: 13886
diff changeset
    91
  Bytecodes::Code bc_raw = scope->method()->raw_code_at_bci(info->stack()->bci());
2f8ca425504e 7199175: JSR 292: C1 needs patching when invokedynamic/invokehandle call site is not linked
roland
parents: 13886
diff changeset
    92
  if (Bytecodes::has_optional_appendix(bc_raw)) {
2f8ca425504e 7199175: JSR 292: C1 needs patching when invokedynamic/invokehandle call site is not linked
roland
parents: 13886
diff changeset
    93
    return PatchingStub::load_appendix_id;
2f8ca425504e 7199175: JSR 292: C1 needs patching when invokedynamic/invokehandle call site is not linked
roland
parents: 13886
diff changeset
    94
  }
2f8ca425504e 7199175: JSR 292: C1 needs patching when invokedynamic/invokehandle call site is not linked
roland
parents: 13886
diff changeset
    95
  return PatchingStub::load_mirror_id;
2f8ca425504e 7199175: JSR 292: C1 needs patching when invokedynamic/invokehandle call site is not linked
roland
parents: 13886
diff changeset
    96
}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    97
489c9b5090e2 Initial load
duke
parents:
diff changeset
    98
//---------------------------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
    99
489c9b5090e2 Initial load
duke
parents:
diff changeset
   100
489c9b5090e2 Initial load
duke
parents:
diff changeset
   101
LIR_Assembler::LIR_Assembler(Compilation* c):
51333
f6641fcf7b7e 8208670: Compiler changes to allow enabling -Wreorder
tschatzl
parents: 50380
diff changeset
   102
   _masm(c->masm())
49754
ee93c1087584 8201362: Remove CollectedHeap::barrier_set()
pliden
parents: 49449
diff changeset
   103
 , _bs(BarrierSet::barrier_set())
51333
f6641fcf7b7e 8208670: Compiler changes to allow enabling -Wreorder
tschatzl
parents: 50380
diff changeset
   104
 , _compilation(c)
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   105
 , _frame_map(c->frame_map())
489c9b5090e2 Initial load
duke
parents:
diff changeset
   106
 , _current_block(NULL)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   107
 , _pending_non_safepoint(NULL)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   108
 , _pending_non_safepoint_offset(0)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   109
{
489c9b5090e2 Initial load
duke
parents:
diff changeset
   110
  _slow_case_stubs = new CodeStubList();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   111
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   112
489c9b5090e2 Initial load
duke
parents:
diff changeset
   113
489c9b5090e2 Initial load
duke
parents:
diff changeset
   114
LIR_Assembler::~LIR_Assembler() {
51519
ecb650023e28 8208480: Test failure: assert(is_bound() || is_unused()) after JDK-8206075 in C1
ghaug
parents: 51333
diff changeset
   115
  // The unwind handler label may be unnbound if this destructor is invoked because of a bail-out.
ecb650023e28 8208480: Test failure: assert(is_bound() || is_unused()) after JDK-8206075 in C1
ghaug
parents: 51333
diff changeset
   116
  // Reset it here to avoid an assertion.
ecb650023e28 8208480: Test failure: assert(is_bound() || is_unused()) after JDK-8206075 in C1
ghaug
parents: 51333
diff changeset
   117
  _unwind_handler_entry.reset();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   118
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   119
489c9b5090e2 Initial load
duke
parents:
diff changeset
   120
489c9b5090e2 Initial load
duke
parents:
diff changeset
   121
void LIR_Assembler::check_codespace() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   122
  CodeSection* cs = _masm->code_section();
10505
df3cc194efc5 7085279: C1 overflows code buffer with VerifyOops and CompressedOops
iveresov
parents: 9124
diff changeset
   123
  if (cs->remaining() < (int)(NOT_LP64(1*K)LP64_ONLY(2*K))) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   124
    BAILOUT("CodeBuffer overflow");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   125
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   126
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   127
489c9b5090e2 Initial load
duke
parents:
diff changeset
   128
24669
14439491d407 8031475: Missing oopmap in patching stubs
neliasso
parents: 24018
diff changeset
   129
void LIR_Assembler::append_code_stub(CodeStub* stub) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   130
  _slow_case_stubs->append(stub);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   131
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   132
489c9b5090e2 Initial load
duke
parents:
diff changeset
   133
void LIR_Assembler::emit_stubs(CodeStubList* stub_list) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   134
  for (int m = 0; m < stub_list->length(); m++) {
38031
e0b822facc03 8149374: Replace C1-specific collection classes with universal collection classes
fzhinkin
parents: 38017
diff changeset
   135
    CodeStub* s = stub_list->at(m);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   136
489c9b5090e2 Initial load
duke
parents:
diff changeset
   137
    check_codespace();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   138
    CHECK_BAILOUT();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   139
489c9b5090e2 Initial load
duke
parents:
diff changeset
   140
#ifndef PRODUCT
489c9b5090e2 Initial load
duke
parents:
diff changeset
   141
    if (CommentedAssembly) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   142
      stringStream st;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   143
      s->print_name(&st);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   144
      st.print(" slow case");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   145
      _masm->block_comment(st.as_string());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   146
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   147
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
   148
    s->emit_code(this);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   149
#ifdef ASSERT
489c9b5090e2 Initial load
duke
parents:
diff changeset
   150
    s->assert_no_unbound_labels();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   151
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
   152
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   153
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   154
489c9b5090e2 Initial load
duke
parents:
diff changeset
   155
489c9b5090e2 Initial load
duke
parents:
diff changeset
   156
void LIR_Assembler::emit_slow_case_stubs() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   157
  emit_stubs(_slow_case_stubs);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   158
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   159
489c9b5090e2 Initial load
duke
parents:
diff changeset
   160
489c9b5090e2 Initial load
duke
parents:
diff changeset
   161
bool LIR_Assembler::needs_icache(ciMethod* method) const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   162
  return !method->is_static();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   163
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   164
55105
9ad765641e8f 8223213: Implement fast class initialization checks on x86-64
vlivanov
parents: 51996
diff changeset
   165
bool LIR_Assembler::needs_clinit_barrier_on_entry(ciMethod* method) const {
9ad765641e8f 8223213: Implement fast class initialization checks on x86-64
vlivanov
parents: 51996
diff changeset
   166
  return VM_Version::supports_fast_class_init_checks() && method->needs_clinit_barrier();
9ad765641e8f 8223213: Implement fast class initialization checks on x86-64
vlivanov
parents: 51996
diff changeset
   167
}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   168
489c9b5090e2 Initial load
duke
parents:
diff changeset
   169
int LIR_Assembler::code_offset() const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   170
  return _masm->offset();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   171
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   172
489c9b5090e2 Initial load
duke
parents:
diff changeset
   173
489c9b5090e2 Initial load
duke
parents:
diff changeset
   174
address LIR_Assembler::pc() const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   175
  return _masm->pc();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   176
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   177
24018
77b156916bab 8032410: compiler/uncommontrap/TestStackBangRbp.java times out on Solaris-Sparc V9
roland
parents: 22244
diff changeset
   178
// To bang the stack of this compiled method we use the stack size
77b156916bab 8032410: compiler/uncommontrap/TestStackBangRbp.java times out on Solaris-Sparc V9
roland
parents: 22244
diff changeset
   179
// that the interpreter would need in case of a deoptimization. This
77b156916bab 8032410: compiler/uncommontrap/TestStackBangRbp.java times out on Solaris-Sparc V9
roland
parents: 22244
diff changeset
   180
// removes the need to bang the stack in the deoptimization blob which
77b156916bab 8032410: compiler/uncommontrap/TestStackBangRbp.java times out on Solaris-Sparc V9
roland
parents: 22244
diff changeset
   181
// in turn simplifies stack overflow handling.
77b156916bab 8032410: compiler/uncommontrap/TestStackBangRbp.java times out on Solaris-Sparc V9
roland
parents: 22244
diff changeset
   182
int LIR_Assembler::bang_size_in_bytes() const {
26576
a9429d24d429 8050147: StoreLoad barrier interferes with stack usages
shade
parents: 25949
diff changeset
   183
  return MAX2(initial_frame_size_in_bytes() + os::extra_bang_size_in_bytes(), _compilation->interpreter_frame_size());
24018
77b156916bab 8032410: compiler/uncommontrap/TestStackBangRbp.java times out on Solaris-Sparc V9
roland
parents: 22244
diff changeset
   184
}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   185
489c9b5090e2 Initial load
duke
parents:
diff changeset
   186
void LIR_Assembler::emit_exception_entries(ExceptionInfoList* info_list) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   187
  for (int i = 0; i < info_list->length(); i++) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   188
    XHandlers* handlers = info_list->at(i)->exception_handlers();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   189
489c9b5090e2 Initial load
duke
parents:
diff changeset
   190
    for (int j = 0; j < handlers->length(); j++) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   191
      XHandler* handler = handlers->handler_at(j);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   192
      assert(handler->lir_op_id() != -1, "handler not processed by LinearScan");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   193
      assert(handler->entry_code() == NULL ||
489c9b5090e2 Initial load
duke
parents:
diff changeset
   194
             handler->entry_code()->instructions_list()->last()->code() == lir_branch ||
489c9b5090e2 Initial load
duke
parents:
diff changeset
   195
             handler->entry_code()->instructions_list()->last()->code() == lir_delay_slot, "last operation must be branch");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   196
489c9b5090e2 Initial load
duke
parents:
diff changeset
   197
      if (handler->entry_pco() == -1) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   198
        // entry code not emitted yet
489c9b5090e2 Initial load
duke
parents:
diff changeset
   199
        if (handler->entry_code() != NULL && handler->entry_code()->instructions_list()->length() > 1) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   200
          handler->set_entry_pco(code_offset());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   201
          if (CommentedAssembly) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   202
            _masm->block_comment("Exception adapter block");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   203
          }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   204
          emit_lir_list(handler->entry_code());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   205
        } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   206
          handler->set_entry_pco(handler->entry_block()->exception_handler_pco());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   207
        }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   208
489c9b5090e2 Initial load
duke
parents:
diff changeset
   209
        assert(handler->entry_pco() != -1, "must be set now");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   210
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   211
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   212
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   213
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   214
489c9b5090e2 Initial load
duke
parents:
diff changeset
   215
489c9b5090e2 Initial load
duke
parents:
diff changeset
   216
void LIR_Assembler::emit_code(BlockList* hir) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   217
  if (PrintLIR) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   218
    print_LIR(hir);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   219
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   220
489c9b5090e2 Initial load
duke
parents:
diff changeset
   221
  int n = hir->length();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   222
  for (int i = 0; i < n; i++) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   223
    emit_block(hir->at(i));
489c9b5090e2 Initial load
duke
parents:
diff changeset
   224
    CHECK_BAILOUT();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   225
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   226
489c9b5090e2 Initial load
duke
parents:
diff changeset
   227
  flush_debug_info(code_offset());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   228
489c9b5090e2 Initial load
duke
parents:
diff changeset
   229
  DEBUG_ONLY(check_no_unbound_labels());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   230
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   231
489c9b5090e2 Initial load
duke
parents:
diff changeset
   232
489c9b5090e2 Initial load
duke
parents:
diff changeset
   233
void LIR_Assembler::emit_block(BlockBegin* block) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   234
  if (block->is_set(BlockBegin::backward_branch_target_flag)) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   235
    align_backward_branch_target();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   236
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   237
489c9b5090e2 Initial load
duke
parents:
diff changeset
   238
  // if this block is the start of an exception handler, record the
489c9b5090e2 Initial load
duke
parents:
diff changeset
   239
  // PC offset of the first instruction for later construction of
489c9b5090e2 Initial load
duke
parents:
diff changeset
   240
  // the ExceptionHandlerTable
489c9b5090e2 Initial load
duke
parents:
diff changeset
   241
  if (block->is_set(BlockBegin::exception_entry_flag)) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   242
    block->set_exception_handler_pco(code_offset());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   243
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   244
489c9b5090e2 Initial load
duke
parents:
diff changeset
   245
#ifndef PRODUCT
489c9b5090e2 Initial load
duke
parents:
diff changeset
   246
  if (PrintLIRWithAssembly) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   247
    // don't print Phi's
489c9b5090e2 Initial load
duke
parents:
diff changeset
   248
    InstructionPrinter ip(false);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   249
    block->print(ip);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   250
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   251
#endif /* PRODUCT */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   252
489c9b5090e2 Initial load
duke
parents:
diff changeset
   253
  assert(block->lir() != NULL, "must have LIR");
1066
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 1
diff changeset
   254
  X86_ONLY(assert(_masm->rsp_offset() == 0, "frame size should be fixed"));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   255
489c9b5090e2 Initial load
duke
parents:
diff changeset
   256
#ifndef PRODUCT
489c9b5090e2 Initial load
duke
parents:
diff changeset
   257
  if (CommentedAssembly) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   258
    stringStream st;
6745
a34ef8968a84 6986046: C1 valuestack cleanup
roland
parents: 6453
diff changeset
   259
    st.print_cr(" block B%d [%d, %d]", block->block_id(), block->bci(), block->end()->printable_bci());
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   260
    _masm->block_comment(st.as_string());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   261
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   262
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
   263
489c9b5090e2 Initial load
duke
parents:
diff changeset
   264
  emit_lir_list(block->lir());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   265
1066
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 1
diff changeset
   266
  X86_ONLY(assert(_masm->rsp_offset() == 0, "frame size should be fixed"));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   267
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   268
489c9b5090e2 Initial load
duke
parents:
diff changeset
   269
489c9b5090e2 Initial load
duke
parents:
diff changeset
   270
void LIR_Assembler::emit_lir_list(LIR_List* list) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   271
  peephole(list);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   272
489c9b5090e2 Initial load
duke
parents:
diff changeset
   273
  int n = list->length();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   274
  for (int i = 0; i < n; i++) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   275
    LIR_Op* op = list->at(i);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   276
489c9b5090e2 Initial load
duke
parents:
diff changeset
   277
    check_codespace();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   278
    CHECK_BAILOUT();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   279
489c9b5090e2 Initial load
duke
parents:
diff changeset
   280
#ifndef PRODUCT
489c9b5090e2 Initial load
duke
parents:
diff changeset
   281
    if (CommentedAssembly) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   282
      // Don't record out every op since that's too verbose.  Print
489c9b5090e2 Initial load
duke
parents:
diff changeset
   283
      // branches since they include block and stub names.  Also print
489c9b5090e2 Initial load
duke
parents:
diff changeset
   284
      // patching moves since they generate funny looking code.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   285
      if (op->code() == lir_branch ||
50102
454fa295105c 8202976: Add C1 lea patching support for x86
pliden
parents: 49754
diff changeset
   286
          (op->code() == lir_move && op->as_Op1()->patch_code() != lir_patch_none) ||
454fa295105c 8202976: Add C1 lea patching support for x86
pliden
parents: 49754
diff changeset
   287
          (op->code() == lir_leal && op->as_Op1()->patch_code() != lir_patch_none)) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   288
        stringStream st;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   289
        op->print_on(&st);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   290
        _masm->block_comment(st.as_string());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   291
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   292
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   293
    if (PrintLIRWithAssembly) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   294
      // print out the LIR operation followed by the resulting assembly
489c9b5090e2 Initial load
duke
parents:
diff changeset
   295
      list->at(i)->print(); tty->cr();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   296
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   297
#endif /* PRODUCT */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   298
489c9b5090e2 Initial load
duke
parents:
diff changeset
   299
    op->emit_code(this);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   300
489c9b5090e2 Initial load
duke
parents:
diff changeset
   301
    if (compilation()->debug_info_recorder()->recording_non_safepoints()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   302
      process_debug_info(op);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   303
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   304
489c9b5090e2 Initial load
duke
parents:
diff changeset
   305
#ifndef PRODUCT
489c9b5090e2 Initial load
duke
parents:
diff changeset
   306
    if (PrintLIRWithAssembly) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   307
      _masm->code()->decode();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   308
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   309
#endif /* PRODUCT */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   310
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   311
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   312
489c9b5090e2 Initial load
duke
parents:
diff changeset
   313
#ifdef ASSERT
489c9b5090e2 Initial load
duke
parents:
diff changeset
   314
void LIR_Assembler::check_no_unbound_labels() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   315
  CHECK_BAILOUT();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   316
489c9b5090e2 Initial load
duke
parents:
diff changeset
   317
  for (int i = 0; i < _branch_target_blocks.length() - 1; i++) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   318
    if (!_branch_target_blocks.at(i)->label()->is_bound()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   319
      tty->print_cr("label of block B%d is not bound", _branch_target_blocks.at(i)->block_id());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   320
      assert(false, "unbound label");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   321
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   322
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   323
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   324
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
   325
489c9b5090e2 Initial load
duke
parents:
diff changeset
   326
//----------------------------------debug info--------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
   327
489c9b5090e2 Initial load
duke
parents:
diff changeset
   328
489c9b5090e2 Initial load
duke
parents:
diff changeset
   329
void LIR_Assembler::add_debug_info_for_branch(CodeEmitInfo* info) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   330
  int pc_offset = code_offset();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   331
  flush_debug_info(pc_offset);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   332
  info->record_debug_info(compilation()->debug_info_recorder(), pc_offset);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   333
  if (info->exception_handlers() != NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   334
    compilation()->add_exception_handlers_for_pco(pc_offset, info->exception_handlers());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   335
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   336
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   337
489c9b5090e2 Initial load
duke
parents:
diff changeset
   338
5687
b862d1f189bd 6930772: JSR 292 needs to support SPARC C1
twisti
parents: 5334
diff changeset
   339
void LIR_Assembler::add_call_info(int pc_offset, CodeEmitInfo* cinfo) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   340
  flush_debug_info(pc_offset);
5687
b862d1f189bd 6930772: JSR 292 needs to support SPARC C1
twisti
parents: 5334
diff changeset
   341
  cinfo->record_debug_info(compilation()->debug_info_recorder(), pc_offset);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   342
  if (cinfo->exception_handlers() != NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   343
    compilation()->add_exception_handlers_for_pco(pc_offset, cinfo->exception_handlers());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   344
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   345
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   346
489c9b5090e2 Initial load
duke
parents:
diff changeset
   347
static ValueStack* debug_info(Instruction* ins) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   348
  StateSplit* ss = ins->as_StateSplit();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   349
  if (ss != NULL) return ss->state();
6745
a34ef8968a84 6986046: C1 valuestack cleanup
roland
parents: 6453
diff changeset
   350
  return ins->state_before();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   351
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   352
489c9b5090e2 Initial load
duke
parents:
diff changeset
   353
void LIR_Assembler::process_debug_info(LIR_Op* op) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   354
  Instruction* src = op->source();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   355
  if (src == NULL)  return;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   356
  int pc_offset = code_offset();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   357
  if (_pending_non_safepoint == src) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   358
    _pending_non_safepoint_offset = pc_offset;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   359
    return;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   360
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   361
  ValueStack* vstack = debug_info(src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   362
  if (vstack == NULL)  return;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   363
  if (_pending_non_safepoint != NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   364
    // Got some old debug info.  Get rid of it.
6745
a34ef8968a84 6986046: C1 valuestack cleanup
roland
parents: 6453
diff changeset
   365
    if (debug_info(_pending_non_safepoint) == vstack) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   366
      _pending_non_safepoint_offset = pc_offset;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   367
      return;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   368
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   369
    if (_pending_non_safepoint_offset < pc_offset) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   370
      record_non_safepoint_debug_info();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   371
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   372
    _pending_non_safepoint = NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   373
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   374
  // Remember the debug info.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   375
  if (pc_offset > compilation()->debug_info_recorder()->last_pc_offset()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   376
    _pending_non_safepoint = src;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   377
    _pending_non_safepoint_offset = pc_offset;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   378
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   379
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   380
489c9b5090e2 Initial load
duke
parents:
diff changeset
   381
// Index caller states in s, where 0 is the oldest, 1 its callee, etc.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   382
// Return NULL if n is too large.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   383
// Returns the caller_bci for the next-younger state, also.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   384
static ValueStack* nth_oldest(ValueStack* s, int n, int& bci_result) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   385
  ValueStack* t = s;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   386
  for (int i = 0; i < n; i++) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   387
    if (t == NULL)  break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   388
    t = t->caller_state();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   389
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   390
  if (t == NULL)  return NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   391
  for (;;) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   392
    ValueStack* tc = t->caller_state();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   393
    if (tc == NULL)  return s;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   394
    t = tc;
6745
a34ef8968a84 6986046: C1 valuestack cleanup
roland
parents: 6453
diff changeset
   395
    bci_result = tc->bci();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   396
    s = s->caller_state();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   397
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   398
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   399
489c9b5090e2 Initial load
duke
parents:
diff changeset
   400
void LIR_Assembler::record_non_safepoint_debug_info() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   401
  int         pc_offset = _pending_non_safepoint_offset;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   402
  ValueStack* vstack    = debug_info(_pending_non_safepoint);
6745
a34ef8968a84 6986046: C1 valuestack cleanup
roland
parents: 6453
diff changeset
   403
  int         bci       = vstack->bci();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   404
489c9b5090e2 Initial load
duke
parents:
diff changeset
   405
  DebugInformationRecorder* debug_info = compilation()->debug_info_recorder();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   406
  assert(debug_info->recording_non_safepoints(), "sanity");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   407
489c9b5090e2 Initial load
duke
parents:
diff changeset
   408
  debug_info->add_non_safepoint(pc_offset);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   409
489c9b5090e2 Initial load
duke
parents:
diff changeset
   410
  // Visit scopes from oldest to youngest.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   411
  for (int n = 0; ; n++) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   412
    int s_bci = bci;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   413
    ValueStack* s = nth_oldest(vstack, n, s_bci);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   414
    if (s == NULL)  break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   415
    IRScope* scope = s->scope();
3600
27aa4477d039 6833129: specjvm98 fails with NullPointerException in the compiler with -XX:DeoptimizeALot
cfang
parents: 1412
diff changeset
   416
    //Always pass false for reexecute since these ScopeDescs are never used for deopt
33160
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 33089
diff changeset
   417
    methodHandle null_mh;
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 33089
diff changeset
   418
    debug_info->describe_scope(pc_offset, null_mh, scope->method(), s->bci(), false/*reexecute*/);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   419
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   420
489c9b5090e2 Initial load
duke
parents:
diff changeset
   421
  debug_info->end_non_safepoint(pc_offset);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   422
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   423
489c9b5090e2 Initial load
duke
parents:
diff changeset
   424
34220
1ba69cb5585c 8138952: C1: Distinguish between PPC32 and PPC64
mdoerr
parents: 33465
diff changeset
   425
ImplicitNullCheckStub* LIR_Assembler::add_debug_info_for_null_check_here(CodeEmitInfo* cinfo) {
1ba69cb5585c 8138952: C1: Distinguish between PPC32 and PPC64
mdoerr
parents: 33465
diff changeset
   426
  return add_debug_info_for_null_check(code_offset(), cinfo);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   427
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   428
34220
1ba69cb5585c 8138952: C1: Distinguish between PPC32 and PPC64
mdoerr
parents: 33465
diff changeset
   429
ImplicitNullCheckStub* LIR_Assembler::add_debug_info_for_null_check(int pc_offset, CodeEmitInfo* cinfo) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   430
  ImplicitNullCheckStub* stub = new ImplicitNullCheckStub(pc_offset, cinfo);
24669
14439491d407 8031475: Missing oopmap in patching stubs
neliasso
parents: 24018
diff changeset
   431
  append_code_stub(stub);
34220
1ba69cb5585c 8138952: C1: Distinguish between PPC32 and PPC64
mdoerr
parents: 33465
diff changeset
   432
  return stub;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   433
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   434
489c9b5090e2 Initial load
duke
parents:
diff changeset
   435
void LIR_Assembler::add_debug_info_for_div0_here(CodeEmitInfo* info) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   436
  add_debug_info_for_div0(code_offset(), info);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   437
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   438
489c9b5090e2 Initial load
duke
parents:
diff changeset
   439
void LIR_Assembler::add_debug_info_for_div0(int pc_offset, CodeEmitInfo* cinfo) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   440
  DivByZeroStub* stub = new DivByZeroStub(pc_offset, cinfo);
24669
14439491d407 8031475: Missing oopmap in patching stubs
neliasso
parents: 24018
diff changeset
   441
  append_code_stub(stub);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   442
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   443
489c9b5090e2 Initial load
duke
parents:
diff changeset
   444
void LIR_Assembler::emit_rtcall(LIR_OpRTCall* op) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   445
  rt_call(op->result_opr(), op->addr(), op->arguments(), op->tmp(), op->info());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   446
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   447
489c9b5090e2 Initial load
duke
parents:
diff changeset
   448
489c9b5090e2 Initial load
duke
parents:
diff changeset
   449
void LIR_Assembler::emit_call(LIR_OpJavaCall* op) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   450
  verify_oop_map(op->info());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   451
51996
84743156e780 8188764: Obsolete AssumeMP and then remove all support for non-MP builds
dholmes
parents: 51857
diff changeset
   452
  // must align calls sites, otherwise they can't be updated atomically
84743156e780 8188764: Obsolete AssumeMP and then remove all support for non-MP builds
dholmes
parents: 51857
diff changeset
   453
  align_call(op->code());
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   454
489c9b5090e2 Initial load
duke
parents:
diff changeset
   455
  // emit the static call stub stuff out of line
489c9b5090e2 Initial load
duke
parents:
diff changeset
   456
  emit_static_call_stub();
32082
2a3323e25de1 8130309: Need to bailout cleanly if creation of stubs fails when codecache is out of space
thartmann
parents: 28954
diff changeset
   457
  CHECK_BAILOUT();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   458
489c9b5090e2 Initial load
duke
parents:
diff changeset
   459
  switch (op->code()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   460
  case lir_static_call:
13487
75aa4880b15f 7192167: JSR 292: C1 has old broken code which needs to be removed
twisti
parents: 12739
diff changeset
   461
  case lir_dynamic_call:
5046
27e801a857cb 6919934: JSR 292 needs to support x86 C1
twisti
parents: 3795
diff changeset
   462
    call(op, relocInfo::static_call_type);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   463
    break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   464
  case lir_optvirtual_call:
5046
27e801a857cb 6919934: JSR 292 needs to support x86 C1
twisti
parents: 3795
diff changeset
   465
    call(op, relocInfo::opt_virtual_call_type);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   466
    break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   467
  case lir_icvirtual_call:
5046
27e801a857cb 6919934: JSR 292 needs to support x86 C1
twisti
parents: 3795
diff changeset
   468
    ic_call(op);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   469
    break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   470
  case lir_virtual_call:
5046
27e801a857cb 6919934: JSR 292 needs to support x86 C1
twisti
parents: 3795
diff changeset
   471
    vtable_call(op);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   472
    break;
13487
75aa4880b15f 7192167: JSR 292: C1 has old broken code which needs to be removed
twisti
parents: 12739
diff changeset
   473
  default:
33105
294e48b4f704 8080775: Better argument formatting for assert() and friends
david
parents: 32203
diff changeset
   474
    fatal("unexpected op code: %s", op->name());
13487
75aa4880b15f 7192167: JSR 292: C1 has old broken code which needs to be removed
twisti
parents: 12739
diff changeset
   475
    break;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   476
  }
5046
27e801a857cb 6919934: JSR 292 needs to support x86 C1
twisti
parents: 3795
diff changeset
   477
6186
7eef4cda471c 6975855: don't emit deopt MH handler in C1 if not required
twisti
parents: 5702
diff changeset
   478
  // JSR 292
7eef4cda471c 6975855: don't emit deopt MH handler in C1 if not required
twisti
parents: 5702
diff changeset
   479
  // Record if this method has MethodHandle invokes.
7eef4cda471c 6975855: don't emit deopt MH handler in C1 if not required
twisti
parents: 5702
diff changeset
   480
  if (op->is_method_handle_invoke()) {
7eef4cda471c 6975855: don't emit deopt MH handler in C1 if not required
twisti
parents: 5702
diff changeset
   481
    compilation()->set_has_method_handle_invokes(true);
7eef4cda471c 6975855: don't emit deopt MH handler in C1 if not required
twisti
parents: 5702
diff changeset
   482
  }
7eef4cda471c 6975855: don't emit deopt MH handler in C1 if not required
twisti
parents: 5702
diff changeset
   483
1066
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 1
diff changeset
   484
#if defined(X86) && defined(TIERED)
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   485
  // C2 leave fpu stack dirty clean it
489c9b5090e2 Initial load
duke
parents:
diff changeset
   486
  if (UseSSE < 2) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   487
    int i;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   488
    for ( i = 1; i <= 7 ; i++ ) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   489
      ffree(i);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   490
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   491
    if (!op->result_opr()->is_float_kind()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   492
      ffree(0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   493
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   494
  }
1066
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 1
diff changeset
   495
#endif // X86 && TIERED
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   496
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   497
489c9b5090e2 Initial load
duke
parents:
diff changeset
   498
489c9b5090e2 Initial load
duke
parents:
diff changeset
   499
void LIR_Assembler::emit_opLabel(LIR_OpLabel* op) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   500
  _masm->bind (*(op->label()));
489c9b5090e2 Initial load
duke
parents:
diff changeset
   501
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   502
489c9b5090e2 Initial load
duke
parents:
diff changeset
   503
489c9b5090e2 Initial load
duke
parents:
diff changeset
   504
void LIR_Assembler::emit_op1(LIR_Op1* op) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   505
  switch (op->code()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   506
    case lir_move:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   507
      if (op->move_kind() == lir_move_volatile) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   508
        assert(op->patch_code() == lir_patch_none, "can't patch volatiles");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   509
        volatile_move_op(op->in_opr(), op->result_opr(), op->type(), op->info());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   510
      } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   511
        move_op(op->in_opr(), op->result_opr(), op->type(),
7427
d7b79a367474 6985015: C1 needs to support compressed oops
iveresov
parents: 7397
diff changeset
   512
                op->patch_code(), op->info(), op->pop_fpu_stack(),
d7b79a367474 6985015: C1 needs to support compressed oops
iveresov
parents: 7397
diff changeset
   513
                op->move_kind() == lir_move_unaligned,
d7b79a367474 6985015: C1 needs to support compressed oops
iveresov
parents: 7397
diff changeset
   514
                op->move_kind() == lir_move_wide);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   515
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   516
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   517
489c9b5090e2 Initial load
duke
parents:
diff changeset
   518
    case lir_roundfp: {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   519
      LIR_OpRoundFP* round_op = op->as_OpRoundFP();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   520
      roundfp_op(round_op->in_opr(), round_op->tmp(), round_op->result_opr(), round_op->pop_fpu_stack());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   521
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   522
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   523
489c9b5090e2 Initial load
duke
parents:
diff changeset
   524
    case lir_return:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   525
      return_op(op->in_opr());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   526
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   527
489c9b5090e2 Initial load
duke
parents:
diff changeset
   528
    case lir_safepoint:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   529
      if (compilation()->debug_info_recorder()->last_pc_offset() == code_offset()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   530
        _masm->nop();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   531
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   532
      safepoint_poll(op->in_opr(), op->info());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   533
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   534
489c9b5090e2 Initial load
duke
parents:
diff changeset
   535
    case lir_fxch:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   536
      fxch(op->in_opr()->as_jint());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   537
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   538
489c9b5090e2 Initial load
duke
parents:
diff changeset
   539
    case lir_fld:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   540
      fld(op->in_opr()->as_jint());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   541
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   542
489c9b5090e2 Initial load
duke
parents:
diff changeset
   543
    case lir_ffree:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   544
      ffree(op->in_opr()->as_jint());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   545
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   546
489c9b5090e2 Initial load
duke
parents:
diff changeset
   547
    case lir_branch:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   548
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   549
489c9b5090e2 Initial load
duke
parents:
diff changeset
   550
    case lir_push:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   551
      push(op->in_opr());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   552
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   553
489c9b5090e2 Initial load
duke
parents:
diff changeset
   554
    case lir_pop:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   555
      pop(op->in_opr());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   556
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   557
489c9b5090e2 Initial load
duke
parents:
diff changeset
   558
    case lir_leal:
50102
454fa295105c 8202976: Add C1 lea patching support for x86
pliden
parents: 49754
diff changeset
   559
      leal(op->in_opr(), op->result_opr(), op->patch_code(), op->info());
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   560
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   561
37291
f13632a2a389 8151724: Remove -XX:GenerateCompilerNullChecks
thartmann
parents: 35540
diff changeset
   562
    case lir_null_check: {
f13632a2a389 8151724: Remove -XX:GenerateCompilerNullChecks
thartmann
parents: 35540
diff changeset
   563
      ImplicitNullCheckStub* stub = add_debug_info_for_null_check_here(op->info());
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   564
37291
f13632a2a389 8151724: Remove -XX:GenerateCompilerNullChecks
thartmann
parents: 35540
diff changeset
   565
      if (op->in_opr()->is_single_cpu()) {
f13632a2a389 8151724: Remove -XX:GenerateCompilerNullChecks
thartmann
parents: 35540
diff changeset
   566
        _masm->null_check(op->in_opr()->as_register(), stub->entry());
f13632a2a389 8151724: Remove -XX:GenerateCompilerNullChecks
thartmann
parents: 35540
diff changeset
   567
      } else {
f13632a2a389 8151724: Remove -XX:GenerateCompilerNullChecks
thartmann
parents: 35540
diff changeset
   568
        Unimplemented();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   569
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   570
      break;
37291
f13632a2a389 8151724: Remove -XX:GenerateCompilerNullChecks
thartmann
parents: 35540
diff changeset
   571
    }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   572
489c9b5090e2 Initial load
duke
parents:
diff changeset
   573
    case lir_monaddr:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   574
      monitor_address(op->in_opr()->as_constant_ptr()->as_jint(), op->result_opr());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   575
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   576
6453
970dc585ab63 6953144: Tiered compilation
iveresov
parents: 6186
diff changeset
   577
#ifdef SPARC
970dc585ab63 6953144: Tiered compilation
iveresov
parents: 6186
diff changeset
   578
    case lir_pack64:
970dc585ab63 6953144: Tiered compilation
iveresov
parents: 6186
diff changeset
   579
      pack64(op->in_opr(), op->result_opr());
970dc585ab63 6953144: Tiered compilation
iveresov
parents: 6186
diff changeset
   580
      break;
970dc585ab63 6953144: Tiered compilation
iveresov
parents: 6186
diff changeset
   581
970dc585ab63 6953144: Tiered compilation
iveresov
parents: 6186
diff changeset
   582
    case lir_unpack64:
970dc585ab63 6953144: Tiered compilation
iveresov
parents: 6186
diff changeset
   583
      unpack64(op->in_opr(), op->result_opr());
970dc585ab63 6953144: Tiered compilation
iveresov
parents: 6186
diff changeset
   584
      break;
970dc585ab63 6953144: Tiered compilation
iveresov
parents: 6186
diff changeset
   585
#endif
970dc585ab63 6953144: Tiered compilation
iveresov
parents: 6186
diff changeset
   586
5334
b2d040a8d375 6939930: exception unwind changes in 6919934 hurts compilation speed
never
parents: 5052
diff changeset
   587
    case lir_unwind:
b2d040a8d375 6939930: exception unwind changes in 6919934 hurts compilation speed
never
parents: 5052
diff changeset
   588
      unwind_op(op->in_opr());
b2d040a8d375 6939930: exception unwind changes in 6919934 hurts compilation speed
never
parents: 5052
diff changeset
   589
      break;
b2d040a8d375 6939930: exception unwind changes in 6919934 hurts compilation speed
never
parents: 5052
diff changeset
   590
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   591
    default:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   592
      Unimplemented();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   593
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   594
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   595
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   596
489c9b5090e2 Initial load
duke
parents:
diff changeset
   597
489c9b5090e2 Initial load
duke
parents:
diff changeset
   598
void LIR_Assembler::emit_op0(LIR_Op0* op) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   599
  switch (op->code()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   600
    case lir_word_align: {
32203
01a3716ed455 8131682: C1 should use multibyte nops everywhere
shade
parents: 32082
diff changeset
   601
      _masm->align(BytesPerWord);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   602
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   603
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   604
489c9b5090e2 Initial load
duke
parents:
diff changeset
   605
    case lir_nop:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   606
      assert(op->info() == NULL, "not supported");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   607
      _masm->nop();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   608
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   609
489c9b5090e2 Initial load
duke
parents:
diff changeset
   610
    case lir_label:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   611
      Unimplemented();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   612
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   613
489c9b5090e2 Initial load
duke
parents:
diff changeset
   614
    case lir_build_frame:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   615
      build_frame();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   616
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   617
489c9b5090e2 Initial load
duke
parents:
diff changeset
   618
    case lir_std_entry:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   619
      // init offsets
489c9b5090e2 Initial load
duke
parents:
diff changeset
   620
      offsets()->set_value(CodeOffsets::OSR_Entry, _masm->offset());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   621
      _masm->align(CodeEntryAlignment);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   622
      if (needs_icache(compilation()->method())) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   623
        check_icache();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   624
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   625
      offsets()->set_value(CodeOffsets::Verified_Entry, _masm->offset());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   626
      _masm->verified_entry();
55105
9ad765641e8f 8223213: Implement fast class initialization checks on x86-64
vlivanov
parents: 51996
diff changeset
   627
      if (needs_clinit_barrier_on_entry(compilation()->method())) {
9ad765641e8f 8223213: Implement fast class initialization checks on x86-64
vlivanov
parents: 51996
diff changeset
   628
        clinit_barrier(compilation()->method());
9ad765641e8f 8223213: Implement fast class initialization checks on x86-64
vlivanov
parents: 51996
diff changeset
   629
      }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   630
      build_frame();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   631
      offsets()->set_value(CodeOffsets::Frame_Complete, _masm->offset());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   632
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   633
489c9b5090e2 Initial load
duke
parents:
diff changeset
   634
    case lir_osr_entry:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   635
      offsets()->set_value(CodeOffsets::OSR_Entry, _masm->offset());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   636
      osr_entry();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   637
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   638
489c9b5090e2 Initial load
duke
parents:
diff changeset
   639
    case lir_24bit_FPU:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   640
      set_24bit_FPU();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   641
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   642
489c9b5090e2 Initial load
duke
parents:
diff changeset
   643
    case lir_reset_FPU:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   644
      reset_FPU();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   645
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   646
489c9b5090e2 Initial load
duke
parents:
diff changeset
   647
    case lir_breakpoint:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   648
      breakpoint();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   649
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   650
489c9b5090e2 Initial load
duke
parents:
diff changeset
   651
    case lir_fpop_raw:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   652
      fpop();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   653
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   654
489c9b5090e2 Initial load
duke
parents:
diff changeset
   655
    case lir_membar:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   656
      membar();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   657
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   658
489c9b5090e2 Initial load
duke
parents:
diff changeset
   659
    case lir_membar_acquire:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   660
      membar_acquire();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   661
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   662
489c9b5090e2 Initial load
duke
parents:
diff changeset
   663
    case lir_membar_release:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   664
      membar_release();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   665
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   666
11886
feebf5c9f40c 7120481: storeStore barrier in constructor with final field
jiangli
parents: 10505
diff changeset
   667
    case lir_membar_loadload:
feebf5c9f40c 7120481: storeStore barrier in constructor with final field
jiangli
parents: 10505
diff changeset
   668
      membar_loadload();
feebf5c9f40c 7120481: storeStore barrier in constructor with final field
jiangli
parents: 10505
diff changeset
   669
      break;
feebf5c9f40c 7120481: storeStore barrier in constructor with final field
jiangli
parents: 10505
diff changeset
   670
feebf5c9f40c 7120481: storeStore barrier in constructor with final field
jiangli
parents: 10505
diff changeset
   671
    case lir_membar_storestore:
feebf5c9f40c 7120481: storeStore barrier in constructor with final field
jiangli
parents: 10505
diff changeset
   672
      membar_storestore();
feebf5c9f40c 7120481: storeStore barrier in constructor with final field
jiangli
parents: 10505
diff changeset
   673
      break;
feebf5c9f40c 7120481: storeStore barrier in constructor with final field
jiangli
parents: 10505
diff changeset
   674
feebf5c9f40c 7120481: storeStore barrier in constructor with final field
jiangli
parents: 10505
diff changeset
   675
    case lir_membar_loadstore:
feebf5c9f40c 7120481: storeStore barrier in constructor with final field
jiangli
parents: 10505
diff changeset
   676
      membar_loadstore();
feebf5c9f40c 7120481: storeStore barrier in constructor with final field
jiangli
parents: 10505
diff changeset
   677
      break;
feebf5c9f40c 7120481: storeStore barrier in constructor with final field
jiangli
parents: 10505
diff changeset
   678
feebf5c9f40c 7120481: storeStore barrier in constructor with final field
jiangli
parents: 10505
diff changeset
   679
    case lir_membar_storeload:
feebf5c9f40c 7120481: storeStore barrier in constructor with final field
jiangli
parents: 10505
diff changeset
   680
      membar_storeload();
feebf5c9f40c 7120481: storeStore barrier in constructor with final field
jiangli
parents: 10505
diff changeset
   681
      break;
feebf5c9f40c 7120481: storeStore barrier in constructor with final field
jiangli
parents: 10505
diff changeset
   682
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   683
    case lir_get_thread:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   684
      get_thread(op->result_opr());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   685
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   686
38017
55047d16f141 8147844: new method j.l.Runtime.onSpinWait() and the corresponding x86 hotspot instrinsic
ikrylov
parents: 37291
diff changeset
   687
    case lir_on_spin_wait:
55047d16f141 8147844: new method j.l.Runtime.onSpinWait() and the corresponding x86 hotspot instrinsic
ikrylov
parents: 37291
diff changeset
   688
      on_spin_wait();
55047d16f141 8147844: new method j.l.Runtime.onSpinWait() and the corresponding x86 hotspot instrinsic
ikrylov
parents: 37291
diff changeset
   689
      break;
55047d16f141 8147844: new method j.l.Runtime.onSpinWait() and the corresponding x86 hotspot instrinsic
ikrylov
parents: 37291
diff changeset
   690
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   691
    default:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   692
      ShouldNotReachHere();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   693
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   694
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   695
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   696
489c9b5090e2 Initial load
duke
parents:
diff changeset
   697
489c9b5090e2 Initial load
duke
parents:
diff changeset
   698
void LIR_Assembler::emit_op2(LIR_Op2* op) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   699
  switch (op->code()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   700
    case lir_cmp:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   701
      if (op->info() != NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   702
        assert(op->in_opr1()->is_address() || op->in_opr2()->is_address(),
489c9b5090e2 Initial load
duke
parents:
diff changeset
   703
               "shouldn't be codeemitinfo for non-address operands");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   704
        add_debug_info_for_null_check_here(op->info()); // exception possible
489c9b5090e2 Initial load
duke
parents:
diff changeset
   705
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   706
      comp_op(op->condition(), op->in_opr1(), op->in_opr2(), op);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   707
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   708
489c9b5090e2 Initial load
duke
parents:
diff changeset
   709
    case lir_cmp_l2i:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   710
    case lir_cmp_fd2i:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   711
    case lir_ucmp_fd2i:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   712
      comp_fl2i(op->code(), op->in_opr1(), op->in_opr2(), op->result_opr(), op);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   713
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   714
489c9b5090e2 Initial load
duke
parents:
diff changeset
   715
    case lir_cmove:
7713
1e06d2419258 7009231: C1: Incorrect CAS code for longs on SPARC 32bit
iveresov
parents: 7427
diff changeset
   716
      cmove(op->condition(), op->in_opr1(), op->in_opr2(), op->result_opr(), op->type());
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   717
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   718
489c9b5090e2 Initial load
duke
parents:
diff changeset
   719
    case lir_shl:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   720
    case lir_shr:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   721
    case lir_ushr:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   722
      if (op->in_opr2()->is_constant()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   723
        shift_op(op->code(), op->in_opr1(), op->in_opr2()->as_constant_ptr()->as_jint(), op->result_opr());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   724
      } else {
12739
09f26b73ae66 7133857: exp() and pow() should use the x87 ISA on x86
roland
parents: 11886
diff changeset
   725
        shift_op(op->code(), op->in_opr1(), op->in_opr2(), op->result_opr(), op->tmp1_opr());
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   726
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   727
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   728
489c9b5090e2 Initial load
duke
parents:
diff changeset
   729
    case lir_add:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   730
    case lir_sub:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   731
    case lir_mul:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   732
    case lir_mul_strictfp:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   733
    case lir_div:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   734
    case lir_div_strictfp:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   735
    case lir_rem:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   736
      assert(op->fpu_pop_count() < 2, "");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   737
      arith_op(
489c9b5090e2 Initial load
duke
parents:
diff changeset
   738
        op->code(),
489c9b5090e2 Initial load
duke
parents:
diff changeset
   739
        op->in_opr1(),
489c9b5090e2 Initial load
duke
parents:
diff changeset
   740
        op->in_opr2(),
489c9b5090e2 Initial load
duke
parents:
diff changeset
   741
        op->result_opr(),
489c9b5090e2 Initial load
duke
parents:
diff changeset
   742
        op->info(),
489c9b5090e2 Initial load
duke
parents:
diff changeset
   743
        op->fpu_pop_count() == 1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   744
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   745
489c9b5090e2 Initial load
duke
parents:
diff changeset
   746
    case lir_abs:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   747
    case lir_sqrt:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   748
    case lir_tan:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   749
    case lir_log10:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   750
      intrinsic_op(op->code(), op->in_opr1(), op->in_opr2(), op->result_opr(), op);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   751
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   752
51857
9978fea8a371 8210764: Update avx512 implementation
kvn
parents: 51519
diff changeset
   753
    case lir_neg:
9978fea8a371 8210764: Update avx512 implementation
kvn
parents: 51519
diff changeset
   754
      negate(op->in_opr1(), op->result_opr(), op->in_opr2());
9978fea8a371 8210764: Update avx512 implementation
kvn
parents: 51519
diff changeset
   755
      break;
9978fea8a371 8210764: Update avx512 implementation
kvn
parents: 51519
diff changeset
   756
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   757
    case lir_logic_and:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   758
    case lir_logic_or:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   759
    case lir_logic_xor:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   760
      logic_op(
489c9b5090e2 Initial load
duke
parents:
diff changeset
   761
        op->code(),
489c9b5090e2 Initial load
duke
parents:
diff changeset
   762
        op->in_opr1(),
489c9b5090e2 Initial load
duke
parents:
diff changeset
   763
        op->in_opr2(),
489c9b5090e2 Initial load
duke
parents:
diff changeset
   764
        op->result_opr());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   765
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   766
489c9b5090e2 Initial load
duke
parents:
diff changeset
   767
    case lir_throw:
5334
b2d040a8d375 6939930: exception unwind changes in 6919934 hurts compilation speed
never
parents: 5052
diff changeset
   768
      throw_op(op->in_opr1(), op->in_opr2(), op->info());
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   769
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   770
13886
8d82c4dfa722 7023898: Intrinsify AtomicLongFieldUpdater.getAndIncrement()
roland
parents: 13728
diff changeset
   771
    case lir_xadd:
8d82c4dfa722 7023898: Intrinsify AtomicLongFieldUpdater.getAndIncrement()
roland
parents: 13728
diff changeset
   772
    case lir_xchg:
8d82c4dfa722 7023898: Intrinsify AtomicLongFieldUpdater.getAndIncrement()
roland
parents: 13728
diff changeset
   773
      atomic_op(op->code(), op->in_opr1(), op->in_opr2(), op->result_opr(), op->tmp1_opr());
8d82c4dfa722 7023898: Intrinsify AtomicLongFieldUpdater.getAndIncrement()
roland
parents: 13728
diff changeset
   774
      break;
8d82c4dfa722 7023898: Intrinsify AtomicLongFieldUpdater.getAndIncrement()
roland
parents: 13728
diff changeset
   775
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   776
    default:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   777
      Unimplemented();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   778
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   779
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   780
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   781
489c9b5090e2 Initial load
duke
parents:
diff changeset
   782
489c9b5090e2 Initial load
duke
parents:
diff changeset
   783
void LIR_Assembler::build_frame() {
24018
77b156916bab 8032410: compiler/uncommontrap/TestStackBangRbp.java times out on Solaris-Sparc V9
roland
parents: 22244
diff changeset
   784
  _masm->build_frame(initial_frame_size_in_bytes(), bang_size_in_bytes());
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   785
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   786
489c9b5090e2 Initial load
duke
parents:
diff changeset
   787
489c9b5090e2 Initial load
duke
parents:
diff changeset
   788
void LIR_Assembler::roundfp_op(LIR_Opr src, LIR_Opr tmp, LIR_Opr dest, bool pop_fpu_stack) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   789
  assert((src->is_single_fpu() && dest->is_single_stack()) ||
489c9b5090e2 Initial load
duke
parents:
diff changeset
   790
         (src->is_double_fpu() && dest->is_double_stack()),
489c9b5090e2 Initial load
duke
parents:
diff changeset
   791
         "round_fp: rounds register -> stack location");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   792
489c9b5090e2 Initial load
duke
parents:
diff changeset
   793
  reg2stack (src, dest, src->type(), pop_fpu_stack);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   794
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   795
489c9b5090e2 Initial load
duke
parents:
diff changeset
   796
7427
d7b79a367474 6985015: C1 needs to support compressed oops
iveresov
parents: 7397
diff changeset
   797
void LIR_Assembler::move_op(LIR_Opr src, LIR_Opr dest, BasicType type, LIR_PatchCode patch_code, CodeEmitInfo* info, bool pop_fpu_stack, bool unaligned, bool wide) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   798
  if (src->is_register()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   799
    if (dest->is_register()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   800
      assert(patch_code == lir_patch_none && info == NULL, "no patching and info allowed here");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   801
      reg2reg(src,  dest);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   802
    } else if (dest->is_stack()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   803
      assert(patch_code == lir_patch_none && info == NULL, "no patching and info allowed here");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   804
      reg2stack(src, dest, type, pop_fpu_stack);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   805
    } else if (dest->is_address()) {
7427
d7b79a367474 6985015: C1 needs to support compressed oops
iveresov
parents: 7397
diff changeset
   806
      reg2mem(src, dest, type, patch_code, info, pop_fpu_stack, wide, unaligned);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   807
    } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   808
      ShouldNotReachHere();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   809
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   810
489c9b5090e2 Initial load
duke
parents:
diff changeset
   811
  } else if (src->is_stack()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   812
    assert(patch_code == lir_patch_none && info == NULL, "no patching and info allowed here");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   813
    if (dest->is_register()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   814
      stack2reg(src, dest, type);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   815
    } else if (dest->is_stack()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   816
      stack2stack(src, dest, type);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   817
    } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   818
      ShouldNotReachHere();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   819
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   820
489c9b5090e2 Initial load
duke
parents:
diff changeset
   821
  } else if (src->is_constant()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   822
    if (dest->is_register()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   823
      const2reg(src, dest, patch_code, info); // patching is possible
489c9b5090e2 Initial load
duke
parents:
diff changeset
   824
    } else if (dest->is_stack()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   825
      assert(patch_code == lir_patch_none && info == NULL, "no patching and info allowed here");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   826
      const2stack(src, dest);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   827
    } else if (dest->is_address()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   828
      assert(patch_code == lir_patch_none, "no patching allowed here");
7427
d7b79a367474 6985015: C1 needs to support compressed oops
iveresov
parents: 7397
diff changeset
   829
      const2mem(src, dest, type, info, wide);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   830
    } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   831
      ShouldNotReachHere();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   832
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   833
489c9b5090e2 Initial load
duke
parents:
diff changeset
   834
  } else if (src->is_address()) {
7427
d7b79a367474 6985015: C1 needs to support compressed oops
iveresov
parents: 7397
diff changeset
   835
    mem2reg(src, dest, type, patch_code, info, wide, unaligned);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   836
489c9b5090e2 Initial load
duke
parents:
diff changeset
   837
  } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   838
    ShouldNotReachHere();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   839
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   840
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   841
489c9b5090e2 Initial load
duke
parents:
diff changeset
   842
489c9b5090e2 Initial load
duke
parents:
diff changeset
   843
void LIR_Assembler::verify_oop_map(CodeEmitInfo* info) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   844
#ifndef PRODUCT
22244
0fdd928b5b64 8011391: C1: assert(code_offset() - offset == NativeInstruction::nop_instruction_size) failed: only one instruction can go in a delay slot
adlertz
parents: 22234
diff changeset
   845
  if (VerifyOops) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   846
    OopMapStream s(info->oop_map());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   847
    while (!s.is_done()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   848
      OopMapValue v = s.current();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   849
      if (v.is_oop()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   850
        VMReg r = v.reg();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   851
        if (!r->is_stack()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   852
          stringStream st;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   853
          st.print("bad oop %s at %d", r->as_Register()->name(), _masm->offset());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   854
#ifdef SPARC
25949
34557722059b 6424123: JVM crashes on failed 'strdup' call
zgu
parents: 25715
diff changeset
   855
          _masm->_verify_oop(r->as_Register(), os::strdup(st.as_string(), mtCompiler), __FILE__, __LINE__);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   856
#else
489c9b5090e2 Initial load
duke
parents:
diff changeset
   857
          _masm->verify_oop(r->as_Register());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   858
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
   859
        } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   860
          _masm->verify_stack_oop(r->reg2stack() * VMRegImpl::stack_slot_size);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   861
        }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   862
      }
9107
8ac339c8f87f 6528013: C1 CTW failure with -XX:+VerifyOops assert(allocates2(pc),"")
never
parents: 8107
diff changeset
   863
      check_codespace();
8ac339c8f87f 6528013: C1 CTW failure with -XX:+VerifyOops assert(allocates2(pc),"")
never
parents: 8107
diff changeset
   864
      CHECK_BAILOUT();
8ac339c8f87f 6528013: C1 CTW failure with -XX:+VerifyOops assert(allocates2(pc),"")
never
parents: 8107
diff changeset
   865
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   866
      s.next();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   867
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   868
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   869
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
   870
}