src/jdk.internal.vm.compiler/share/classes/org.graalvm.compiler.lir/src/org/graalvm/compiler/lir/StandardOp.java
author chegar
Thu, 17 Oct 2019 20:54:25 +0100
branchdatagramsocketimpl-branch
changeset 58679 9c3209ff7550
parent 58678 9cf78a70fa4f
parent 58299 6df94ce3ab2f
permissions -rw-r--r--
datagramsocketimpl-branch: merge with default
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
     1
/*
58299
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
     2
 * Copyright (c) 2011, 2019, Oracle and/or its affiliates. All rights reserved.
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
     4
 *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
     7
 * published by the Free Software Foundation.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
     8
 *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
     9
 * This code is distributed in the hope that it will be useful, but WITHOUT
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    10
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    11
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    12
 * version 2 for more details (a copy is included in the LICENSE file that
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    13
 * accompanied this code).
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    14
 *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    15
 * You should have received a copy of the GNU General Public License version
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    16
 * 2 along with this work; if not, write to the Free Software Foundation,
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    17
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    18
 *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    19
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    20
 * or visit www.oracle.com if you need additional information or have any
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    21
 * questions.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    22
 */
50858
2d3e99a72541 8205824: Update Graal
never
parents: 49873
diff changeset
    23
2d3e99a72541 8205824: Update Graal
never
parents: 49873
diff changeset
    24
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    25
package org.graalvm.compiler.lir;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    26
58299
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
    27
import static jdk.vm.ci.code.ValueUtil.asStackSlot;
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
    28
import static jdk.vm.ci.code.ValueUtil.isStackSlot;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    29
import static org.graalvm.compiler.lir.LIRInstruction.OperandFlag.CONST;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    30
import static org.graalvm.compiler.lir.LIRInstruction.OperandFlag.HINT;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    31
import static org.graalvm.compiler.lir.LIRInstruction.OperandFlag.OUTGOING;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    32
import static org.graalvm.compiler.lir.LIRInstruction.OperandFlag.REG;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    33
import static org.graalvm.compiler.lir.LIRInstruction.OperandFlag.STACK;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    34
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
    35
import java.util.ArrayList;
58299
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
    36
import java.util.Arrays;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    37
import java.util.EnumSet;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    38
49873
26ebfe8ce852 8199755: Update Graal
dlong
parents: 48861
diff changeset
    39
import jdk.internal.vm.compiler.collections.EconomicSet;
58299
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
    40
import jdk.internal.vm.compiler.collections.Equivalence;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    41
import org.graalvm.compiler.asm.Label;
57537
ecc6e394475f 8226771: Update Graal
dlong
parents: 54084
diff changeset
    42
import org.graalvm.compiler.core.common.GraalOptions;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    43
import org.graalvm.compiler.core.common.cfg.AbstractBlockBase;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    44
import org.graalvm.compiler.debug.GraalError;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    45
import org.graalvm.compiler.lir.asm.CompilationResultBuilder;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    46
import org.graalvm.compiler.lir.framemap.FrameMap;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    47
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    48
import jdk.vm.ci.code.Register;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    49
import jdk.vm.ci.code.RegisterSaveLayout;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    50
import jdk.vm.ci.code.StackSlot;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    51
import jdk.vm.ci.meta.AllocatableValue;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    52
import jdk.vm.ci.meta.Constant;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    53
import jdk.vm.ci.meta.Value;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    54
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    55
/**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    56
 * A collection of machine-independent LIR operations, as well as interfaces to be implemented for
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    57
 * specific kinds or LIR operations.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    58
 */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    59
public class StandardOp {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    60
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    61
    /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    62
     * A block delimiter. Every well formed block must contain exactly one such operation and it
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    63
     * must be the last operation in the block.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    64
     */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    65
    public interface BlockEndOp {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    66
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    67
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    68
    public interface NullCheck {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    69
        Value getCheckedValue();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    70
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    71
        LIRFrameState getState();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    72
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    73
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    74
    public interface ImplicitNullCheck {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    75
        boolean makeNullCheckFor(Value value, LIRFrameState nullCheckState, int implicitNullCheckLimit);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    76
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    77
54084
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
    78
    public interface LabelHoldingOp {
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
    79
        Label getLabel();
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
    80
    }
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
    81
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    82
    /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    83
     * LIR operation that defines the position of a label.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    84
     */
54084
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
    85
    public static final class LabelOp extends LIRInstruction implements LabelHoldingOp {
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    86
        public static final LIRInstructionClass<LabelOp> TYPE = LIRInstructionClass.create(LabelOp.class);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    87
        public static final EnumSet<OperandFlag> incomingFlags = EnumSet.of(REG, STACK);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    88
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    89
        /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    90
         * In the LIR, every register and variable must be defined before it is used. For method
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    91
         * parameters that are passed in fixed registers, exception objects passed to the exception
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    92
         * handler in a fixed register, or any other use of a fixed register not defined in this
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    93
         * method, an artificial definition is necessary. To avoid spill moves to be inserted
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    94
         * between the label at the beginning of a block an an actual definition in the second
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    95
         * instruction of a block, the registers are defined here in the label.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    96
         */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    97
        @Def({REG, STACK}) private Value[] incomingValues;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    98
        private final Label label;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    99
        private final boolean align;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   100
        private int numbPhis;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   101
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   102
        public LabelOp(Label label, boolean align) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   103
            super(TYPE);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   104
            this.label = label;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   105
            this.align = align;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   106
            this.incomingValues = Value.NO_VALUES;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   107
            this.numbPhis = 0;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   108
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   109
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   110
        public void setPhiValues(Value[] values) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   111
            setIncomingValues(values);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   112
            setNumberOfPhis(values.length);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   113
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   114
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   115
        private void setNumberOfPhis(int numPhis) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   116
            assert numbPhis == 0;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   117
            numbPhis = numPhis;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   118
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   119
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   120
        public int getPhiSize() {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   121
            return numbPhis;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   122
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   123
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   124
        public void setIncomingValues(Value[] values) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   125
            assert this.incomingValues.length == 0;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   126
            assert values != null;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   127
            this.incomingValues = values;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   128
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   129
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   130
        public int getIncomingSize() {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   131
            return incomingValues.length;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   132
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   133
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   134
        public Value getIncomingValue(int idx) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   135
            assert checkRange(idx);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   136
            return incomingValues[idx];
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   137
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   138
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   139
        public void clearIncomingValues() {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   140
            incomingValues = Value.NO_VALUES;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   141
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   142
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   143
        public void addIncomingValues(Value[] values) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   144
            if (incomingValues.length == 0) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   145
                setIncomingValues(values);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   146
                return;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   147
            }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   148
            int t = incomingValues.length + values.length;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   149
            Value[] newArray = new Value[t];
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   150
            System.arraycopy(incomingValues, 0, newArray, 0, incomingValues.length);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   151
            System.arraycopy(values, 0, newArray, incomingValues.length, values.length);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   152
            incomingValues = newArray;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   153
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   154
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   155
        private boolean checkRange(int idx) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   156
            return idx < incomingValues.length;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   157
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   158
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   159
        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   160
        public void emitCode(CompilationResultBuilder crb) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   161
            if (align) {
57537
ecc6e394475f 8226771: Update Graal
dlong
parents: 54084
diff changeset
   162
                crb.asm.align(GraalOptions.LoopHeaderAlignment.getValue(crb.getOptions()));
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   163
            }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   164
            crb.asm.bind(label);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   165
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   166
54084
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
   167
        @Override
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   168
        public Label getLabel() {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   169
            return label;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   170
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   171
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   172
        /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   173
         * @return true if this label acts as a PhiIn.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   174
         */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   175
        public boolean isPhiIn() {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   176
            return getPhiSize() > 0;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   177
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   178
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   179
        public void forEachIncomingValue(InstructionValueProcedure proc) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   180
            for (int i = 0; i < incomingValues.length; i++) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   181
                incomingValues[i] = proc.doValue(this, incomingValues[i], OperandMode.DEF, incomingFlags);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   182
            }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   183
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   184
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   185
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   186
    /**
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   187
     * LIR operation that is an unconditional jump to a {@link #destination()}.
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   188
     */
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   189
    public static class JumpOp extends LIRInstruction implements BlockEndOp {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   190
        public static final LIRInstructionClass<JumpOp> TYPE = LIRInstructionClass.create(JumpOp.class);
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   191
        public static final EnumSet<OperandFlag> outgoingFlags = EnumSet.of(REG, STACK, CONST, OUTGOING);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   192
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   193
        @Alive({REG, STACK, CONST, OUTGOING}) private Value[] outgoingValues;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   194
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   195
        private final LabelRef destination;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   196
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   197
        public JumpOp(LabelRef destination) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   198
            this(TYPE, destination);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   199
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   200
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   201
        protected JumpOp(LIRInstructionClass<? extends JumpOp> c, LabelRef destination) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   202
            super(c);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   203
            this.destination = destination;
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   204
            this.outgoingValues = Value.NO_VALUES;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   205
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   206
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   207
        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   208
        public void emitCode(CompilationResultBuilder crb) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   209
            if (!crb.isSuccessorEdge(destination)) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   210
                crb.asm.jmp(destination.label());
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   211
            }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   212
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   213
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   214
        public LabelRef destination() {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   215
            return destination;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   216
        }
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   217
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   218
        public void setPhiValues(Value[] values) {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   219
            assert this.outgoingValues.length == 0;
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   220
            assert values != null;
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   221
            this.outgoingValues = values;
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   222
        }
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   223
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   224
        public int getPhiSize() {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   225
            return outgoingValues.length;
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   226
        }
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   227
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   228
        public Value getOutgoingValue(int idx) {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   229
            assert checkRange(idx);
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   230
            return outgoingValues[idx];
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   231
        }
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   232
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   233
        public void clearOutgoingValues() {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   234
            outgoingValues = Value.NO_VALUES;
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   235
        }
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   236
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   237
        private boolean checkRange(int idx) {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   238
            return idx < outgoingValues.length;
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   239
        }
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   240
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   241
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   242
    /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   243
     * Marker interface for a LIR operation that is a conditional jump.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   244
     */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   245
    public interface BranchOp extends BlockEndOp {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   246
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   247
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   248
    /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   249
     * Marker interface for a LIR operation that moves a value to {@link #getResult()}.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   250
     */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   251
    public interface MoveOp {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   252
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   253
        AllocatableValue getResult();
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46344
diff changeset
   254
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46344
diff changeset
   255
        // Checkstyle: stop
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46344
diff changeset
   256
        static MoveOp asMoveOp(LIRInstruction op) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46344
diff changeset
   257
            return (MoveOp) op;
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46344
diff changeset
   258
        }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46344
diff changeset
   259
        // Checkstyle: resume
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46344
diff changeset
   260
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46344
diff changeset
   261
        static boolean isMoveOp(LIRInstruction op) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46344
diff changeset
   262
            return op.isMoveOp();
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46344
diff changeset
   263
        }
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   264
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   265
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   266
    /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   267
     * Marker interface for a LIR operation that moves some non-constant value to another location.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   268
     */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   269
    public interface ValueMoveOp extends MoveOp {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   270
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   271
        AllocatableValue getInput();
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46344
diff changeset
   272
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46344
diff changeset
   273
        // Checkstyle: stop
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46344
diff changeset
   274
        static ValueMoveOp asValueMoveOp(LIRInstruction op) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46344
diff changeset
   275
            return (ValueMoveOp) op;
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46344
diff changeset
   276
        }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46344
diff changeset
   277
        // Checkstyle: resume
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46344
diff changeset
   278
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46344
diff changeset
   279
        static boolean isValueMoveOp(LIRInstruction op) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46344
diff changeset
   280
            return op.isValueMoveOp();
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46344
diff changeset
   281
        }
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   282
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   283
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   284
    /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   285
     * Marker interface for a LIR operation that loads a {@link #getConstant()}.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   286
     */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   287
    public interface LoadConstantOp extends MoveOp {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   288
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   289
        Constant getConstant();
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46344
diff changeset
   290
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46344
diff changeset
   291
        // Checkstyle: stop
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46344
diff changeset
   292
        static LoadConstantOp asLoadConstantOp(LIRInstruction op) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46344
diff changeset
   293
            return (LoadConstantOp) op;
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46344
diff changeset
   294
        }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46344
diff changeset
   295
        // Checkstyle: resume
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46344
diff changeset
   296
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46344
diff changeset
   297
        static boolean isLoadConstantOp(LIRInstruction op) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46344
diff changeset
   298
            return op.isLoadConstantOp();
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46344
diff changeset
   299
        }
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   300
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   301
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   302
    /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   303
     * An operation that saves registers to the stack. The set of saved registers can be
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   304
     * {@linkplain #remove(EconomicSet) pruned} and a mapping from registers to the frame slots in
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   305
     * which they are saved can be {@linkplain #getMap(FrameMap) retrieved}.
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   306
     */
58299
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   307
    public abstract static class SaveRegistersOp extends LIRInstruction {
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   308
        public static final LIRInstructionClass<SaveRegistersOp> TYPE = LIRInstructionClass.create(SaveRegistersOp.class);
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   309
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   310
        /**
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   311
         * The registers (potentially) saved by this operation.
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   312
         */
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   313
        protected final Register[] savedRegisters;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   314
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   315
        /**
58299
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   316
         * The slots to which the registers are saved.
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   317
         */
58299
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   318
        @Def(STACK) protected final AllocatableValue[] slots;
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   319
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   320
        /**
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   321
         *
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   322
         * @param savedRegisters the registers saved by this operation which may be subject to
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   323
         *            {@linkplain #remove(EconomicSet) pruning}
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   324
         * @param savedRegisterLocations the slots to which the registers are saved
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   325
         */
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   326
        protected SaveRegistersOp(LIRInstructionClass<? extends SaveRegistersOp> c, Register[] savedRegisters, AllocatableValue[] savedRegisterLocations) {
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   327
            super(c);
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   328
            assert Arrays.asList(savedRegisterLocations).stream().allMatch(LIRValueUtil::isVirtualStackSlot);
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   329
            this.savedRegisters = savedRegisters;
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   330
            this.slots = savedRegisterLocations;
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   331
        }
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   332
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   333
        /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   334
         * Prunes {@code doNotSave} from the registers saved by this operation.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   335
         *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   336
         * @param doNotSave registers that should not be saved by this operation
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   337
         * @return the number of registers pruned
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   338
         */
58299
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   339
        public int remove(EconomicSet<Register> doNotSave) {
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   340
            return prune(doNotSave, savedRegisters);
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   341
        }
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   342
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   343
        /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   344
         * Gets a map from the saved registers saved by this operation to the frame slots in which
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   345
         * they are saved.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   346
         *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   347
         * @param frameMap used to {@linkplain FrameMap#offsetForStackSlot(StackSlot) convert} a
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   348
         *            virtual slot to a frame slot index
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   349
         */
58299
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   350
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   351
        public RegisterSaveLayout getMap(FrameMap frameMap) {
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   352
            int total = 0;
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   353
            for (int i = 0; i < savedRegisters.length; i++) {
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   354
                if (savedRegisters[i] != null) {
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   355
                    total++;
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   356
                }
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   357
            }
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   358
            Register[] keys = new Register[total];
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   359
            int[] values = new int[total];
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   360
            if (total != 0) {
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   361
                int mapIndex = 0;
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   362
                for (int i = 0; i < savedRegisters.length; i++) {
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   363
                    if (savedRegisters[i] != null) {
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   364
                        keys[mapIndex] = savedRegisters[i];
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   365
                        assert isStackSlot(slots[i]) : "not a StackSlot: " + slots[i];
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   366
                        StackSlot slot = asStackSlot(slots[i]);
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   367
                        values[mapIndex] = indexForStackSlot(frameMap, slot);
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   368
                        mapIndex++;
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   369
                    }
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   370
                }
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   371
                assert mapIndex == total;
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   372
            }
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   373
            return new RegisterSaveLayout(keys, values);
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   374
        }
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   375
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   376
        public Register[] getSavedRegisters() {
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   377
            return savedRegisters;
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   378
        }
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   379
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   380
        public EconomicSet<Register> getSaveableRegisters() {
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   381
            EconomicSet<Register> registers = EconomicSet.create(Equivalence.IDENTITY);
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   382
            for (Register r : savedRegisters) {
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   383
                registers.add(r);
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   384
            }
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   385
            return registers;
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   386
        }
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   387
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   388
        public AllocatableValue[] getSlots() {
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   389
            return slots;
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   390
        }
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   391
58299
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   392
        @Override
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   393
        public abstract void emitCode(CompilationResultBuilder crb);
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   394
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   395
        static int prune(EconomicSet<Register> toRemove, Register[] registers) {
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   396
            int pruned = 0;
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   397
            for (int i = 0; i < registers.length; i++) {
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   398
                if (registers[i] != null) {
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   399
                    if (toRemove.contains(registers[i])) {
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   400
                        registers[i] = null;
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   401
                        pruned++;
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   402
                    }
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   403
                }
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   404
            }
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   405
            return pruned;
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   406
        }
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   407
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   408
        /**
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   409
         * Computes the index of a stack slot relative to slot 0. This is also the bit index of
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   410
         * stack slots in the reference map.
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   411
         *
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   412
         * @param slot a stack slot
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   413
         * @return the index of the stack slot
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   414
         */
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   415
        private static int indexForStackSlot(FrameMap frameMap, StackSlot slot) {
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   416
            assert frameMap.offsetForStackSlot(slot) % frameMap.getTarget().wordSize == 0;
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   417
            int value = frameMap.offsetForStackSlot(slot) / frameMap.getTarget().wordSize;
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   418
            return value;
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   419
        }
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   420
    }
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   421
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   422
    /**
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   423
     * Marker interface for an operation that restores the registers saved by
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   424
     * {@link SaveRegistersOp}.
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   425
     */
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   426
    public interface RestoreRegistersOp {
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   427
    }
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   428
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   429
    /**
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   430
     * Marker interface for an operation that kills some set register and stack locations.
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   431
     */
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   432
    public interface ZapRegistersOp {
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   433
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   434
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   435
    /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   436
     * A LIR operation that does nothing. If the operation records its position, it can be
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   437
     * subsequently {@linkplain #replace(LIR, LIRInstruction) replaced}.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   438
     */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   439
    public static final class NoOp extends LIRInstruction {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   440
        public static final LIRInstructionClass<NoOp> TYPE = LIRInstructionClass.create(NoOp.class);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   441
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   442
        /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   443
         * The block in which this instruction is located.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   444
         */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   445
        final AbstractBlockBase<?> block;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   446
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   447
        /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   448
         * The block index of this instruction.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   449
         */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   450
        final int index;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   451
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   452
        public NoOp(AbstractBlockBase<?> block, int index) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   453
            super(TYPE);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   454
            this.block = block;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   455
            this.index = index;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   456
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   457
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   458
        public void replace(LIR lir, LIRInstruction replacement) {
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   459
            ArrayList<LIRInstruction> instructions = lir.getLIRforBlock(block);
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   460
            assert instructions.get(index).equals(this) : String.format("Replacing the wrong instruction: %s instead of %s", instructions.get(index), this);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   461
            instructions.set(index, replacement);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   462
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   463
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   464
        public void remove(LIR lir) {
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   465
            ArrayList<LIRInstruction> instructions = lir.getLIRforBlock(block);
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   466
            assert instructions.get(index).equals(this) : String.format("Removing the wrong instruction: %s instead of %s", instructions.get(index), this);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   467
            instructions.remove(index);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   468
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   469
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   470
        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   471
        public void emitCode(CompilationResultBuilder crb) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   472
            if (block != null) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   473
                throw new GraalError(this + " should have been replaced");
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   474
            }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   475
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   476
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   477
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   478
    @Opcode("BLACKHOLE")
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   479
    public static final class BlackholeOp extends LIRInstruction {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   480
        public static final LIRInstructionClass<BlackholeOp> TYPE = LIRInstructionClass.create(BlackholeOp.class);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   481
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   482
        @Use({REG, STACK, CONST}) private Value value;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   483
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   484
        public BlackholeOp(Value value) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   485
            super(TYPE);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   486
            this.value = value;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   487
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   488
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   489
        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   490
        public void emitCode(CompilationResultBuilder crb) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   491
            // do nothing, just keep value alive until at least here
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   492
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   493
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   494
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   495
    public static final class BindToRegisterOp extends LIRInstruction {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   496
        public static final LIRInstructionClass<BindToRegisterOp> TYPE = LIRInstructionClass.create(BindToRegisterOp.class);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   497
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   498
        @Use({REG}) private Value value;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   499
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   500
        public BindToRegisterOp(Value value) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   501
            super(TYPE);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   502
            this.value = value;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   503
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   504
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   505
        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   506
        public void emitCode(CompilationResultBuilder crb) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   507
            // do nothing, just keep value alive until at least here
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   508
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   509
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   510
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   511
    @Opcode("SPILLREGISTERS")
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   512
    public static final class SpillRegistersOp extends LIRInstruction {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   513
        public static final LIRInstructionClass<SpillRegistersOp> TYPE = LIRInstructionClass.create(SpillRegistersOp.class);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   514
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   515
        public SpillRegistersOp() {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   516
            super(TYPE);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   517
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   518
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   519
        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   520
        public boolean destroysCallerSavedRegisters() {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   521
            return true;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   522
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   523
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   524
        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   525
        public void emitCode(CompilationResultBuilder crb) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   526
            // do nothing, just keep value alive until at least here
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   527
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   528
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   529
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   530
    public static final class StackMove extends LIRInstruction implements ValueMoveOp {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   531
        public static final LIRInstructionClass<StackMove> TYPE = LIRInstructionClass.create(StackMove.class);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   532
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   533
        @Def({STACK, HINT}) protected AllocatableValue result;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   534
        @Use({STACK}) protected AllocatableValue input;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   535
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   536
        public StackMove(AllocatableValue result, AllocatableValue input) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   537
            super(TYPE);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   538
            this.result = result;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   539
            this.input = input;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   540
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   541
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   542
        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   543
        public void emitCode(CompilationResultBuilder crb) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   544
            throw new GraalError(this + " should have been removed");
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   545
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   546
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   547
        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   548
        public AllocatableValue getInput() {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   549
            return input;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   550
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   551
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   552
        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   553
        public AllocatableValue getResult() {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   554
            return result;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   555
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   556
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   557
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   558
}