hotspot/src/share/vm/c1/c1_LIR.cpp
author iveresov
Thu, 02 Dec 2010 17:21:12 -0800
changeset 7432 f06f1253c317
parent 7427 d7b79a367474
child 8067 f5f4eac4c48f
permissions -rw-r--r--
7003554: (tiered) assert(is_null_object() || handle() != NULL) failed: cannot embed null pointer Summary: C1 with profiling doesn't check whether the MDO has been really allocated, which can silently fail if the perm gen is full. The solution is to check if the allocation failed and bailout out of inlining or compilation. Reviewed-by: kvn, never
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
     1
/*
5547
f4b087cbb361 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 5334
diff changeset
     2
 * Copyright (c) 2000, 2010, 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"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6745
diff changeset
    26
#include "c1/c1_InstructionPrinter.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6745
diff changeset
    27
#include "c1/c1_LIR.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6745
diff changeset
    28
#include "c1/c1_LIRAssembler.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6745
diff changeset
    29
#include "c1/c1_ValueStack.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6745
diff changeset
    30
#include "ci/ciInstance.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6745
diff changeset
    31
#include "runtime/sharedRuntime.hpp"
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    32
489c9b5090e2 Initial load
duke
parents:
diff changeset
    33
Register LIR_OprDesc::as_register() const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    34
  return FrameMap::cpu_rnr2reg(cpu_regnr());
489c9b5090e2 Initial load
duke
parents:
diff changeset
    35
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
    36
489c9b5090e2 Initial load
duke
parents:
diff changeset
    37
Register LIR_OprDesc::as_register_lo() const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    38
  return FrameMap::cpu_rnr2reg(cpu_regnrLo());
489c9b5090e2 Initial load
duke
parents:
diff changeset
    39
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
    40
489c9b5090e2 Initial load
duke
parents:
diff changeset
    41
Register LIR_OprDesc::as_register_hi() const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    42
  return FrameMap::cpu_rnr2reg(cpu_regnrHi());
489c9b5090e2 Initial load
duke
parents:
diff changeset
    43
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
    44
1066
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 670
diff changeset
    45
#if defined(X86)
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    46
489c9b5090e2 Initial load
duke
parents:
diff changeset
    47
XMMRegister LIR_OprDesc::as_xmm_float_reg() const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    48
  return FrameMap::nr2xmmreg(xmm_regnr());
489c9b5090e2 Initial load
duke
parents:
diff changeset
    49
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
    50
489c9b5090e2 Initial load
duke
parents:
diff changeset
    51
XMMRegister LIR_OprDesc::as_xmm_double_reg() const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    52
  assert(xmm_regnrLo() == xmm_regnrHi(), "assumed in calculation");
489c9b5090e2 Initial load
duke
parents:
diff changeset
    53
  return FrameMap::nr2xmmreg(xmm_regnrLo());
489c9b5090e2 Initial load
duke
parents:
diff changeset
    54
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
    55
1066
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 670
diff changeset
    56
#endif // X86
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    57
6176
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
    58
#if defined(SPARC) || defined(PPC)
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    59
489c9b5090e2 Initial load
duke
parents:
diff changeset
    60
FloatRegister LIR_OprDesc::as_float_reg() const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    61
  return FrameMap::nr2floatreg(fpu_regnr());
489c9b5090e2 Initial load
duke
parents:
diff changeset
    62
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
    63
489c9b5090e2 Initial load
duke
parents:
diff changeset
    64
FloatRegister LIR_OprDesc::as_double_reg() const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    65
  return FrameMap::nr2floatreg(fpu_regnrHi());
489c9b5090e2 Initial load
duke
parents:
diff changeset
    66
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
    67
489c9b5090e2 Initial load
duke
parents:
diff changeset
    68
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
    69
6176
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
    70
#ifdef ARM
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
    71
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
    72
FloatRegister LIR_OprDesc::as_float_reg() const {
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
    73
  return as_FloatRegister(fpu_regnr());
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
    74
}
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
    75
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
    76
FloatRegister LIR_OprDesc::as_double_reg() const {
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
    77
  return as_FloatRegister(fpu_regnrLo());
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
    78
}
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
    79
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
    80
#endif
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
    81
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
    82
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    83
LIR_Opr LIR_OprFact::illegalOpr = LIR_OprFact::illegal();
489c9b5090e2 Initial load
duke
parents:
diff changeset
    84
489c9b5090e2 Initial load
duke
parents:
diff changeset
    85
LIR_Opr LIR_OprFact::value_type(ValueType* type) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    86
  ValueTag tag = type->tag();
489c9b5090e2 Initial load
duke
parents:
diff changeset
    87
  switch (tag) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    88
  case objectTag : {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    89
    ClassConstant* c = type->as_ClassConstant();
489c9b5090e2 Initial load
duke
parents:
diff changeset
    90
    if (c != NULL && !c->value()->is_loaded()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    91
      return LIR_OprFact::oopConst(NULL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
    92
    } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    93
      return LIR_OprFact::oopConst(type->as_ObjectType()->encoding());
489c9b5090e2 Initial load
duke
parents:
diff changeset
    94
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
    95
  }
5048
c31b6243f37e 6932496: c1: deoptimization of jsr subroutine fails on sparcv9
roland
parents: 5046
diff changeset
    96
  case addressTag: return LIR_OprFact::addressConst(type->as_AddressConstant()->value());
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    97
  case intTag    : return LIR_OprFact::intConst(type->as_IntConstant()->value());
489c9b5090e2 Initial load
duke
parents:
diff changeset
    98
  case floatTag  : return LIR_OprFact::floatConst(type->as_FloatConstant()->value());
489c9b5090e2 Initial load
duke
parents:
diff changeset
    99
  case longTag   : return LIR_OprFact::longConst(type->as_LongConstant()->value());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   100
  case doubleTag : return LIR_OprFact::doubleConst(type->as_DoubleConstant()->value());
1066
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 670
diff changeset
   101
  default: ShouldNotReachHere(); return LIR_OprFact::intConst(-1);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   102
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   103
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   104
489c9b5090e2 Initial load
duke
parents:
diff changeset
   105
489c9b5090e2 Initial load
duke
parents:
diff changeset
   106
LIR_Opr LIR_OprFact::dummy_value_type(ValueType* type) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   107
  switch (type->tag()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   108
    case objectTag: return LIR_OprFact::oopConst(NULL);
5048
c31b6243f37e 6932496: c1: deoptimization of jsr subroutine fails on sparcv9
roland
parents: 5046
diff changeset
   109
    case addressTag:return LIR_OprFact::addressConst(0);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   110
    case intTag:    return LIR_OprFact::intConst(0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   111
    case floatTag:  return LIR_OprFact::floatConst(0.0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   112
    case longTag:   return LIR_OprFact::longConst(0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   113
    case doubleTag: return LIR_OprFact::doubleConst(0.0);
1066
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 670
diff changeset
   114
    default:        ShouldNotReachHere(); return LIR_OprFact::intConst(-1);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   115
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   116
  return illegalOpr;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   117
}
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
//---------------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
   122
489c9b5090e2 Initial load
duke
parents:
diff changeset
   123
489c9b5090e2 Initial load
duke
parents:
diff changeset
   124
LIR_Address::Scale LIR_Address::scale(BasicType type) {
202
dc13bf0e5d5d 6633953: type2aelembytes{T_ADDRESS} should be 8 bytes in 64 bit VM
kvn
parents: 1
diff changeset
   125
  int elem_size = type2aelembytes(type);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   126
  switch (elem_size) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   127
  case 1: return LIR_Address::times_1;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   128
  case 2: return LIR_Address::times_2;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   129
  case 4: return LIR_Address::times_4;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   130
  case 8: return LIR_Address::times_8;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   131
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   132
  ShouldNotReachHere();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   133
  return LIR_Address::times_1;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   134
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   135
489c9b5090e2 Initial load
duke
parents:
diff changeset
   136
489c9b5090e2 Initial load
duke
parents:
diff changeset
   137
#ifndef PRODUCT
489c9b5090e2 Initial load
duke
parents:
diff changeset
   138
void LIR_Address::verify() const {
6176
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
   139
#if defined(SPARC) || defined(PPC)
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
   140
  assert(scale() == times_1, "Scaled addressing mode not available on SPARC/PPC and should not be used");
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   141
  assert(disp() == 0 || index()->is_illegal(), "can't have both");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   142
#endif
6176
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
   143
#ifdef ARM
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
   144
  assert(disp() == 0 || index()->is_illegal(), "can't have both");
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
   145
  assert(-4096 < disp() && disp() < 4096, "architecture constraint");
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
   146
#endif
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   147
#ifdef _LP64
489c9b5090e2 Initial load
duke
parents:
diff changeset
   148
  assert(base()->is_cpu_register(), "wrong base operand");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   149
  assert(index()->is_illegal() || index()->is_double_cpu(), "wrong index operand");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   150
  assert(base()->type() == T_OBJECT || base()->type() == T_LONG,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   151
         "wrong type for addresses");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   152
#else
489c9b5090e2 Initial load
duke
parents:
diff changeset
   153
  assert(base()->is_single_cpu(), "wrong base operand");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   154
  assert(index()->is_illegal() || index()->is_single_cpu(), "wrong index operand");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   155
  assert(base()->type() == T_OBJECT || base()->type() == T_INT,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   156
         "wrong type for addresses");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   157
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
   158
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   159
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
   160
489c9b5090e2 Initial load
duke
parents:
diff changeset
   161
489c9b5090e2 Initial load
duke
parents:
diff changeset
   162
//---------------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
   163
489c9b5090e2 Initial load
duke
parents:
diff changeset
   164
char LIR_OprDesc::type_char(BasicType t) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   165
  switch (t) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   166
    case T_ARRAY:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   167
      t = T_OBJECT;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   168
    case T_BOOLEAN:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   169
    case T_CHAR:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   170
    case T_FLOAT:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   171
    case T_DOUBLE:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   172
    case T_BYTE:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   173
    case T_SHORT:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   174
    case T_INT:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   175
    case T_LONG:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   176
    case T_OBJECT:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   177
    case T_ADDRESS:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   178
    case T_VOID:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   179
      return ::type2char(t);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   180
489c9b5090e2 Initial load
duke
parents:
diff changeset
   181
    case T_ILLEGAL:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   182
      return '?';
489c9b5090e2 Initial load
duke
parents:
diff changeset
   183
489c9b5090e2 Initial load
duke
parents:
diff changeset
   184
    default:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   185
      ShouldNotReachHere();
1066
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 670
diff changeset
   186
      return '?';
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   187
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   188
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   189
489c9b5090e2 Initial load
duke
parents:
diff changeset
   190
#ifndef PRODUCT
489c9b5090e2 Initial load
duke
parents:
diff changeset
   191
void LIR_OprDesc::validate_type() const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   192
489c9b5090e2 Initial load
duke
parents:
diff changeset
   193
#ifdef ASSERT
489c9b5090e2 Initial load
duke
parents:
diff changeset
   194
  if (!is_pointer() && !is_illegal()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   195
    switch (as_BasicType(type_field())) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   196
    case T_LONG:
6176
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
   197
      assert((kind_field() == cpu_register || kind_field() == stack_value) &&
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
   198
             size_field() == double_size, "must match");
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   199
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   200
    case T_FLOAT:
6176
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
   201
      // FP return values can be also in CPU registers on ARM and PPC (softfp ABI)
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
   202
      assert((kind_field() == fpu_register || kind_field() == stack_value
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
   203
             ARM_ONLY(|| kind_field() == cpu_register)
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
   204
             PPC_ONLY(|| kind_field() == cpu_register) ) &&
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
   205
             size_field() == single_size, "must match");
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   206
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   207
    case T_DOUBLE:
6176
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
   208
      // FP return values can be also in CPU registers on ARM and PPC (softfp ABI)
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
   209
      assert((kind_field() == fpu_register || kind_field() == stack_value
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
   210
             ARM_ONLY(|| kind_field() == cpu_register)
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
   211
             PPC_ONLY(|| kind_field() == cpu_register) ) &&
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
   212
             size_field() == double_size, "must match");
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   213
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   214
    case T_BOOLEAN:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   215
    case T_CHAR:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   216
    case T_BYTE:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   217
    case T_SHORT:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   218
    case T_INT:
6742
81ef369b8fc7 6972540: sun/nio/ch/SocketChannelImpl compilation crashed when executing CompileTheWorld
never
parents: 6461
diff changeset
   219
    case T_ADDRESS:
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   220
    case T_OBJECT:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   221
    case T_ARRAY:
6176
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
   222
      assert((kind_field() == cpu_register || kind_field() == stack_value) &&
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
   223
             size_field() == single_size, "must match");
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   224
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   225
489c9b5090e2 Initial load
duke
parents:
diff changeset
   226
    case T_ILLEGAL:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   227
      // XXX TKR also means unknown right now
489c9b5090e2 Initial load
duke
parents:
diff changeset
   228
      // assert(is_illegal(), "must match");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   229
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   230
489c9b5090e2 Initial load
duke
parents:
diff changeset
   231
    default:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   232
      ShouldNotReachHere();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   233
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   234
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   235
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
   236
489c9b5090e2 Initial load
duke
parents:
diff changeset
   237
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   238
#endif // PRODUCT
489c9b5090e2 Initial load
duke
parents:
diff changeset
   239
489c9b5090e2 Initial load
duke
parents:
diff changeset
   240
489c9b5090e2 Initial load
duke
parents:
diff changeset
   241
bool LIR_OprDesc::is_oop() const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   242
  if (is_pointer()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   243
    return pointer()->is_oop_pointer();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   244
  } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   245
    OprType t= type_field();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   246
    assert(t != unknown_type, "not set");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   247
    return t == object_type;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   248
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   249
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   250
489c9b5090e2 Initial load
duke
parents:
diff changeset
   251
489c9b5090e2 Initial load
duke
parents:
diff changeset
   252
489c9b5090e2 Initial load
duke
parents:
diff changeset
   253
void LIR_Op2::verify() const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   254
#ifdef ASSERT
489c9b5090e2 Initial load
duke
parents:
diff changeset
   255
  switch (code()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   256
    case lir_cmove:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   257
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   258
489c9b5090e2 Initial load
duke
parents:
diff changeset
   259
    default:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   260
      assert(!result_opr()->is_register() || !result_opr()->is_oop_register(),
489c9b5090e2 Initial load
duke
parents:
diff changeset
   261
             "can't produce oops from arith");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   262
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   263
489c9b5090e2 Initial load
duke
parents:
diff changeset
   264
  if (TwoOperandLIRForm) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   265
    switch (code()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   266
    case lir_add:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   267
    case lir_sub:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   268
    case lir_mul:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   269
    case lir_mul_strictfp:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   270
    case lir_div:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   271
    case lir_div_strictfp:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   272
    case lir_rem:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   273
    case lir_logic_and:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   274
    case lir_logic_or:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   275
    case lir_logic_xor:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   276
    case lir_shl:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   277
    case lir_shr:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   278
      assert(in_opr1() == result_opr(), "opr1 and result must match");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   279
      assert(in_opr1()->is_valid() && in_opr2()->is_valid(), "must be valid");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   280
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   281
489c9b5090e2 Initial load
duke
parents:
diff changeset
   282
    // special handling for lir_ushr because of write barriers
489c9b5090e2 Initial load
duke
parents:
diff changeset
   283
    case lir_ushr:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   284
      assert(in_opr1() == result_opr() || in_opr2()->is_constant(), "opr1 and result must match or shift count is constant");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   285
      assert(in_opr1()->is_valid() && in_opr2()->is_valid(), "must be valid");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   286
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   287
489c9b5090e2 Initial load
duke
parents:
diff changeset
   288
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   289
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   290
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
   291
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   292
489c9b5090e2 Initial load
duke
parents:
diff changeset
   293
489c9b5090e2 Initial load
duke
parents:
diff changeset
   294
LIR_OpBranch::LIR_OpBranch(LIR_Condition cond, BasicType type, BlockBegin* block)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   295
  : LIR_Op(lir_branch, LIR_OprFact::illegalOpr, (CodeEmitInfo*)NULL)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   296
  , _cond(cond)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   297
  , _type(type)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   298
  , _label(block->label())
489c9b5090e2 Initial load
duke
parents:
diff changeset
   299
  , _block(block)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   300
  , _ublock(NULL)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   301
  , _stub(NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   302
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   303
489c9b5090e2 Initial load
duke
parents:
diff changeset
   304
LIR_OpBranch::LIR_OpBranch(LIR_Condition cond, BasicType type, CodeStub* stub) :
489c9b5090e2 Initial load
duke
parents:
diff changeset
   305
  LIR_Op(lir_branch, LIR_OprFact::illegalOpr, (CodeEmitInfo*)NULL)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   306
  , _cond(cond)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   307
  , _type(type)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   308
  , _label(stub->entry())
489c9b5090e2 Initial load
duke
parents:
diff changeset
   309
  , _block(NULL)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   310
  , _ublock(NULL)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   311
  , _stub(stub) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   312
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   313
489c9b5090e2 Initial load
duke
parents:
diff changeset
   314
LIR_OpBranch::LIR_OpBranch(LIR_Condition cond, BasicType type, BlockBegin* block, BlockBegin* ublock)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   315
  : LIR_Op(lir_cond_float_branch, LIR_OprFact::illegalOpr, (CodeEmitInfo*)NULL)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   316
  , _cond(cond)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   317
  , _type(type)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   318
  , _label(block->label())
489c9b5090e2 Initial load
duke
parents:
diff changeset
   319
  , _block(block)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   320
  , _ublock(ublock)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   321
  , _stub(NULL)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   322
{
489c9b5090e2 Initial load
duke
parents:
diff changeset
   323
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   324
489c9b5090e2 Initial load
duke
parents:
diff changeset
   325
void LIR_OpBranch::change_block(BlockBegin* b) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   326
  assert(_block != NULL, "must have old block");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   327
  assert(_block->label() == label(), "must be equal");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   328
489c9b5090e2 Initial load
duke
parents:
diff changeset
   329
  _block = b;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   330
  _label = b->label();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   331
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   332
489c9b5090e2 Initial load
duke
parents:
diff changeset
   333
void LIR_OpBranch::change_ublock(BlockBegin* b) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   334
  assert(_ublock != NULL, "must have old block");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   335
  _ublock = b;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   336
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   337
489c9b5090e2 Initial load
duke
parents:
diff changeset
   338
void LIR_OpBranch::negate_cond() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   339
  switch (_cond) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   340
    case lir_cond_equal:        _cond = lir_cond_notEqual;     break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   341
    case lir_cond_notEqual:     _cond = lir_cond_equal;        break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   342
    case lir_cond_less:         _cond = lir_cond_greaterEqual; break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   343
    case lir_cond_lessEqual:    _cond = lir_cond_greater;      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   344
    case lir_cond_greaterEqual: _cond = lir_cond_less;         break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   345
    case lir_cond_greater:      _cond = lir_cond_lessEqual;    break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   346
    default: ShouldNotReachHere();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   347
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   348
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   349
489c9b5090e2 Initial load
duke
parents:
diff changeset
   350
489c9b5090e2 Initial load
duke
parents:
diff changeset
   351
LIR_OpTypeCheck::LIR_OpTypeCheck(LIR_Code code, LIR_Opr result, LIR_Opr object, ciKlass* klass,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   352
                                 LIR_Opr tmp1, LIR_Opr tmp2, LIR_Opr tmp3,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   353
                                 bool fast_check, CodeEmitInfo* info_for_exception, CodeEmitInfo* info_for_patch,
6453
970dc585ab63 6953144: Tiered compilation
iveresov
parents: 6176
diff changeset
   354
                                 CodeStub* stub)
970dc585ab63 6953144: Tiered compilation
iveresov
parents: 6176
diff changeset
   355
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   356
  : LIR_Op(code, result, NULL)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   357
  , _object(object)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   358
  , _array(LIR_OprFact::illegalOpr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   359
  , _klass(klass)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   360
  , _tmp1(tmp1)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   361
  , _tmp2(tmp2)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   362
  , _tmp3(tmp3)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   363
  , _fast_check(fast_check)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   364
  , _stub(stub)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   365
  , _info_for_patch(info_for_patch)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   366
  , _info_for_exception(info_for_exception)
6453
970dc585ab63 6953144: Tiered compilation
iveresov
parents: 6176
diff changeset
   367
  , _profiled_method(NULL)
970dc585ab63 6953144: Tiered compilation
iveresov
parents: 6176
diff changeset
   368
  , _profiled_bci(-1)
970dc585ab63 6953144: Tiered compilation
iveresov
parents: 6176
diff changeset
   369
  , _should_profile(false)
970dc585ab63 6953144: Tiered compilation
iveresov
parents: 6176
diff changeset
   370
{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   371
  if (code == lir_checkcast) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   372
    assert(info_for_exception != NULL, "checkcast throws exceptions");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   373
  } else if (code == lir_instanceof) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   374
    assert(info_for_exception == NULL, "instanceof throws no exceptions");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   375
  } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   376
    ShouldNotReachHere();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   377
  }
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
6453
970dc585ab63 6953144: Tiered compilation
iveresov
parents: 6176
diff changeset
   382
LIR_OpTypeCheck::LIR_OpTypeCheck(LIR_Code code, LIR_Opr object, LIR_Opr array, LIR_Opr tmp1, LIR_Opr tmp2, LIR_Opr tmp3, CodeEmitInfo* info_for_exception)
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   383
  : LIR_Op(code, LIR_OprFact::illegalOpr, NULL)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   384
  , _object(object)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   385
  , _array(array)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   386
  , _klass(NULL)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   387
  , _tmp1(tmp1)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   388
  , _tmp2(tmp2)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   389
  , _tmp3(tmp3)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   390
  , _fast_check(false)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   391
  , _stub(NULL)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   392
  , _info_for_patch(NULL)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   393
  , _info_for_exception(info_for_exception)
6453
970dc585ab63 6953144: Tiered compilation
iveresov
parents: 6176
diff changeset
   394
  , _profiled_method(NULL)
970dc585ab63 6953144: Tiered compilation
iveresov
parents: 6176
diff changeset
   395
  , _profiled_bci(-1)
970dc585ab63 6953144: Tiered compilation
iveresov
parents: 6176
diff changeset
   396
  , _should_profile(false)
970dc585ab63 6953144: Tiered compilation
iveresov
parents: 6176
diff changeset
   397
{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   398
  if (code == lir_store_check) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   399
    _stub = new ArrayStoreExceptionStub(info_for_exception);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   400
    assert(info_for_exception != NULL, "store_check throws exceptions");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   401
  } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   402
    ShouldNotReachHere();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   403
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   404
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   405
489c9b5090e2 Initial load
duke
parents:
diff changeset
   406
489c9b5090e2 Initial load
duke
parents:
diff changeset
   407
LIR_OpArrayCopy::LIR_OpArrayCopy(LIR_Opr src, LIR_Opr src_pos, LIR_Opr dst, LIR_Opr dst_pos, LIR_Opr length,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   408
                                 LIR_Opr tmp, ciArrayKlass* expected_type, int flags, CodeEmitInfo* info)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   409
  : LIR_Op(lir_arraycopy, LIR_OprFact::illegalOpr, info)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   410
  , _tmp(tmp)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   411
  , _src(src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   412
  , _src_pos(src_pos)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   413
  , _dst(dst)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   414
  , _dst_pos(dst_pos)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   415
  , _flags(flags)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   416
  , _expected_type(expected_type)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   417
  , _length(length) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   418
  _stub = new ArrayCopyStub(this);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   419
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   420
489c9b5090e2 Initial load
duke
parents:
diff changeset
   421
489c9b5090e2 Initial load
duke
parents:
diff changeset
   422
//-------------------verify--------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
   423
489c9b5090e2 Initial load
duke
parents:
diff changeset
   424
void LIR_Op1::verify() const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   425
  switch(code()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   426
  case lir_move:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   427
    assert(in_opr()->is_valid() && result_opr()->is_valid(), "must be");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   428
    break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   429
  case lir_null_check:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   430
    assert(in_opr()->is_register(), "must be");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   431
    break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   432
  case lir_return:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   433
    assert(in_opr()->is_register() || in_opr()->is_illegal(), "must be");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   434
    break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   435
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   436
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   437
489c9b5090e2 Initial load
duke
parents:
diff changeset
   438
void LIR_OpRTCall::verify() const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   439
  assert(strcmp(Runtime1::name_for_address(addr()), "<unknown function>") != 0, "unknown function");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   440
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   441
489c9b5090e2 Initial load
duke
parents:
diff changeset
   442
//-------------------visits--------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
   443
489c9b5090e2 Initial load
duke
parents:
diff changeset
   444
// complete rework of LIR instruction visitor.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   445
// The virtual calls for each instruction type is replaced by a big
489c9b5090e2 Initial load
duke
parents:
diff changeset
   446
// switch that adds the operands for each instruction
489c9b5090e2 Initial load
duke
parents:
diff changeset
   447
489c9b5090e2 Initial load
duke
parents:
diff changeset
   448
void LIR_OpVisitState::visit(LIR_Op* op) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   449
  // copy information from the LIR_Op
489c9b5090e2 Initial load
duke
parents:
diff changeset
   450
  reset();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   451
  set_op(op);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   452
489c9b5090e2 Initial load
duke
parents:
diff changeset
   453
  switch (op->code()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   454
489c9b5090e2 Initial load
duke
parents:
diff changeset
   455
// LIR_Op0
489c9b5090e2 Initial load
duke
parents:
diff changeset
   456
    case lir_word_align:               // result and info always invalid
489c9b5090e2 Initial load
duke
parents:
diff changeset
   457
    case lir_backwardbranch_target:    // result and info always invalid
489c9b5090e2 Initial load
duke
parents:
diff changeset
   458
    case lir_build_frame:              // result and info always invalid
489c9b5090e2 Initial load
duke
parents:
diff changeset
   459
    case lir_fpop_raw:                 // result and info always invalid
489c9b5090e2 Initial load
duke
parents:
diff changeset
   460
    case lir_24bit_FPU:                // result and info always invalid
489c9b5090e2 Initial load
duke
parents:
diff changeset
   461
    case lir_reset_FPU:                // result and info always invalid
489c9b5090e2 Initial load
duke
parents:
diff changeset
   462
    case lir_breakpoint:               // result and info always invalid
489c9b5090e2 Initial load
duke
parents:
diff changeset
   463
    case lir_membar:                   // result and info always invalid
489c9b5090e2 Initial load
duke
parents:
diff changeset
   464
    case lir_membar_acquire:           // result and info always invalid
489c9b5090e2 Initial load
duke
parents:
diff changeset
   465
    case lir_membar_release:           // result and info always invalid
489c9b5090e2 Initial load
duke
parents:
diff changeset
   466
    {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   467
      assert(op->as_Op0() != NULL, "must be");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   468
      assert(op->_info == NULL, "info not used by this instruction");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   469
      assert(op->_result->is_illegal(), "not used");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   470
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   471
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   472
489c9b5090e2 Initial load
duke
parents:
diff changeset
   473
    case lir_nop:                      // may have info, result always invalid
489c9b5090e2 Initial load
duke
parents:
diff changeset
   474
    case lir_std_entry:                // may have result, info always invalid
489c9b5090e2 Initial load
duke
parents:
diff changeset
   475
    case lir_osr_entry:                // may have result, info always invalid
489c9b5090e2 Initial load
duke
parents:
diff changeset
   476
    case lir_get_thread:               // may have result, info always invalid
489c9b5090e2 Initial load
duke
parents:
diff changeset
   477
    {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   478
      assert(op->as_Op0() != NULL, "must be");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   479
      if (op->_info != NULL)           do_info(op->_info);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   480
      if (op->_result->is_valid())     do_output(op->_result);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   481
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   482
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   483
489c9b5090e2 Initial load
duke
parents:
diff changeset
   484
489c9b5090e2 Initial load
duke
parents:
diff changeset
   485
// LIR_OpLabel
489c9b5090e2 Initial load
duke
parents:
diff changeset
   486
    case lir_label:                    // result and info always invalid
489c9b5090e2 Initial load
duke
parents:
diff changeset
   487
    {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   488
      assert(op->as_OpLabel() != NULL, "must be");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   489
      assert(op->_info == NULL, "info not used by this instruction");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   490
      assert(op->_result->is_illegal(), "not used");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   491
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   492
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   493
489c9b5090e2 Initial load
duke
parents:
diff changeset
   494
489c9b5090e2 Initial load
duke
parents:
diff changeset
   495
// LIR_Op1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   496
    case lir_fxch:           // input always valid, result and info always invalid
489c9b5090e2 Initial load
duke
parents:
diff changeset
   497
    case lir_fld:            // input always valid, result and info always invalid
489c9b5090e2 Initial load
duke
parents:
diff changeset
   498
    case lir_ffree:          // input always valid, result and info always invalid
489c9b5090e2 Initial load
duke
parents:
diff changeset
   499
    case lir_push:           // input always valid, result and info always invalid
489c9b5090e2 Initial load
duke
parents:
diff changeset
   500
    case lir_pop:            // input always valid, result and info always invalid
489c9b5090e2 Initial load
duke
parents:
diff changeset
   501
    case lir_return:         // input always valid, result and info always invalid
489c9b5090e2 Initial load
duke
parents:
diff changeset
   502
    case lir_leal:           // input and result always valid, info always invalid
489c9b5090e2 Initial load
duke
parents:
diff changeset
   503
    case lir_neg:            // input and result always valid, info always invalid
489c9b5090e2 Initial load
duke
parents:
diff changeset
   504
    case lir_monaddr:        // input and result always valid, info always invalid
489c9b5090e2 Initial load
duke
parents:
diff changeset
   505
    case lir_null_check:     // input and info always valid, result always invalid
489c9b5090e2 Initial load
duke
parents:
diff changeset
   506
    case lir_move:           // input and result always valid, may have info
6453
970dc585ab63 6953144: Tiered compilation
iveresov
parents: 6176
diff changeset
   507
    case lir_pack64:         // input and result always valid
970dc585ab63 6953144: Tiered compilation
iveresov
parents: 6176
diff changeset
   508
    case lir_unpack64:       // input and result always valid
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   509
    case lir_prefetchr:      // input always valid, result and info always invalid
489c9b5090e2 Initial load
duke
parents:
diff changeset
   510
    case lir_prefetchw:      // input always valid, result and info always invalid
489c9b5090e2 Initial load
duke
parents:
diff changeset
   511
    {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   512
      assert(op->as_Op1() != NULL, "must be");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   513
      LIR_Op1* op1 = (LIR_Op1*)op;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   514
489c9b5090e2 Initial load
duke
parents:
diff changeset
   515
      if (op1->_info)                  do_info(op1->_info);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   516
      if (op1->_opr->is_valid())       do_input(op1->_opr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   517
      if (op1->_result->is_valid())    do_output(op1->_result);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   518
489c9b5090e2 Initial load
duke
parents:
diff changeset
   519
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   520
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   521
489c9b5090e2 Initial load
duke
parents:
diff changeset
   522
    case lir_safepoint:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   523
    {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   524
      assert(op->as_Op1() != NULL, "must be");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   525
      LIR_Op1* op1 = (LIR_Op1*)op;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   526
489c9b5090e2 Initial load
duke
parents:
diff changeset
   527
      assert(op1->_info != NULL, "");  do_info(op1->_info);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   528
      if (op1->_opr->is_valid())       do_temp(op1->_opr); // safepoints on SPARC need temporary register
489c9b5090e2 Initial load
duke
parents:
diff changeset
   529
      assert(op1->_result->is_illegal(), "safepoint does not produce value");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   530
489c9b5090e2 Initial load
duke
parents:
diff changeset
   531
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   532
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   533
489c9b5090e2 Initial load
duke
parents:
diff changeset
   534
// LIR_OpConvert;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   535
    case lir_convert:        // input and result always valid, info always invalid
489c9b5090e2 Initial load
duke
parents:
diff changeset
   536
    {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   537
      assert(op->as_OpConvert() != NULL, "must be");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   538
      LIR_OpConvert* opConvert = (LIR_OpConvert*)op;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   539
489c9b5090e2 Initial load
duke
parents:
diff changeset
   540
      assert(opConvert->_info == NULL, "must be");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   541
      if (opConvert->_opr->is_valid())       do_input(opConvert->_opr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   542
      if (opConvert->_result->is_valid())    do_output(opConvert->_result);
6176
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
   543
#ifdef PPC
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
   544
      if (opConvert->_tmp1->is_valid())      do_temp(opConvert->_tmp1);
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
   545
      if (opConvert->_tmp2->is_valid())      do_temp(opConvert->_tmp2);
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
   546
#endif
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   547
      do_stub(opConvert->_stub);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   548
489c9b5090e2 Initial load
duke
parents:
diff changeset
   549
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   550
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   551
489c9b5090e2 Initial load
duke
parents:
diff changeset
   552
// LIR_OpBranch;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   553
    case lir_branch:                   // may have info, input and result register always invalid
489c9b5090e2 Initial load
duke
parents:
diff changeset
   554
    case lir_cond_float_branch:        // may have info, input and result register always invalid
489c9b5090e2 Initial load
duke
parents:
diff changeset
   555
    {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   556
      assert(op->as_OpBranch() != NULL, "must be");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   557
      LIR_OpBranch* opBranch = (LIR_OpBranch*)op;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   558
489c9b5090e2 Initial load
duke
parents:
diff changeset
   559
      if (opBranch->_info != NULL)     do_info(opBranch->_info);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   560
      assert(opBranch->_result->is_illegal(), "not used");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   561
      if (opBranch->_stub != NULL)     opBranch->stub()->visit(this);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   562
489c9b5090e2 Initial load
duke
parents:
diff changeset
   563
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   564
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   565
489c9b5090e2 Initial load
duke
parents:
diff changeset
   566
489c9b5090e2 Initial load
duke
parents:
diff changeset
   567
// LIR_OpAllocObj
489c9b5090e2 Initial load
duke
parents:
diff changeset
   568
    case lir_alloc_object:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   569
    {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   570
      assert(op->as_OpAllocObj() != NULL, "must be");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   571
      LIR_OpAllocObj* opAllocObj = (LIR_OpAllocObj*)op;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   572
489c9b5090e2 Initial load
duke
parents:
diff changeset
   573
      if (opAllocObj->_info)                     do_info(opAllocObj->_info);
6176
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
   574
      if (opAllocObj->_opr->is_valid()) {        do_input(opAllocObj->_opr);
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
   575
                                                 do_temp(opAllocObj->_opr);
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
   576
                                        }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   577
      if (opAllocObj->_tmp1->is_valid())         do_temp(opAllocObj->_tmp1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   578
      if (opAllocObj->_tmp2->is_valid())         do_temp(opAllocObj->_tmp2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   579
      if (opAllocObj->_tmp3->is_valid())         do_temp(opAllocObj->_tmp3);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   580
      if (opAllocObj->_tmp4->is_valid())         do_temp(opAllocObj->_tmp4);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   581
      if (opAllocObj->_result->is_valid())       do_output(opAllocObj->_result);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   582
                                                 do_stub(opAllocObj->_stub);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   583
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   584
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   585
489c9b5090e2 Initial load
duke
parents:
diff changeset
   586
489c9b5090e2 Initial load
duke
parents:
diff changeset
   587
// LIR_OpRoundFP;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   588
    case lir_roundfp: {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   589
      assert(op->as_OpRoundFP() != NULL, "must be");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   590
      LIR_OpRoundFP* opRoundFP = (LIR_OpRoundFP*)op;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   591
489c9b5090e2 Initial load
duke
parents:
diff changeset
   592
      assert(op->_info == NULL, "info not used by this instruction");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   593
      assert(opRoundFP->_tmp->is_illegal(), "not used");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   594
      do_input(opRoundFP->_opr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   595
      do_output(opRoundFP->_result);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   596
489c9b5090e2 Initial load
duke
parents:
diff changeset
   597
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   598
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   599
489c9b5090e2 Initial load
duke
parents:
diff changeset
   600
489c9b5090e2 Initial load
duke
parents:
diff changeset
   601
// LIR_Op2
489c9b5090e2 Initial load
duke
parents:
diff changeset
   602
    case lir_cmp:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   603
    case lir_cmp_l2i:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   604
    case lir_ucmp_fd2i:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   605
    case lir_cmp_fd2i:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   606
    case lir_add:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   607
    case lir_sub:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   608
    case lir_mul:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   609
    case lir_div:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   610
    case lir_rem:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   611
    case lir_sqrt:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   612
    case lir_abs:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   613
    case lir_logic_and:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   614
    case lir_logic_or:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   615
    case lir_logic_xor:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   616
    case lir_shl:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   617
    case lir_shr:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   618
    case lir_ushr:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   619
    {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   620
      assert(op->as_Op2() != NULL, "must be");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   621
      LIR_Op2* op2 = (LIR_Op2*)op;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   622
489c9b5090e2 Initial load
duke
parents:
diff changeset
   623
      if (op2->_info)                     do_info(op2->_info);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   624
      if (op2->_opr1->is_valid())         do_input(op2->_opr1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   625
      if (op2->_opr2->is_valid())         do_input(op2->_opr2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   626
      if (op2->_tmp->is_valid())          do_temp(op2->_tmp);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   627
      if (op2->_result->is_valid())       do_output(op2->_result);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   628
489c9b5090e2 Initial load
duke
parents:
diff changeset
   629
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   630
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   631
489c9b5090e2 Initial load
duke
parents:
diff changeset
   632
    // special handling for cmove: right input operand must not be equal
489c9b5090e2 Initial load
duke
parents:
diff changeset
   633
    // to the result operand, otherwise the backend fails
489c9b5090e2 Initial load
duke
parents:
diff changeset
   634
    case lir_cmove:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   635
    {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   636
      assert(op->as_Op2() != NULL, "must be");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   637
      LIR_Op2* op2 = (LIR_Op2*)op;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   638
489c9b5090e2 Initial load
duke
parents:
diff changeset
   639
      assert(op2->_info == NULL && op2->_tmp->is_illegal(), "not used");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   640
      assert(op2->_opr1->is_valid() && op2->_opr2->is_valid() && op2->_result->is_valid(), "used");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   641
489c9b5090e2 Initial load
duke
parents:
diff changeset
   642
      do_input(op2->_opr1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   643
      do_input(op2->_opr2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   644
      do_temp(op2->_opr2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   645
      do_output(op2->_result);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   646
489c9b5090e2 Initial load
duke
parents:
diff changeset
   647
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   648
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   649
489c9b5090e2 Initial load
duke
parents:
diff changeset
   650
    // vspecial handling for strict operations: register input operands
489c9b5090e2 Initial load
duke
parents:
diff changeset
   651
    // as temp to guarantee that they do not overlap with other
489c9b5090e2 Initial load
duke
parents:
diff changeset
   652
    // registers
489c9b5090e2 Initial load
duke
parents:
diff changeset
   653
    case lir_mul_strictfp:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   654
    case lir_div_strictfp:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   655
    {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   656
      assert(op->as_Op2() != NULL, "must be");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   657
      LIR_Op2* op2 = (LIR_Op2*)op;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   658
489c9b5090e2 Initial load
duke
parents:
diff changeset
   659
      assert(op2->_info == NULL, "not used");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   660
      assert(op2->_opr1->is_valid(), "used");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   661
      assert(op2->_opr2->is_valid(), "used");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   662
      assert(op2->_result->is_valid(), "used");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   663
489c9b5090e2 Initial load
duke
parents:
diff changeset
   664
      do_input(op2->_opr1); do_temp(op2->_opr1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   665
      do_input(op2->_opr2); do_temp(op2->_opr2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   666
      if (op2->_tmp->is_valid()) do_temp(op2->_tmp);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   667
      do_output(op2->_result);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   668
489c9b5090e2 Initial load
duke
parents:
diff changeset
   669
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   670
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   671
5334
b2d040a8d375 6939930: exception unwind changes in 6919934 hurts compilation speed
never
parents: 5052
diff changeset
   672
    case lir_throw: {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   673
      assert(op->as_Op2() != NULL, "must be");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   674
      LIR_Op2* op2 = (LIR_Op2*)op;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   675
489c9b5090e2 Initial load
duke
parents:
diff changeset
   676
      if (op2->_info)                     do_info(op2->_info);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   677
      if (op2->_opr1->is_valid())         do_temp(op2->_opr1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   678
      if (op2->_opr2->is_valid())         do_input(op2->_opr2); // exception object is input parameter
489c9b5090e2 Initial load
duke
parents:
diff changeset
   679
      assert(op2->_result->is_illegal(), "no result");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   680
489c9b5090e2 Initial load
duke
parents:
diff changeset
   681
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   682
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   683
5334
b2d040a8d375 6939930: exception unwind changes in 6919934 hurts compilation speed
never
parents: 5052
diff changeset
   684
    case lir_unwind: {
b2d040a8d375 6939930: exception unwind changes in 6919934 hurts compilation speed
never
parents: 5052
diff changeset
   685
      assert(op->as_Op1() != NULL, "must be");
b2d040a8d375 6939930: exception unwind changes in 6919934 hurts compilation speed
never
parents: 5052
diff changeset
   686
      LIR_Op1* op1 = (LIR_Op1*)op;
b2d040a8d375 6939930: exception unwind changes in 6919934 hurts compilation speed
never
parents: 5052
diff changeset
   687
b2d040a8d375 6939930: exception unwind changes in 6919934 hurts compilation speed
never
parents: 5052
diff changeset
   688
      assert(op1->_info == NULL, "no info");
b2d040a8d375 6939930: exception unwind changes in 6919934 hurts compilation speed
never
parents: 5052
diff changeset
   689
      assert(op1->_opr->is_valid(), "exception oop");         do_input(op1->_opr);
b2d040a8d375 6939930: exception unwind changes in 6919934 hurts compilation speed
never
parents: 5052
diff changeset
   690
      assert(op1->_result->is_illegal(), "no result");
b2d040a8d375 6939930: exception unwind changes in 6919934 hurts compilation speed
never
parents: 5052
diff changeset
   691
b2d040a8d375 6939930: exception unwind changes in 6919934 hurts compilation speed
never
parents: 5052
diff changeset
   692
      break;
b2d040a8d375 6939930: exception unwind changes in 6919934 hurts compilation speed
never
parents: 5052
diff changeset
   693
    }
b2d040a8d375 6939930: exception unwind changes in 6919934 hurts compilation speed
never
parents: 5052
diff changeset
   694
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   695
489c9b5090e2 Initial load
duke
parents:
diff changeset
   696
    case lir_tan:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   697
    case lir_sin:
3800
3195b4844b5a 6855215: Calculation error (NaN) after about 1500 calculations
never
parents: 1066
diff changeset
   698
    case lir_cos:
3195b4844b5a 6855215: Calculation error (NaN) after about 1500 calculations
never
parents: 1066
diff changeset
   699
    case lir_log:
3195b4844b5a 6855215: Calculation error (NaN) after about 1500 calculations
never
parents: 1066
diff changeset
   700
    case lir_log10: {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   701
      assert(op->as_Op2() != NULL, "must be");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   702
      LIR_Op2* op2 = (LIR_Op2*)op;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   703
3800
3195b4844b5a 6855215: Calculation error (NaN) after about 1500 calculations
never
parents: 1066
diff changeset
   704
      // On x86 tan/sin/cos need two temporary fpu stack slots and
3195b4844b5a 6855215: Calculation error (NaN) after about 1500 calculations
never
parents: 1066
diff changeset
   705
      // log/log10 need one so handle opr2 and tmp as temp inputs.
3195b4844b5a 6855215: Calculation error (NaN) after about 1500 calculations
never
parents: 1066
diff changeset
   706
      // Register input operand as temp to guarantee that it doesn't
3195b4844b5a 6855215: Calculation error (NaN) after about 1500 calculations
never
parents: 1066
diff changeset
   707
      // overlap with the input.
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   708
      assert(op2->_info == NULL, "not used");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   709
      assert(op2->_opr1->is_valid(), "used");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   710
      do_input(op2->_opr1); do_temp(op2->_opr1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   711
489c9b5090e2 Initial load
duke
parents:
diff changeset
   712
      if (op2->_opr2->is_valid())         do_temp(op2->_opr2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   713
      if (op2->_tmp->is_valid())          do_temp(op2->_tmp);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   714
      if (op2->_result->is_valid())       do_output(op2->_result);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   715
489c9b5090e2 Initial load
duke
parents:
diff changeset
   716
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   717
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   718
489c9b5090e2 Initial load
duke
parents:
diff changeset
   719
489c9b5090e2 Initial load
duke
parents:
diff changeset
   720
// LIR_Op3
489c9b5090e2 Initial load
duke
parents:
diff changeset
   721
    case lir_idiv:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   722
    case lir_irem: {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   723
      assert(op->as_Op3() != NULL, "must be");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   724
      LIR_Op3* op3= (LIR_Op3*)op;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   725
489c9b5090e2 Initial load
duke
parents:
diff changeset
   726
      if (op3->_info)                     do_info(op3->_info);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   727
      if (op3->_opr1->is_valid())         do_input(op3->_opr1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   728
489c9b5090e2 Initial load
duke
parents:
diff changeset
   729
      // second operand is input and temp, so ensure that second operand
489c9b5090e2 Initial load
duke
parents:
diff changeset
   730
      // and third operand get not the same register
489c9b5090e2 Initial load
duke
parents:
diff changeset
   731
      if (op3->_opr2->is_valid())         do_input(op3->_opr2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   732
      if (op3->_opr2->is_valid())         do_temp(op3->_opr2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   733
      if (op3->_opr3->is_valid())         do_temp(op3->_opr3);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   734
489c9b5090e2 Initial load
duke
parents:
diff changeset
   735
      if (op3->_result->is_valid())       do_output(op3->_result);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   736
489c9b5090e2 Initial load
duke
parents:
diff changeset
   737
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   738
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   739
489c9b5090e2 Initial load
duke
parents:
diff changeset
   740
489c9b5090e2 Initial load
duke
parents:
diff changeset
   741
// LIR_OpJavaCall
489c9b5090e2 Initial load
duke
parents:
diff changeset
   742
    case lir_static_call:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   743
    case lir_optvirtual_call:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   744
    case lir_icvirtual_call:
5046
27e801a857cb 6919934: JSR 292 needs to support x86 C1
twisti
parents: 3800
diff changeset
   745
    case lir_virtual_call:
27e801a857cb 6919934: JSR 292 needs to support x86 C1
twisti
parents: 3800
diff changeset
   746
    case lir_dynamic_call: {
27e801a857cb 6919934: JSR 292 needs to support x86 C1
twisti
parents: 3800
diff changeset
   747
      LIR_OpJavaCall* opJavaCall = op->as_OpJavaCall();
27e801a857cb 6919934: JSR 292 needs to support x86 C1
twisti
parents: 3800
diff changeset
   748
      assert(opJavaCall != NULL, "must be");
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   749
489c9b5090e2 Initial load
duke
parents:
diff changeset
   750
      if (opJavaCall->_receiver->is_valid())     do_input(opJavaCall->_receiver);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   751
489c9b5090e2 Initial load
duke
parents:
diff changeset
   752
      // only visit register parameters
489c9b5090e2 Initial load
duke
parents:
diff changeset
   753
      int n = opJavaCall->_arguments->length();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   754
      for (int i = 0; i < n; i++) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   755
        if (!opJavaCall->_arguments->at(i)->is_pointer()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   756
          do_input(*opJavaCall->_arguments->adr_at(i));
489c9b5090e2 Initial load
duke
parents:
diff changeset
   757
        }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   758
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   759
489c9b5090e2 Initial load
duke
parents:
diff changeset
   760
      if (opJavaCall->_info)                     do_info(opJavaCall->_info);
5687
b862d1f189bd 6930772: JSR 292 needs to support SPARC C1
twisti
parents: 5334
diff changeset
   761
      if (opJavaCall->is_method_handle_invoke()) {
b862d1f189bd 6930772: JSR 292 needs to support SPARC C1
twisti
parents: 5334
diff changeset
   762
        opJavaCall->_method_handle_invoke_SP_save_opr = FrameMap::method_handle_invoke_SP_save_opr();
b862d1f189bd 6930772: JSR 292 needs to support SPARC C1
twisti
parents: 5334
diff changeset
   763
        do_temp(opJavaCall->_method_handle_invoke_SP_save_opr);
b862d1f189bd 6930772: JSR 292 needs to support SPARC C1
twisti
parents: 5334
diff changeset
   764
      }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   765
      do_call();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   766
      if (opJavaCall->_result->is_valid())       do_output(opJavaCall->_result);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   767
489c9b5090e2 Initial load
duke
parents:
diff changeset
   768
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   769
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   770
489c9b5090e2 Initial load
duke
parents:
diff changeset
   771
489c9b5090e2 Initial load
duke
parents:
diff changeset
   772
// LIR_OpRTCall
489c9b5090e2 Initial load
duke
parents:
diff changeset
   773
    case lir_rtcall: {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   774
      assert(op->as_OpRTCall() != NULL, "must be");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   775
      LIR_OpRTCall* opRTCall = (LIR_OpRTCall*)op;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   776
489c9b5090e2 Initial load
duke
parents:
diff changeset
   777
      // only visit register parameters
489c9b5090e2 Initial load
duke
parents:
diff changeset
   778
      int n = opRTCall->_arguments->length();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   779
      for (int i = 0; i < n; i++) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   780
        if (!opRTCall->_arguments->at(i)->is_pointer()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   781
          do_input(*opRTCall->_arguments->adr_at(i));
489c9b5090e2 Initial load
duke
parents:
diff changeset
   782
        }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   783
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   784
      if (opRTCall->_info)                     do_info(opRTCall->_info);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   785
      if (opRTCall->_tmp->is_valid())          do_temp(opRTCall->_tmp);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   786
      do_call();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   787
      if (opRTCall->_result->is_valid())       do_output(opRTCall->_result);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   788
489c9b5090e2 Initial load
duke
parents:
diff changeset
   789
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   790
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   791
489c9b5090e2 Initial load
duke
parents:
diff changeset
   792
489c9b5090e2 Initial load
duke
parents:
diff changeset
   793
// LIR_OpArrayCopy
489c9b5090e2 Initial load
duke
parents:
diff changeset
   794
    case lir_arraycopy: {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   795
      assert(op->as_OpArrayCopy() != NULL, "must be");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   796
      LIR_OpArrayCopy* opArrayCopy = (LIR_OpArrayCopy*)op;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   797
489c9b5090e2 Initial load
duke
parents:
diff changeset
   798
      assert(opArrayCopy->_result->is_illegal(), "unused");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   799
      assert(opArrayCopy->_src->is_valid(), "used");          do_input(opArrayCopy->_src);     do_temp(opArrayCopy->_src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   800
      assert(opArrayCopy->_src_pos->is_valid(), "used");      do_input(opArrayCopy->_src_pos); do_temp(opArrayCopy->_src_pos);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   801
      assert(opArrayCopy->_dst->is_valid(), "used");          do_input(opArrayCopy->_dst);     do_temp(opArrayCopy->_dst);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   802
      assert(opArrayCopy->_dst_pos->is_valid(), "used");      do_input(opArrayCopy->_dst_pos); do_temp(opArrayCopy->_dst_pos);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   803
      assert(opArrayCopy->_length->is_valid(), "used");       do_input(opArrayCopy->_length);  do_temp(opArrayCopy->_length);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   804
      assert(opArrayCopy->_tmp->is_valid(), "used");          do_temp(opArrayCopy->_tmp);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   805
      if (opArrayCopy->_info)                     do_info(opArrayCopy->_info);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   806
489c9b5090e2 Initial load
duke
parents:
diff changeset
   807
      // the implementation of arraycopy always has a call into the runtime
489c9b5090e2 Initial load
duke
parents:
diff changeset
   808
      do_call();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   809
489c9b5090e2 Initial load
duke
parents:
diff changeset
   810
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   811
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   812
489c9b5090e2 Initial load
duke
parents:
diff changeset
   813
489c9b5090e2 Initial load
duke
parents:
diff changeset
   814
// LIR_OpLock
489c9b5090e2 Initial load
duke
parents:
diff changeset
   815
    case lir_lock:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   816
    case lir_unlock: {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   817
      assert(op->as_OpLock() != NULL, "must be");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   818
      LIR_OpLock* opLock = (LIR_OpLock*)op;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   819
489c9b5090e2 Initial load
duke
parents:
diff changeset
   820
      if (opLock->_info)                          do_info(opLock->_info);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   821
489c9b5090e2 Initial load
duke
parents:
diff changeset
   822
      // TODO: check if these operands really have to be temp
489c9b5090e2 Initial load
duke
parents:
diff changeset
   823
      // (or if input is sufficient). This may have influence on the oop map!
489c9b5090e2 Initial load
duke
parents:
diff changeset
   824
      assert(opLock->_lock->is_valid(), "used");  do_temp(opLock->_lock);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   825
      assert(opLock->_hdr->is_valid(),  "used");  do_temp(opLock->_hdr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   826
      assert(opLock->_obj->is_valid(),  "used");  do_temp(opLock->_obj);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   827
489c9b5090e2 Initial load
duke
parents:
diff changeset
   828
      if (opLock->_scratch->is_valid())           do_temp(opLock->_scratch);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   829
      assert(opLock->_result->is_illegal(), "unused");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   830
489c9b5090e2 Initial load
duke
parents:
diff changeset
   831
      do_stub(opLock->_stub);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   832
489c9b5090e2 Initial load
duke
parents:
diff changeset
   833
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   834
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   835
489c9b5090e2 Initial load
duke
parents:
diff changeset
   836
489c9b5090e2 Initial load
duke
parents:
diff changeset
   837
// LIR_OpDelay
489c9b5090e2 Initial load
duke
parents:
diff changeset
   838
    case lir_delay_slot: {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   839
      assert(op->as_OpDelay() != NULL, "must be");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   840
      LIR_OpDelay* opDelay = (LIR_OpDelay*)op;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   841
489c9b5090e2 Initial load
duke
parents:
diff changeset
   842
      visit(opDelay->delay_op());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   843
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   844
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   845
489c9b5090e2 Initial load
duke
parents:
diff changeset
   846
// LIR_OpTypeCheck
489c9b5090e2 Initial load
duke
parents:
diff changeset
   847
    case lir_instanceof:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   848
    case lir_checkcast:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   849
    case lir_store_check: {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   850
      assert(op->as_OpTypeCheck() != NULL, "must be");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   851
      LIR_OpTypeCheck* opTypeCheck = (LIR_OpTypeCheck*)op;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   852
489c9b5090e2 Initial load
duke
parents:
diff changeset
   853
      if (opTypeCheck->_info_for_exception)       do_info(opTypeCheck->_info_for_exception);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   854
      if (opTypeCheck->_info_for_patch)           do_info(opTypeCheck->_info_for_patch);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   855
      if (opTypeCheck->_object->is_valid())       do_input(opTypeCheck->_object);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   856
      if (opTypeCheck->_array->is_valid())        do_input(opTypeCheck->_array);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   857
      if (opTypeCheck->_tmp1->is_valid())         do_temp(opTypeCheck->_tmp1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   858
      if (opTypeCheck->_tmp2->is_valid())         do_temp(opTypeCheck->_tmp2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   859
      if (opTypeCheck->_tmp3->is_valid())         do_temp(opTypeCheck->_tmp3);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   860
      if (opTypeCheck->_result->is_valid())       do_output(opTypeCheck->_result);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   861
                                                  do_stub(opTypeCheck->_stub);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   862
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   863
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   864
489c9b5090e2 Initial load
duke
parents:
diff changeset
   865
// LIR_OpCompareAndSwap
489c9b5090e2 Initial load
duke
parents:
diff changeset
   866
    case lir_cas_long:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   867
    case lir_cas_obj:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   868
    case lir_cas_int: {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   869
      assert(op->as_OpCompareAndSwap() != NULL, "must be");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   870
      LIR_OpCompareAndSwap* opCompareAndSwap = (LIR_OpCompareAndSwap*)op;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   871
6176
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
   872
      assert(opCompareAndSwap->_addr->is_valid(),      "used");
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
   873
      assert(opCompareAndSwap->_cmp_value->is_valid(), "used");
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
   874
      assert(opCompareAndSwap->_new_value->is_valid(), "used");
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   875
      if (opCompareAndSwap->_info)                    do_info(opCompareAndSwap->_info);
6176
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
   876
                                                      do_input(opCompareAndSwap->_addr);
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
   877
                                                      do_temp(opCompareAndSwap->_addr);
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
   878
                                                      do_input(opCompareAndSwap->_cmp_value);
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
   879
                                                      do_temp(opCompareAndSwap->_cmp_value);
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
   880
                                                      do_input(opCompareAndSwap->_new_value);
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
   881
                                                      do_temp(opCompareAndSwap->_new_value);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   882
      if (opCompareAndSwap->_tmp1->is_valid())        do_temp(opCompareAndSwap->_tmp1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   883
      if (opCompareAndSwap->_tmp2->is_valid())        do_temp(opCompareAndSwap->_tmp2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   884
      if (opCompareAndSwap->_result->is_valid())      do_output(opCompareAndSwap->_result);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   885
489c9b5090e2 Initial load
duke
parents:
diff changeset
   886
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   887
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   888
489c9b5090e2 Initial load
duke
parents:
diff changeset
   889
489c9b5090e2 Initial load
duke
parents:
diff changeset
   890
// LIR_OpAllocArray;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   891
    case lir_alloc_array: {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   892
      assert(op->as_OpAllocArray() != NULL, "must be");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   893
      LIR_OpAllocArray* opAllocArray = (LIR_OpAllocArray*)op;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   894
489c9b5090e2 Initial load
duke
parents:
diff changeset
   895
      if (opAllocArray->_info)                        do_info(opAllocArray->_info);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   896
      if (opAllocArray->_klass->is_valid())           do_input(opAllocArray->_klass); do_temp(opAllocArray->_klass);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   897
      if (opAllocArray->_len->is_valid())             do_input(opAllocArray->_len);   do_temp(opAllocArray->_len);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   898
      if (opAllocArray->_tmp1->is_valid())            do_temp(opAllocArray->_tmp1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   899
      if (opAllocArray->_tmp2->is_valid())            do_temp(opAllocArray->_tmp2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   900
      if (opAllocArray->_tmp3->is_valid())            do_temp(opAllocArray->_tmp3);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   901
      if (opAllocArray->_tmp4->is_valid())            do_temp(opAllocArray->_tmp4);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   902
      if (opAllocArray->_result->is_valid())          do_output(opAllocArray->_result);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   903
                                                      do_stub(opAllocArray->_stub);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   904
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   905
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   906
489c9b5090e2 Initial load
duke
parents:
diff changeset
   907
// LIR_OpProfileCall:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   908
    case lir_profile_call: {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   909
      assert(op->as_OpProfileCall() != NULL, "must be");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   910
      LIR_OpProfileCall* opProfileCall = (LIR_OpProfileCall*)op;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   911
489c9b5090e2 Initial load
duke
parents:
diff changeset
   912
      if (opProfileCall->_recv->is_valid())              do_temp(opProfileCall->_recv);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   913
      assert(opProfileCall->_mdo->is_valid(), "used");   do_temp(opProfileCall->_mdo);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   914
      assert(opProfileCall->_tmp1->is_valid(), "used");  do_temp(opProfileCall->_tmp1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   915
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   916
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   917
  default:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   918
    ShouldNotReachHere();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   919
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   920
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   921
489c9b5090e2 Initial load
duke
parents:
diff changeset
   922
489c9b5090e2 Initial load
duke
parents:
diff changeset
   923
void LIR_OpVisitState::do_stub(CodeStub* stub) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   924
  if (stub != NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   925
    stub->visit(this);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   926
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   927
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   928
489c9b5090e2 Initial load
duke
parents:
diff changeset
   929
XHandlers* LIR_OpVisitState::all_xhandler() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   930
  XHandlers* result = NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   931
489c9b5090e2 Initial load
duke
parents:
diff changeset
   932
  int i;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   933
  for (i = 0; i < info_count(); i++) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   934
    if (info_at(i)->exception_handlers() != NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   935
      result = info_at(i)->exception_handlers();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   936
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   937
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   938
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   939
489c9b5090e2 Initial load
duke
parents:
diff changeset
   940
#ifdef ASSERT
489c9b5090e2 Initial load
duke
parents:
diff changeset
   941
  for (i = 0; i < info_count(); i++) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   942
    assert(info_at(i)->exception_handlers() == NULL ||
489c9b5090e2 Initial load
duke
parents:
diff changeset
   943
           info_at(i)->exception_handlers() == result,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   944
           "only one xhandler list allowed per LIR-operation");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   945
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   946
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
   947
489c9b5090e2 Initial load
duke
parents:
diff changeset
   948
  if (result != NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   949
    return result;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   950
  } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   951
    return new XHandlers();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   952
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   953
489c9b5090e2 Initial load
duke
parents:
diff changeset
   954
  return result;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   955
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   956
489c9b5090e2 Initial load
duke
parents:
diff changeset
   957
489c9b5090e2 Initial load
duke
parents:
diff changeset
   958
#ifdef ASSERT
489c9b5090e2 Initial load
duke
parents:
diff changeset
   959
bool LIR_OpVisitState::no_operands(LIR_Op* op) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   960
  visit(op);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   961
489c9b5090e2 Initial load
duke
parents:
diff changeset
   962
  return opr_count(inputMode) == 0 &&
489c9b5090e2 Initial load
duke
parents:
diff changeset
   963
         opr_count(outputMode) == 0 &&
489c9b5090e2 Initial load
duke
parents:
diff changeset
   964
         opr_count(tempMode) == 0 &&
489c9b5090e2 Initial load
duke
parents:
diff changeset
   965
         info_count() == 0 &&
489c9b5090e2 Initial load
duke
parents:
diff changeset
   966
         !has_call() &&
489c9b5090e2 Initial load
duke
parents:
diff changeset
   967
         !has_slow_case();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   968
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   969
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
   970
489c9b5090e2 Initial load
duke
parents:
diff changeset
   971
//---------------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
   972
489c9b5090e2 Initial load
duke
parents:
diff changeset
   973
489c9b5090e2 Initial load
duke
parents:
diff changeset
   974
void LIR_OpJavaCall::emit_code(LIR_Assembler* masm) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   975
  masm->emit_call(this);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   976
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   977
489c9b5090e2 Initial load
duke
parents:
diff changeset
   978
void LIR_OpRTCall::emit_code(LIR_Assembler* masm) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   979
  masm->emit_rtcall(this);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   980
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   981
489c9b5090e2 Initial load
duke
parents:
diff changeset
   982
void LIR_OpLabel::emit_code(LIR_Assembler* masm) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   983
  masm->emit_opLabel(this);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   984
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   985
489c9b5090e2 Initial load
duke
parents:
diff changeset
   986
void LIR_OpArrayCopy::emit_code(LIR_Assembler* masm) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   987
  masm->emit_arraycopy(this);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   988
  masm->emit_code_stub(stub());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   989
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   990
489c9b5090e2 Initial load
duke
parents:
diff changeset
   991
void LIR_Op0::emit_code(LIR_Assembler* masm) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   992
  masm->emit_op0(this);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   993
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   994
489c9b5090e2 Initial load
duke
parents:
diff changeset
   995
void LIR_Op1::emit_code(LIR_Assembler* masm) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   996
  masm->emit_op1(this);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   997
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   998
489c9b5090e2 Initial load
duke
parents:
diff changeset
   999
void LIR_OpAllocObj::emit_code(LIR_Assembler* masm) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1000
  masm->emit_alloc_obj(this);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1001
  masm->emit_code_stub(stub());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1002
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1003
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1004
void LIR_OpBranch::emit_code(LIR_Assembler* masm) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1005
  masm->emit_opBranch(this);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1006
  if (stub()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1007
    masm->emit_code_stub(stub());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1008
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1009
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1010
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1011
void LIR_OpConvert::emit_code(LIR_Assembler* masm) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1012
  masm->emit_opConvert(this);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1013
  if (stub() != NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1014
    masm->emit_code_stub(stub());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1015
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1016
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1017
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1018
void LIR_Op2::emit_code(LIR_Assembler* masm) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1019
  masm->emit_op2(this);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1020
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1021
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1022
void LIR_OpAllocArray::emit_code(LIR_Assembler* masm) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1023
  masm->emit_alloc_array(this);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1024
  masm->emit_code_stub(stub());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1025
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1026
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1027
void LIR_OpTypeCheck::emit_code(LIR_Assembler* masm) {
6461
cfc616b49f58 6919069: client compiler needs to capture more profile information for tiered work
iveresov
parents: 6453
diff changeset
  1028
  masm->emit_opTypeCheck(this);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1029
  if (stub()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1030
    masm->emit_code_stub(stub());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1031
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1032
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1033
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1034
void LIR_OpCompareAndSwap::emit_code(LIR_Assembler* masm) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1035
  masm->emit_compare_and_swap(this);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1036
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1037
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1038
void LIR_Op3::emit_code(LIR_Assembler* masm) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1039
  masm->emit_op3(this);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1040
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1041
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1042
void LIR_OpLock::emit_code(LIR_Assembler* masm) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1043
  masm->emit_lock(this);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1044
  if (stub()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1045
    masm->emit_code_stub(stub());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1046
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1047
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1048
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1049
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1050
void LIR_OpDelay::emit_code(LIR_Assembler* masm) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1051
  masm->emit_delay(this);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1052
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1053
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1054
void LIR_OpProfileCall::emit_code(LIR_Assembler* masm) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1055
  masm->emit_profile_call(this);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1056
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1057
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1058
// LIR_List
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1059
LIR_List::LIR_List(Compilation* compilation, BlockBegin* block)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1060
  : _operations(8)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1061
  , _compilation(compilation)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1062
#ifndef PRODUCT
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1063
  , _block(block)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1064
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1065
#ifdef ASSERT
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1066
  , _file(NULL)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1067
  , _line(0)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1068
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1069
{ }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1070
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1071
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1072
#ifdef ASSERT
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1073
void LIR_List::set_file_and_line(const char * file, int line) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1074
  const char * f = strrchr(file, '/');
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1075
  if (f == NULL) f = strrchr(file, '\\');
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1076
  if (f == NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1077
    f = file;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1078
  } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1079
    f++;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1080
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1081
  _file = f;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1082
  _line = line;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1083
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1084
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1085
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1086
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1087
void LIR_List::append(LIR_InsertionBuffer* buffer) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1088
  assert(this == buffer->lir_list(), "wrong lir list");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1089
  const int n = _operations.length();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1090
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1091
  if (buffer->number_of_ops() > 0) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1092
    // increase size of instructions list
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1093
    _operations.at_grow(n + buffer->number_of_ops() - 1, NULL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1094
    // insert ops from buffer into instructions list
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1095
    int op_index = buffer->number_of_ops() - 1;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1096
    int ip_index = buffer->number_of_insertion_points() - 1;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1097
    int from_index = n - 1;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1098
    int to_index = _operations.length() - 1;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1099
    for (; ip_index >= 0; ip_index --) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1100
      int index = buffer->index_at(ip_index);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1101
      // make room after insertion point
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1102
      while (index < from_index) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1103
        _operations.at_put(to_index --, _operations.at(from_index --));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1104
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1105
      // insert ops from buffer
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1106
      for (int i = buffer->count_at(ip_index); i > 0; i --) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1107
        _operations.at_put(to_index --, buffer->op_at(op_index --));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1108
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1109
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1110
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1111
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1112
  buffer->finish();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1113
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1114
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1115
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1116
void LIR_List::oop2reg_patch(jobject o, LIR_Opr reg, CodeEmitInfo* info) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1117
  append(new LIR_Op1(lir_move, LIR_OprFact::oopConst(o),  reg, T_OBJECT, lir_patch_normal, info));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1118
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1119
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1120
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1121
void LIR_List::load(LIR_Address* addr, LIR_Opr src, CodeEmitInfo* info, LIR_PatchCode patch_code) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1122
  append(new LIR_Op1(
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1123
            lir_move,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1124
            LIR_OprFact::address(addr),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1125
            src,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1126
            addr->type(),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1127
            patch_code,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1128
            info));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1129
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1130
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1131
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1132
void LIR_List::volatile_load_mem_reg(LIR_Address* address, LIR_Opr dst, CodeEmitInfo* info, LIR_PatchCode patch_code) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1133
  append(new LIR_Op1(
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1134
            lir_move,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1135
            LIR_OprFact::address(address),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1136
            dst,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1137
            address->type(),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1138
            patch_code,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1139
            info, lir_move_volatile));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1140
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1141
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1142
void LIR_List::volatile_load_unsafe_reg(LIR_Opr base, LIR_Opr offset, LIR_Opr dst, BasicType type, CodeEmitInfo* info, LIR_PatchCode patch_code) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1143
  append(new LIR_Op1(
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1144
            lir_move,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1145
            LIR_OprFact::address(new LIR_Address(base, offset, type)),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1146
            dst,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1147
            type,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1148
            patch_code,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1149
            info, lir_move_volatile));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1150
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1151
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1152
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1153
void LIR_List::prefetch(LIR_Address* addr, bool is_store) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1154
  append(new LIR_Op1(
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1155
            is_store ? lir_prefetchw : lir_prefetchr,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1156
            LIR_OprFact::address(addr)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1157
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1158
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1159
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1160
void LIR_List::store_mem_int(jint v, LIR_Opr base, int offset_in_bytes, BasicType type, CodeEmitInfo* info, LIR_PatchCode patch_code) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1161
  append(new LIR_Op1(
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1162
            lir_move,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1163
            LIR_OprFact::intConst(v),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1164
            LIR_OprFact::address(new LIR_Address(base, offset_in_bytes, type)),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1165
            type,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1166
            patch_code,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1167
            info));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1168
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1169
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1170
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1171
void LIR_List::store_mem_oop(jobject o, LIR_Opr base, int offset_in_bytes, BasicType type, CodeEmitInfo* info, LIR_PatchCode patch_code) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1172
  append(new LIR_Op1(
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1173
            lir_move,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1174
            LIR_OprFact::oopConst(o),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1175
            LIR_OprFact::address(new LIR_Address(base, offset_in_bytes, type)),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1176
            type,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1177
            patch_code,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1178
            info));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1179
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1180
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1181
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1182
void LIR_List::store(LIR_Opr src, LIR_Address* addr, CodeEmitInfo* info, LIR_PatchCode patch_code) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1183
  append(new LIR_Op1(
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1184
            lir_move,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1185
            src,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1186
            LIR_OprFact::address(addr),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1187
            addr->type(),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1188
            patch_code,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1189
            info));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1190
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1191
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1192
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1193
void LIR_List::volatile_store_mem_reg(LIR_Opr src, LIR_Address* addr, CodeEmitInfo* info, LIR_PatchCode patch_code) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1194
  append(new LIR_Op1(
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1195
            lir_move,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1196
            src,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1197
            LIR_OprFact::address(addr),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1198
            addr->type(),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1199
            patch_code,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1200
            info,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1201
            lir_move_volatile));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1202
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1203
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1204
void LIR_List::volatile_store_unsafe_reg(LIR_Opr src, LIR_Opr base, LIR_Opr offset, BasicType type, CodeEmitInfo* info, LIR_PatchCode patch_code) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1205
  append(new LIR_Op1(
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1206
            lir_move,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1207
            src,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1208
            LIR_OprFact::address(new LIR_Address(base, offset, type)),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1209
            type,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1210
            patch_code,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1211
            info, lir_move_volatile));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1212
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1213
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1214
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1215
void LIR_List::idiv(LIR_Opr left, LIR_Opr right, LIR_Opr res, LIR_Opr tmp, CodeEmitInfo* info) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1216
  append(new LIR_Op3(
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1217
                    lir_idiv,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1218
                    left,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1219
                    right,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1220
                    tmp,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1221
                    res,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1222
                    info));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1223
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1224
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1225
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1226
void LIR_List::idiv(LIR_Opr left, int right, LIR_Opr res, LIR_Opr tmp, CodeEmitInfo* info) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1227
  append(new LIR_Op3(
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1228
                    lir_idiv,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1229
                    left,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1230
                    LIR_OprFact::intConst(right),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1231
                    tmp,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1232
                    res,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1233
                    info));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1234
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1235
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1236
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1237
void LIR_List::irem(LIR_Opr left, LIR_Opr right, LIR_Opr res, LIR_Opr tmp, CodeEmitInfo* info) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1238
  append(new LIR_Op3(
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1239
                    lir_irem,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1240
                    left,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1241
                    right,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1242
                    tmp,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1243
                    res,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1244
                    info));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1245
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1246
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1247
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1248
void LIR_List::irem(LIR_Opr left, int right, LIR_Opr res, LIR_Opr tmp, CodeEmitInfo* info) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1249
  append(new LIR_Op3(
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1250
                    lir_irem,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1251
                    left,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1252
                    LIR_OprFact::intConst(right),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1253
                    tmp,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1254
                    res,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1255
                    info));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1256
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1257
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1258
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1259
void LIR_List::cmp_mem_int(LIR_Condition condition, LIR_Opr base, int disp, int c, CodeEmitInfo* info) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1260
  append(new LIR_Op2(
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1261
                    lir_cmp,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1262
                    condition,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1263
                    LIR_OprFact::address(new LIR_Address(base, disp, T_INT)),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1264
                    LIR_OprFact::intConst(c),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1265
                    info));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1266
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1267
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1268
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1269
void LIR_List::cmp_reg_mem(LIR_Condition condition, LIR_Opr reg, LIR_Address* addr, CodeEmitInfo* info) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1270
  append(new LIR_Op2(
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1271
                    lir_cmp,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1272
                    condition,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1273
                    reg,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1274
                    LIR_OprFact::address(addr),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1275
                    info));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1276
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1277
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1278
void LIR_List::allocate_object(LIR_Opr dst, LIR_Opr t1, LIR_Opr t2, LIR_Opr t3, LIR_Opr t4,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1279
                               int header_size, int object_size, LIR_Opr klass, bool init_check, CodeStub* stub) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1280
  append(new LIR_OpAllocObj(
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1281
                           klass,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1282
                           dst,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1283
                           t1,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1284
                           t2,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1285
                           t3,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1286
                           t4,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1287
                           header_size,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1288
                           object_size,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1289
                           init_check,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1290
                           stub));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1291
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1292
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1293
void LIR_List::allocate_array(LIR_Opr dst, LIR_Opr len, LIR_Opr t1,LIR_Opr t2, LIR_Opr t3,LIR_Opr t4, BasicType type, LIR_Opr klass, CodeStub* stub) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1294
  append(new LIR_OpAllocArray(
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1295
                           klass,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1296
                           len,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1297
                           dst,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1298
                           t1,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1299
                           t2,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1300
                           t3,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1301
                           t4,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1302
                           type,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1303
                           stub));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1304
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1305
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1306
void LIR_List::shift_left(LIR_Opr value, LIR_Opr count, LIR_Opr dst, LIR_Opr tmp) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1307
 append(new LIR_Op2(
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1308
                    lir_shl,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1309
                    value,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1310
                    count,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1311
                    dst,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1312
                    tmp));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1313
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1314
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1315
void LIR_List::shift_right(LIR_Opr value, LIR_Opr count, LIR_Opr dst, LIR_Opr tmp) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1316
 append(new LIR_Op2(
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1317
                    lir_shr,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1318
                    value,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1319
                    count,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1320
                    dst,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1321
                    tmp));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1322
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1323
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1324
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1325
void LIR_List::unsigned_shift_right(LIR_Opr value, LIR_Opr count, LIR_Opr dst, LIR_Opr tmp) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1326
 append(new LIR_Op2(
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1327
                    lir_ushr,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1328
                    value,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1329
                    count,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1330
                    dst,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1331
                    tmp));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1332
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1333
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1334
void LIR_List::fcmp2int(LIR_Opr left, LIR_Opr right, LIR_Opr dst, bool is_unordered_less) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1335
  append(new LIR_Op2(is_unordered_less ? lir_ucmp_fd2i : lir_cmp_fd2i,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1336
                     left,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1337
                     right,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1338
                     dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1339
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1340
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1341
void LIR_List::lock_object(LIR_Opr hdr, LIR_Opr obj, LIR_Opr lock, LIR_Opr scratch, CodeStub* stub, CodeEmitInfo* info) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1342
  append(new LIR_OpLock(
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1343
                    lir_lock,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1344
                    hdr,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1345
                    obj,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1346
                    lock,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1347
                    scratch,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1348
                    stub,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1349
                    info));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1350
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1351
6176
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
  1352
void LIR_List::unlock_object(LIR_Opr hdr, LIR_Opr obj, LIR_Opr lock, LIR_Opr scratch, CodeStub* stub) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1353
  append(new LIR_OpLock(
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1354
                    lir_unlock,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1355
                    hdr,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1356
                    obj,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1357
                    lock,
6176
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
  1358
                    scratch,
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1359
                    stub,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1360
                    NULL));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1361
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1362
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1363
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1364
void check_LIR() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1365
  // cannot do the proper checking as PRODUCT and other modes return different results
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1366
  // guarantee(sizeof(LIR_OprDesc) == wordSize, "may not have a v-table");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1367
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1368
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1369
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1370
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1371
void LIR_List::checkcast (LIR_Opr result, LIR_Opr object, ciKlass* klass,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1372
                          LIR_Opr tmp1, LIR_Opr tmp2, LIR_Opr tmp3, bool fast_check,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1373
                          CodeEmitInfo* info_for_exception, CodeEmitInfo* info_for_patch, CodeStub* stub,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1374
                          ciMethod* profiled_method, int profiled_bci) {
6453
970dc585ab63 6953144: Tiered compilation
iveresov
parents: 6176
diff changeset
  1375
  LIR_OpTypeCheck* c = new LIR_OpTypeCheck(lir_checkcast, result, object, klass,
970dc585ab63 6953144: Tiered compilation
iveresov
parents: 6176
diff changeset
  1376
                                           tmp1, tmp2, tmp3, fast_check, info_for_exception, info_for_patch, stub);
970dc585ab63 6953144: Tiered compilation
iveresov
parents: 6176
diff changeset
  1377
  if (profiled_method != NULL) {
970dc585ab63 6953144: Tiered compilation
iveresov
parents: 6176
diff changeset
  1378
    c->set_profiled_method(profiled_method);
970dc585ab63 6953144: Tiered compilation
iveresov
parents: 6176
diff changeset
  1379
    c->set_profiled_bci(profiled_bci);
970dc585ab63 6953144: Tiered compilation
iveresov
parents: 6176
diff changeset
  1380
    c->set_should_profile(true);
970dc585ab63 6953144: Tiered compilation
iveresov
parents: 6176
diff changeset
  1381
  }
970dc585ab63 6953144: Tiered compilation
iveresov
parents: 6176
diff changeset
  1382
  append(c);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1383
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1384
6461
cfc616b49f58 6919069: client compiler needs to capture more profile information for tiered work
iveresov
parents: 6453
diff changeset
  1385
void LIR_List::instanceof(LIR_Opr result, LIR_Opr object, ciKlass* klass, LIR_Opr tmp1, LIR_Opr tmp2, LIR_Opr tmp3, bool fast_check, CodeEmitInfo* info_for_patch, ciMethod* profiled_method, int profiled_bci) {
cfc616b49f58 6919069: client compiler needs to capture more profile information for tiered work
iveresov
parents: 6453
diff changeset
  1386
  LIR_OpTypeCheck* c = new LIR_OpTypeCheck(lir_instanceof, result, object, klass, tmp1, tmp2, tmp3, fast_check, NULL, info_for_patch, NULL);
cfc616b49f58 6919069: client compiler needs to capture more profile information for tiered work
iveresov
parents: 6453
diff changeset
  1387
  if (profiled_method != NULL) {
cfc616b49f58 6919069: client compiler needs to capture more profile information for tiered work
iveresov
parents: 6453
diff changeset
  1388
    c->set_profiled_method(profiled_method);
cfc616b49f58 6919069: client compiler needs to capture more profile information for tiered work
iveresov
parents: 6453
diff changeset
  1389
    c->set_profiled_bci(profiled_bci);
cfc616b49f58 6919069: client compiler needs to capture more profile information for tiered work
iveresov
parents: 6453
diff changeset
  1390
    c->set_should_profile(true);
cfc616b49f58 6919069: client compiler needs to capture more profile information for tiered work
iveresov
parents: 6453
diff changeset
  1391
  }
cfc616b49f58 6919069: client compiler needs to capture more profile information for tiered work
iveresov
parents: 6453
diff changeset
  1392
  append(c);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1393
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1394
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1395
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1396
void LIR_List::store_check(LIR_Opr object, LIR_Opr array, LIR_Opr tmp1, LIR_Opr tmp2, LIR_Opr tmp3, CodeEmitInfo* info_for_exception) {
6453
970dc585ab63 6953144: Tiered compilation
iveresov
parents: 6176
diff changeset
  1397
  append(new LIR_OpTypeCheck(lir_store_check, object, array, tmp1, tmp2, tmp3, info_for_exception));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1398
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1399
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1400
6176
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
  1401
void LIR_List::cas_long(LIR_Opr addr, LIR_Opr cmp_value, LIR_Opr new_value,
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
  1402
                        LIR_Opr t1, LIR_Opr t2, LIR_Opr result) {
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
  1403
  append(new LIR_OpCompareAndSwap(lir_cas_long, addr, cmp_value, new_value, t1, t2, result));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1404
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1405
6176
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
  1406
void LIR_List::cas_obj(LIR_Opr addr, LIR_Opr cmp_value, LIR_Opr new_value,
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
  1407
                       LIR_Opr t1, LIR_Opr t2, LIR_Opr result) {
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
  1408
  append(new LIR_OpCompareAndSwap(lir_cas_obj, addr, cmp_value, new_value, t1, t2, result));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1409
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1410
6176
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
  1411
void LIR_List::cas_int(LIR_Opr addr, LIR_Opr cmp_value, LIR_Opr new_value,
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
  1412
                       LIR_Opr t1, LIR_Opr t2, LIR_Opr result) {
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
  1413
  append(new LIR_OpCompareAndSwap(lir_cas_int, addr, cmp_value, new_value, t1, t2, result));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1414
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1415
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1416
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1417
#ifdef PRODUCT
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1418
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1419
void print_LIR(BlockList* blocks) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1420
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1421
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1422
#else
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1423
// LIR_OprDesc
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1424
void LIR_OprDesc::print() const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1425
  print(tty);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1426
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1427
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1428
void LIR_OprDesc::print(outputStream* out) const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1429
  if (is_illegal()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1430
    return;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1431
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1432
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1433
  out->print("[");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1434
  if (is_pointer()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1435
    pointer()->print_value_on(out);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1436
  } else if (is_single_stack()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1437
    out->print("stack:%d", single_stack_ix());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1438
  } else if (is_double_stack()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1439
    out->print("dbl_stack:%d",double_stack_ix());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1440
  } else if (is_virtual()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1441
    out->print("R%d", vreg_number());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1442
  } else if (is_single_cpu()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1443
    out->print(as_register()->name());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1444
  } else if (is_double_cpu()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1445
    out->print(as_register_hi()->name());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1446
    out->print(as_register_lo()->name());
1066
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 670
diff changeset
  1447
#if defined(X86)
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1448
  } else if (is_single_xmm()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1449
    out->print(as_xmm_float_reg()->name());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1450
  } else if (is_double_xmm()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1451
    out->print(as_xmm_double_reg()->name());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1452
  } else if (is_single_fpu()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1453
    out->print("fpu%d", fpu_regnr());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1454
  } else if (is_double_fpu()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1455
    out->print("fpu%d", fpu_regnrLo());
6176
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
  1456
#elif defined(ARM)
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
  1457
  } else if (is_single_fpu()) {
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
  1458
    out->print("s%d", fpu_regnr());
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
  1459
  } else if (is_double_fpu()) {
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
  1460
    out->print("d%d", fpu_regnrLo() >> 1);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1461
#else
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1462
  } else if (is_single_fpu()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1463
    out->print(as_float_reg()->name());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1464
  } else if (is_double_fpu()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1465
    out->print(as_double_reg()->name());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1466
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1467
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1468
  } else if (is_illegal()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1469
    out->print("-");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1470
  } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1471
    out->print("Unknown Operand");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1472
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1473
  if (!is_illegal()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1474
    out->print("|%c", type_char());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1475
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1476
  if (is_register() && is_last_use()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1477
    out->print("(last_use)");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1478
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1479
  out->print("]");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1480
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1481
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1482
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1483
// LIR_Address
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1484
void LIR_Const::print_value_on(outputStream* out) const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1485
  switch (type()) {
5048
c31b6243f37e 6932496: c1: deoptimization of jsr subroutine fails on sparcv9
roland
parents: 5046
diff changeset
  1486
    case T_ADDRESS:out->print("address:%d",as_jint());          break;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1487
    case T_INT:    out->print("int:%d",   as_jint());           break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1488
    case T_LONG:   out->print("lng:%lld", as_jlong());          break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1489
    case T_FLOAT:  out->print("flt:%f",   as_jfloat());         break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1490
    case T_DOUBLE: out->print("dbl:%f",   as_jdouble());        break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1491
    case T_OBJECT: out->print("obj:0x%x", as_jobject());        break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1492
    default:       out->print("%3d:0x%x",type(), as_jdouble()); break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1493
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1494
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1495
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1496
// LIR_Address
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1497
void LIR_Address::print_value_on(outputStream* out) const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1498
  out->print("Base:"); _base->print(out);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1499
  if (!_index->is_illegal()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1500
    out->print(" Index:"); _index->print(out);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1501
    switch (scale()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1502
    case times_1: break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1503
    case times_2: out->print(" * 2"); break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1504
    case times_4: out->print(" * 4"); break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1505
    case times_8: out->print(" * 8"); break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1506
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1507
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1508
  out->print(" Disp: %d", _disp);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1509
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1510
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1511
// debug output of block header without InstructionPrinter
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1512
//       (because phi functions are not necessary for LIR)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1513
static void print_block(BlockBegin* x) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1514
  // print block id
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1515
  BlockEnd* end = x->end();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1516
  tty->print("B%d ", x->block_id());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1517
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1518
  // print flags
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1519
  if (x->is_set(BlockBegin::std_entry_flag))               tty->print("std ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1520
  if (x->is_set(BlockBegin::osr_entry_flag))               tty->print("osr ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1521
  if (x->is_set(BlockBegin::exception_entry_flag))         tty->print("ex ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1522
  if (x->is_set(BlockBegin::subroutine_entry_flag))        tty->print("jsr ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1523
  if (x->is_set(BlockBegin::backward_branch_target_flag))  tty->print("bb ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1524
  if (x->is_set(BlockBegin::linear_scan_loop_header_flag)) tty->print("lh ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1525
  if (x->is_set(BlockBegin::linear_scan_loop_end_flag))    tty->print("le ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1526
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1527
  // print block bci range
6745
a34ef8968a84 6986046: C1 valuestack cleanup
roland
parents: 6742
diff changeset
  1528
  tty->print("[%d, %d] ", x->bci(), (end == NULL ? -1 : end->printable_bci()));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1529
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1530
  // print predecessors and successors
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1531
  if (x->number_of_preds() > 0) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1532
    tty->print("preds: ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1533
    for (int i = 0; i < x->number_of_preds(); i ++) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1534
      tty->print("B%d ", x->pred_at(i)->block_id());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1535
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1536
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1537
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1538
  if (x->number_of_sux() > 0) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1539
    tty->print("sux: ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1540
    for (int i = 0; i < x->number_of_sux(); i ++) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1541
      tty->print("B%d ", x->sux_at(i)->block_id());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1542
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1543
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1544
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1545
  // print exception handlers
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1546
  if (x->number_of_exception_handlers() > 0) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1547
    tty->print("xhandler: ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1548
    for (int i = 0; i < x->number_of_exception_handlers();  i++) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1549
      tty->print("B%d ", x->exception_handler_at(i)->block_id());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1550
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1551
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1552
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1553
  tty->cr();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1554
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1555
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1556
void print_LIR(BlockList* blocks) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1557
  tty->print_cr("LIR:");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1558
  int i;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1559
  for (i = 0; i < blocks->length(); i++) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1560
    BlockBegin* bb = blocks->at(i);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1561
    print_block(bb);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1562
    tty->print("__id_Instruction___________________________________________"); tty->cr();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1563
    bb->lir()->print_instructions();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1564
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1565
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1566
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1567
void LIR_List::print_instructions() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1568
  for (int i = 0; i < _operations.length(); i++) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1569
    _operations.at(i)->print(); tty->cr();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1570
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1571
  tty->cr();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1572
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1573
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1574
// LIR_Ops printing routines
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1575
// LIR_Op
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1576
void LIR_Op::print_on(outputStream* out) const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1577
  if (id() != -1 || PrintCFGToFile) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1578
    out->print("%4d ", id());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1579
  } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1580
    out->print("     ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1581
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1582
  out->print(name()); out->print(" ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1583
  print_instr(out);
6745
a34ef8968a84 6986046: C1 valuestack cleanup
roland
parents: 6742
diff changeset
  1584
  if (info() != NULL) out->print(" [bci:%d]", info()->stack()->bci());
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1585
#ifdef ASSERT
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1586
  if (Verbose && _file != NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1587
    out->print(" (%s:%d)", _file, _line);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1588
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1589
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1590
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1591
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1592
const char * LIR_Op::name() const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1593
  const char* s = NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1594
  switch(code()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1595
     // LIR_Op0
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1596
     case lir_membar:                s = "membar";        break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1597
     case lir_membar_acquire:        s = "membar_acquire"; break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1598
     case lir_membar_release:        s = "membar_release"; break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1599
     case lir_word_align:            s = "word_align";    break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1600
     case lir_label:                 s = "label";         break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1601
     case lir_nop:                   s = "nop";           break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1602
     case lir_backwardbranch_target: s = "backbranch";    break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1603
     case lir_std_entry:             s = "std_entry";     break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1604
     case lir_osr_entry:             s = "osr_entry";     break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1605
     case lir_build_frame:           s = "build_frm";     break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1606
     case lir_fpop_raw:              s = "fpop_raw";      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1607
     case lir_24bit_FPU:             s = "24bit_FPU";     break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1608
     case lir_reset_FPU:             s = "reset_FPU";     break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1609
     case lir_breakpoint:            s = "breakpoint";    break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1610
     case lir_get_thread:            s = "get_thread";    break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1611
     // LIR_Op1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1612
     case lir_fxch:                  s = "fxch";          break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1613
     case lir_fld:                   s = "fld";           break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1614
     case lir_ffree:                 s = "ffree";         break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1615
     case lir_push:                  s = "push";          break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1616
     case lir_pop:                   s = "pop";           break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1617
     case lir_null_check:            s = "null_check";    break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1618
     case lir_return:                s = "return";        break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1619
     case lir_safepoint:             s = "safepoint";     break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1620
     case lir_neg:                   s = "neg";           break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1621
     case lir_leal:                  s = "leal";          break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1622
     case lir_branch:                s = "branch";        break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1623
     case lir_cond_float_branch:     s = "flt_cond_br";   break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1624
     case lir_move:                  s = "move";          break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1625
     case lir_roundfp:               s = "roundfp";       break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1626
     case lir_rtcall:                s = "rtcall";        break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1627
     case lir_throw:                 s = "throw";         break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1628
     case lir_unwind:                s = "unwind";        break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1629
     case lir_convert:               s = "convert";       break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1630
     case lir_alloc_object:          s = "alloc_obj";     break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1631
     case lir_monaddr:               s = "mon_addr";      break;
6453
970dc585ab63 6953144: Tiered compilation
iveresov
parents: 6176
diff changeset
  1632
     case lir_pack64:                s = "pack64";        break;
970dc585ab63 6953144: Tiered compilation
iveresov
parents: 6176
diff changeset
  1633
     case lir_unpack64:              s = "unpack64";      break;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1634
     // LIR_Op2
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1635
     case lir_cmp:                   s = "cmp";           break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1636
     case lir_cmp_l2i:               s = "cmp_l2i";       break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1637
     case lir_ucmp_fd2i:             s = "ucomp_fd2i";    break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1638
     case lir_cmp_fd2i:              s = "comp_fd2i";     break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1639
     case lir_cmove:                 s = "cmove";         break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1640
     case lir_add:                   s = "add";           break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1641
     case lir_sub:                   s = "sub";           break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1642
     case lir_mul:                   s = "mul";           break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1643
     case lir_mul_strictfp:          s = "mul_strictfp";  break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1644
     case lir_div:                   s = "div";           break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1645
     case lir_div_strictfp:          s = "div_strictfp";  break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1646
     case lir_rem:                   s = "rem";           break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1647
     case lir_abs:                   s = "abs";           break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1648
     case lir_sqrt:                  s = "sqrt";          break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1649
     case lir_sin:                   s = "sin";           break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1650
     case lir_cos:                   s = "cos";           break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1651
     case lir_tan:                   s = "tan";           break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1652
     case lir_log:                   s = "log";           break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1653
     case lir_log10:                 s = "log10";         break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1654
     case lir_logic_and:             s = "logic_and";     break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1655
     case lir_logic_or:              s = "logic_or";      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1656
     case lir_logic_xor:             s = "logic_xor";     break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1657
     case lir_shl:                   s = "shift_left";    break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1658
     case lir_shr:                   s = "shift_right";   break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1659
     case lir_ushr:                  s = "ushift_right";  break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1660
     case lir_alloc_array:           s = "alloc_array";   break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1661
     // LIR_Op3
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1662
     case lir_idiv:                  s = "idiv";          break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1663
     case lir_irem:                  s = "irem";          break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1664
     // LIR_OpJavaCall
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1665
     case lir_static_call:           s = "static";        break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1666
     case lir_optvirtual_call:       s = "optvirtual";    break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1667
     case lir_icvirtual_call:        s = "icvirtual";     break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1668
     case lir_virtual_call:          s = "virtual";       break;
5046
27e801a857cb 6919934: JSR 292 needs to support x86 C1
twisti
parents: 3800
diff changeset
  1669
     case lir_dynamic_call:          s = "dynamic";       break;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1670
     // LIR_OpArrayCopy
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1671
     case lir_arraycopy:             s = "arraycopy";     break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1672
     // LIR_OpLock
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1673
     case lir_lock:                  s = "lock";          break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1674
     case lir_unlock:                s = "unlock";        break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1675
     // LIR_OpDelay
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1676
     case lir_delay_slot:            s = "delay";         break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1677
     // LIR_OpTypeCheck
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1678
     case lir_instanceof:            s = "instanceof";    break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1679
     case lir_checkcast:             s = "checkcast";     break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1680
     case lir_store_check:           s = "store_check";   break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1681
     // LIR_OpCompareAndSwap
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1682
     case lir_cas_long:              s = "cas_long";      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1683
     case lir_cas_obj:               s = "cas_obj";      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1684
     case lir_cas_int:               s = "cas_int";      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1685
     // LIR_OpProfileCall
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1686
     case lir_profile_call:          s = "profile_call";  break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1687
     case lir_none:                  ShouldNotReachHere();break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1688
    default:                         s = "illegal_op";    break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1689
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1690
  return s;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1691
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1692
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1693
// LIR_OpJavaCall
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1694
void LIR_OpJavaCall::print_instr(outputStream* out) const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1695
  out->print("call: ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1696
  out->print("[addr: 0x%x]", address());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1697
  if (receiver()->is_valid()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1698
    out->print(" [recv: ");   receiver()->print(out);   out->print("]");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1699
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1700
  if (result_opr()->is_valid()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1701
    out->print(" [result: "); result_opr()->print(out); out->print("]");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1702
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1703
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1704
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1705
// LIR_OpLabel
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1706
void LIR_OpLabel::print_instr(outputStream* out) const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1707
  out->print("[label:0x%x]", _label);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1708
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1709
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1710
// LIR_OpArrayCopy
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1711
void LIR_OpArrayCopy::print_instr(outputStream* out) const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1712
  src()->print(out);     out->print(" ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1713
  src_pos()->print(out); out->print(" ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1714
  dst()->print(out);     out->print(" ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1715
  dst_pos()->print(out); out->print(" ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1716
  length()->print(out);  out->print(" ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1717
  tmp()->print(out);     out->print(" ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1718
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1719
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1720
// LIR_OpCompareAndSwap
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1721
void LIR_OpCompareAndSwap::print_instr(outputStream* out) const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1722
  addr()->print(out);      out->print(" ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1723
  cmp_value()->print(out); out->print(" ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1724
  new_value()->print(out); out->print(" ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1725
  tmp1()->print(out);      out->print(" ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1726
  tmp2()->print(out);      out->print(" ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1727
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1728
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1729
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1730
// LIR_Op0
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1731
void LIR_Op0::print_instr(outputStream* out) const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1732
  result_opr()->print(out);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1733
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1734
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1735
// LIR_Op1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1736
const char * LIR_Op1::name() const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1737
  if (code() == lir_move) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1738
    switch (move_kind()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1739
    case lir_move_normal:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1740
      return "move";
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1741
    case lir_move_unaligned:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1742
      return "unaligned move";
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1743
    case lir_move_volatile:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1744
      return "volatile_move";
7427
d7b79a367474 6985015: C1 needs to support compressed oops
iveresov
parents: 7397
diff changeset
  1745
    case lir_move_wide:
d7b79a367474 6985015: C1 needs to support compressed oops
iveresov
parents: 7397
diff changeset
  1746
      return "wide_move";
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1747
    default:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1748
      ShouldNotReachHere();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1749
    return "illegal_op";
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1750
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1751
  } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1752
    return LIR_Op::name();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1753
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1754
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1755
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1756
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1757
void LIR_Op1::print_instr(outputStream* out) const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1758
  _opr->print(out);         out->print(" ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1759
  result_opr()->print(out); out->print(" ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1760
  print_patch_code(out, patch_code());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1761
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1762
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1763
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1764
// LIR_Op1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1765
void LIR_OpRTCall::print_instr(outputStream* out) const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1766
  intx a = (intx)addr();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1767
  out->print(Runtime1::name_for_address(addr()));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1768
  out->print(" ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1769
  tmp()->print(out);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1770
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1771
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1772
void LIR_Op1::print_patch_code(outputStream* out, LIR_PatchCode code) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1773
  switch(code) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1774
    case lir_patch_none:                                 break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1775
    case lir_patch_low:    out->print("[patch_low]");    break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1776
    case lir_patch_high:   out->print("[patch_high]");   break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1777
    case lir_patch_normal: out->print("[patch_normal]"); break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1778
    default: ShouldNotReachHere();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1779
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1780
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1781
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1782
// LIR_OpBranch
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1783
void LIR_OpBranch::print_instr(outputStream* out) const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1784
  print_condition(out, cond());             out->print(" ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1785
  if (block() != NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1786
    out->print("[B%d] ", block()->block_id());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1787
  } else if (stub() != NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1788
    out->print("[");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1789
    stub()->print_name(out);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1790
    out->print(": 0x%x]", stub());
6745
a34ef8968a84 6986046: C1 valuestack cleanup
roland
parents: 6742
diff changeset
  1791
    if (stub()->info() != NULL) out->print(" [bci:%d]", stub()->info()->stack()->bci());
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1792
  } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1793
    out->print("[label:0x%x] ", label());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1794
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1795
  if (ublock() != NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1796
    out->print("unordered: [B%d] ", ublock()->block_id());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1797
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1798
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1799
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1800
void LIR_Op::print_condition(outputStream* out, LIR_Condition cond) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1801
  switch(cond) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1802
    case lir_cond_equal:           out->print("[EQ]");      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1803
    case lir_cond_notEqual:        out->print("[NE]");      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1804
    case lir_cond_less:            out->print("[LT]");      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1805
    case lir_cond_lessEqual:       out->print("[LE]");      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1806
    case lir_cond_greaterEqual:    out->print("[GE]");      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1807
    case lir_cond_greater:         out->print("[GT]");      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1808
    case lir_cond_belowEqual:      out->print("[BE]");      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1809
    case lir_cond_aboveEqual:      out->print("[AE]");      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1810
    case lir_cond_always:          out->print("[AL]");      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1811
    default:                       out->print("[%d]",cond); break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1812
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1813
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1814
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1815
// LIR_OpConvert
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1816
void LIR_OpConvert::print_instr(outputStream* out) const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1817
  print_bytecode(out, bytecode());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1818
  in_opr()->print(out);                  out->print(" ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1819
  result_opr()->print(out);              out->print(" ");
6176
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
  1820
#ifdef PPC
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
  1821
  if(tmp1()->is_valid()) {
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
  1822
    tmp1()->print(out); out->print(" ");
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
  1823
    tmp2()->print(out); out->print(" ");
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
  1824
  }
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5702
diff changeset
  1825
#endif
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1826
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1827
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1828
void LIR_OpConvert::print_bytecode(outputStream* out, Bytecodes::Code code) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1829
  switch(code) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1830
    case Bytecodes::_d2f: out->print("[d2f] "); break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1831
    case Bytecodes::_d2i: out->print("[d2i] "); break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1832
    case Bytecodes::_d2l: out->print("[d2l] "); break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1833
    case Bytecodes::_f2d: out->print("[f2d] "); break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1834
    case Bytecodes::_f2i: out->print("[f2i] "); break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1835
    case Bytecodes::_f2l: out->print("[f2l] "); break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1836
    case Bytecodes::_i2b: out->print("[i2b] "); break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1837
    case Bytecodes::_i2c: out->print("[i2c] "); break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1838
    case Bytecodes::_i2d: out->print("[i2d] "); break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1839
    case Bytecodes::_i2f: out->print("[i2f] "); break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1840
    case Bytecodes::_i2l: out->print("[i2l] "); break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1841
    case Bytecodes::_i2s: out->print("[i2s] "); break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1842
    case Bytecodes::_l2i: out->print("[l2i] "); break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1843
    case Bytecodes::_l2f: out->print("[l2f] "); break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1844
    case Bytecodes::_l2d: out->print("[l2d] "); break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1845
    default:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1846
      out->print("[?%d]",code);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1847
    break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1848
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1849
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1850
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1851
void LIR_OpAllocObj::print_instr(outputStream* out) const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1852
  klass()->print(out);                      out->print(" ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1853
  obj()->print(out);                        out->print(" ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1854
  tmp1()->print(out);                       out->print(" ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1855
  tmp2()->print(out);                       out->print(" ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1856
  tmp3()->print(out);                       out->print(" ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1857
  tmp4()->print(out);                       out->print(" ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1858
  out->print("[hdr:%d]", header_size()); out->print(" ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1859
  out->print("[obj:%d]", object_size()); out->print(" ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1860
  out->print("[lbl:0x%x]", stub()->entry());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1861
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1862
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1863
void LIR_OpRoundFP::print_instr(outputStream* out) const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1864
  _opr->print(out);         out->print(" ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1865
  tmp()->print(out);        out->print(" ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1866
  result_opr()->print(out); out->print(" ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1867
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1868
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1869
// LIR_Op2
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1870
void LIR_Op2::print_instr(outputStream* out) const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1871
  if (code() == lir_cmove) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1872
    print_condition(out, condition());         out->print(" ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1873
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1874
  in_opr1()->print(out);    out->print(" ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1875
  in_opr2()->print(out);    out->print(" ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1876
  if (tmp_opr()->is_valid()) { tmp_opr()->print(out);    out->print(" "); }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1877
  result_opr()->print(out);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1878
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1879
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1880
void LIR_OpAllocArray::print_instr(outputStream* out) const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1881
  klass()->print(out);                   out->print(" ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1882
  len()->print(out);                     out->print(" ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1883
  obj()->print(out);                     out->print(" ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1884
  tmp1()->print(out);                    out->print(" ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1885
  tmp2()->print(out);                    out->print(" ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1886
  tmp3()->print(out);                    out->print(" ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1887
  tmp4()->print(out);                    out->print(" ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1888
  out->print("[type:0x%x]", type());     out->print(" ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1889
  out->print("[label:0x%x]", stub()->entry());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1890
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1891
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1892
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1893
void LIR_OpTypeCheck::print_instr(outputStream* out) const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1894
  object()->print(out);                  out->print(" ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1895
  if (code() == lir_store_check) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1896
    array()->print(out);                 out->print(" ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1897
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1898
  if (code() != lir_store_check) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1899
    klass()->print_name_on(out);         out->print(" ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1900
    if (fast_check())                 out->print("fast_check ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1901
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1902
  tmp1()->print(out);                    out->print(" ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1903
  tmp2()->print(out);                    out->print(" ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1904
  tmp3()->print(out);                    out->print(" ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1905
  result_opr()->print(out);              out->print(" ");
6745
a34ef8968a84 6986046: C1 valuestack cleanup
roland
parents: 6742
diff changeset
  1906
  if (info_for_exception() != NULL) out->print(" [bci:%d]", info_for_exception()->stack()->bci());
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1907
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1908
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1909
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1910
// LIR_Op3
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1911
void LIR_Op3::print_instr(outputStream* out) const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1912
  in_opr1()->print(out);    out->print(" ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1913
  in_opr2()->print(out);    out->print(" ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1914
  in_opr3()->print(out);    out->print(" ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1915
  result_opr()->print(out);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1916
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1917
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1918
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1919
void LIR_OpLock::print_instr(outputStream* out) const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1920
  hdr_opr()->print(out);   out->print(" ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1921
  obj_opr()->print(out);   out->print(" ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1922
  lock_opr()->print(out);  out->print(" ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1923
  if (_scratch->is_valid()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1924
    _scratch->print(out);  out->print(" ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1925
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1926
  out->print("[lbl:0x%x]", stub()->entry());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1927
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1928
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1929
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1930
void LIR_OpDelay::print_instr(outputStream* out) const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1931
  _op->print_on(out);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1932
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1933
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1934
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1935
// LIR_OpProfileCall
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1936
void LIR_OpProfileCall::print_instr(outputStream* out) const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1937
  profiled_method()->name()->print_symbol_on(out);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1938
  out->print(".");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1939
  profiled_method()->holder()->name()->print_symbol_on(out);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1940
  out->print(" @ %d ", profiled_bci());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1941
  mdo()->print(out);           out->print(" ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1942
  recv()->print(out);          out->print(" ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1943
  tmp1()->print(out);          out->print(" ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1944
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1945
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1946
#endif // PRODUCT
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1947
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1948
// Implementation of LIR_InsertionBuffer
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1949
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1950
void LIR_InsertionBuffer::append(int index, LIR_Op* op) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1951
  assert(_index_and_count.length() % 2 == 0, "must have a count for each index");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1952
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1953
  int i = number_of_insertion_points() - 1;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1954
  if (i < 0 || index_at(i) < index) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1955
    append_new(index, 1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1956
  } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1957
    assert(index_at(i) == index, "can append LIR_Ops in ascending order only");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1958
    assert(count_at(i) > 0, "check");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1959
    set_count_at(i, count_at(i) + 1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1960
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1961
  _ops.push(op);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1962
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1963
  DEBUG_ONLY(verify());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1964
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1965
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1966
#ifdef ASSERT
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1967
void LIR_InsertionBuffer::verify() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1968
  int sum = 0;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1969
  int prev_idx = -1;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1970
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1971
  for (int i = 0; i < number_of_insertion_points(); i++) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1972
    assert(prev_idx < index_at(i), "index must be ordered ascending");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1973
    sum += count_at(i);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1974
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1975
  assert(sum == number_of_ops(), "wrong total sum");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1976
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1977
#endif