src/jdk.internal.vm.compiler/share/classes/org.graalvm.compiler.lir.amd64/src/org/graalvm/compiler/lir/amd64/AMD64MathIntrinsicBinaryOp.java
author dlong
Tue, 24 Sep 2019 12:47:15 -0400
changeset 58299 6df94ce3ab2f
parent 54084 84f10bbf993f
permissions -rw-r--r--
8229201: Update Graal Reviewed-by: kvn
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: 54084
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: 47216
diff changeset
    23
2d3e99a72541 8205824: Update Graal
never
parents: 47216
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.amd64;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    26
54084
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
    27
import static jdk.vm.ci.amd64.AMD64.xmm0;
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
    28
import static jdk.vm.ci.amd64.AMD64.xmm1;
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
    29
import static org.graalvm.compiler.lir.amd64.AMD64HotSpotHelper.registersToValues;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    30
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    31
import org.graalvm.compiler.core.common.LIRKind;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    32
import org.graalvm.compiler.lir.LIRInstructionClass;
54084
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
    33
import org.graalvm.compiler.lir.Variable;
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
    34
import org.graalvm.compiler.lir.gen.LIRGenerator;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    35
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    36
import jdk.vm.ci.amd64.AMD64Kind;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    37
import jdk.vm.ci.code.Register;
54084
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
    38
import jdk.vm.ci.code.RegisterValue;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    39
import jdk.vm.ci.meta.Value;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    40
54084
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
    41
/**
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
    42
 * AMD64MathIntrinsicBinaryOp assumes that the input values are stored in the xmm0 and xmm1
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
    43
 * registers, and it will emit the output value into the xmm0 register.
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
    44
 * {@link #emitLIRWrapper(LIRGenerator, Value, Value)} is provided for emitting necessary mov LIRs
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
    45
 * before and after this LIR instruction.
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
    46
 */
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
    47
public abstract class AMD64MathIntrinsicBinaryOp extends AMD64LIRInstruction {
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    48
54084
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
    49
    @Def protected Value output;
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
    50
    @Use protected Value input0;
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
    51
    @Use protected Value input1;
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
    52
    @Temp protected Value[] temps;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    53
54084
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
    54
    public AMD64MathIntrinsicBinaryOp(LIRInstructionClass<? extends AMD64MathIntrinsicBinaryOp> type, Register... registers) {
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
    55
        super(type);
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    56
54084
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
    57
        input0 = xmm0.asValue(LIRKind.value(AMD64Kind.DOUBLE));
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
    58
        input1 = xmm1.asValue(LIRKind.value(AMD64Kind.DOUBLE));
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
    59
        output = xmm0.asValue(LIRKind.value(AMD64Kind.DOUBLE));
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    60
54084
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
    61
        temps = registersToValues(registers);
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    62
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    63
54084
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
    64
    public final Variable emitLIRWrapper(LIRGenerator gen, Value x, Value y) {
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
    65
        LIRKind kind = LIRKind.combine(x, y);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
    66
        RegisterValue xmm0Value = xmm0.asValue(kind);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
    67
        gen.emitMove(xmm0Value, x);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
    68
        RegisterValue xmm1Value = xmm1.asValue(kind);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
    69
        gen.emitMove(xmm1Value, y);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
    70
        gen.append(this);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
    71
        Variable result = gen.newVariable(kind);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
    72
        gen.emitMove(result, xmm0Value);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
    73
        return result;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    74
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    75
}