src/jdk.internal.vm.compiler/share/classes/org.graalvm.compiler.replacements/src/org/graalvm/compiler/replacements/DefaultJavaLoweringProvider.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: 50330
diff changeset
    23
2d3e99a72541 8205824: Update Graal
never
parents: 50330
diff changeset
    24
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    25
package org.graalvm.compiler.replacements;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    26
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    27
import static jdk.vm.ci.code.MemoryBarriers.JMM_POST_VOLATILE_READ;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    28
import static jdk.vm.ci.code.MemoryBarriers.JMM_POST_VOLATILE_WRITE;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    29
import static jdk.vm.ci.code.MemoryBarriers.JMM_PRE_VOLATILE_READ;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    30
import static jdk.vm.ci.code.MemoryBarriers.JMM_PRE_VOLATILE_WRITE;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    31
import static jdk.vm.ci.meta.DeoptimizationAction.InvalidateReprofile;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    32
import static jdk.vm.ci.meta.DeoptimizationReason.BoundsCheckException;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    33
import static jdk.vm.ci.meta.DeoptimizationReason.NullCheckException;
52578
7dd81e82d083 8210777: Update Graal
dlong
parents: 51436
diff changeset
    34
import static org.graalvm.compiler.core.common.SpeculativeExecutionAttacksMitigations.Options.UseIndexMasking;
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
    35
import static org.graalvm.compiler.nodes.NamedLocationIdentity.ARRAY_LENGTH_LOCATION;
52578
7dd81e82d083 8210777: Update Graal
dlong
parents: 51436
diff changeset
    36
import static org.graalvm.compiler.nodes.calc.BinaryArithmeticNode.branchlessMax;
7dd81e82d083 8210777: Update Graal
dlong
parents: 51436
diff changeset
    37
import static org.graalvm.compiler.nodes.calc.BinaryArithmeticNode.branchlessMin;
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
    38
import static org.graalvm.compiler.nodes.java.ArrayLengthNode.readArrayLength;
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
    39
import static org.graalvm.compiler.nodes.util.GraphUtil.skipPiWhileNonNull;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    40
47798
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
    41
import java.nio.ByteOrder;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    42
import java.util.ArrayList;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    43
import java.util.BitSet;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    44
import java.util.List;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    45
58299
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
    46
import jdk.vm.ci.meta.JavaConstant;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    47
import org.graalvm.compiler.api.directives.GraalDirectives;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    48
import org.graalvm.compiler.api.replacements.Snippet;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    49
import org.graalvm.compiler.api.replacements.SnippetReflectionProvider;
50330
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
    50
import org.graalvm.compiler.core.common.LIRKind;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    51
import org.graalvm.compiler.core.common.spi.ForeignCallsProvider;
58299
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
    52
import org.graalvm.compiler.core.common.type.AbstractPointerStamp;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    53
import org.graalvm.compiler.core.common.type.IntegerStamp;
47798
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
    54
import org.graalvm.compiler.core.common.type.ObjectStamp;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    55
import org.graalvm.compiler.core.common.type.Stamp;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    56
import org.graalvm.compiler.core.common.type.StampFactory;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    57
import org.graalvm.compiler.core.common.type.TypeReference;
49873
26ebfe8ce852 8199755: Update Graal
dlong
parents: 48861
diff changeset
    58
import org.graalvm.compiler.debug.DebugCloseable;
46640
70bdce04c59b 8183991: Update Graal
iveresov
parents: 46551
diff changeset
    59
import org.graalvm.compiler.debug.DebugHandlersFactory;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    60
import org.graalvm.compiler.debug.GraalError;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    61
import org.graalvm.compiler.graph.Node;
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46371
diff changeset
    62
import org.graalvm.compiler.nodeinfo.InputType;
47798
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
    63
import org.graalvm.compiler.nodes.CompressionNode.CompressionOp;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    64
import org.graalvm.compiler.nodes.ConstantNode;
58299
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
    65
import org.graalvm.compiler.nodes.EndNode;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    66
import org.graalvm.compiler.nodes.FieldLocationIdentity;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    67
import org.graalvm.compiler.nodes.FixedNode;
58299
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
    68
import org.graalvm.compiler.nodes.FixedWithNextNode;
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
    69
import org.graalvm.compiler.nodes.IfNode;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    70
import org.graalvm.compiler.nodes.LogicNode;
58299
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
    71
import org.graalvm.compiler.nodes.MergeNode;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    72
import org.graalvm.compiler.nodes.NamedLocationIdentity;
48190
25cfedf27edc 8192814: Update Graal
dlong
parents: 47798
diff changeset
    73
import org.graalvm.compiler.nodes.NodeView;
58299
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
    74
import org.graalvm.compiler.nodes.PhiNode;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    75
import org.graalvm.compiler.nodes.PiNode;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    76
import org.graalvm.compiler.nodes.StructuredGraph;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    77
import org.graalvm.compiler.nodes.ValueNode;
58299
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
    78
import org.graalvm.compiler.nodes.ValuePhiNode;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    79
import org.graalvm.compiler.nodes.calc.AddNode;
46963
089674d9949b 8186681: Update Graal
iveresov
parents: 46640
diff changeset
    80
import org.graalvm.compiler.nodes.calc.ConditionalNode;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    81
import org.graalvm.compiler.nodes.calc.IntegerBelowNode;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    82
import org.graalvm.compiler.nodes.calc.IntegerConvertNode;
46963
089674d9949b 8186681: Update Graal
iveresov
parents: 46640
diff changeset
    83
import org.graalvm.compiler.nodes.calc.IntegerEqualsNode;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    84
import org.graalvm.compiler.nodes.calc.IsNullNode;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    85
import org.graalvm.compiler.nodes.calc.LeftShiftNode;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    86
import org.graalvm.compiler.nodes.calc.NarrowNode;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    87
import org.graalvm.compiler.nodes.calc.RightShiftNode;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    88
import org.graalvm.compiler.nodes.calc.SignExtendNode;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    89
import org.graalvm.compiler.nodes.calc.SubNode;
47798
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
    90
import org.graalvm.compiler.nodes.calc.UnpackEndianHalfNode;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    91
import org.graalvm.compiler.nodes.calc.ZeroExtendNode;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    92
import org.graalvm.compiler.nodes.debug.VerifyHeapNode;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    93
import org.graalvm.compiler.nodes.extended.BoxNode;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    94
import org.graalvm.compiler.nodes.extended.FixedValueAnchorNode;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    95
import org.graalvm.compiler.nodes.extended.ForeignCallNode;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    96
import org.graalvm.compiler.nodes.extended.GuardedUnsafeLoadNode;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    97
import org.graalvm.compiler.nodes.extended.GuardingNode;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    98
import org.graalvm.compiler.nodes.extended.JavaReadNode;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    99
import org.graalvm.compiler.nodes.extended.JavaWriteNode;
50330
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   100
import org.graalvm.compiler.nodes.extended.LoadArrayComponentHubNode;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   101
import org.graalvm.compiler.nodes.extended.LoadHubNode;
58299
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   102
import org.graalvm.compiler.nodes.extended.LoadHubOrNullNode;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   103
import org.graalvm.compiler.nodes.extended.MembarNode;
46371
0337d0617e7b 8178088: Update Graal
iveresov
parents: 46344
diff changeset
   104
import org.graalvm.compiler.nodes.extended.RawLoadNode;
0337d0617e7b 8178088: Update Graal
iveresov
parents: 46344
diff changeset
   105
import org.graalvm.compiler.nodes.extended.RawStoreNode;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   106
import org.graalvm.compiler.nodes.extended.UnboxNode;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   107
import org.graalvm.compiler.nodes.extended.UnsafeMemoryLoadNode;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   108
import org.graalvm.compiler.nodes.extended.UnsafeMemoryStoreNode;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   109
import org.graalvm.compiler.nodes.java.AbstractNewObjectNode;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   110
import org.graalvm.compiler.nodes.java.AccessIndexedNode;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   111
import org.graalvm.compiler.nodes.java.ArrayLengthNode;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   112
import org.graalvm.compiler.nodes.java.AtomicReadAndWriteNode;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   113
import org.graalvm.compiler.nodes.java.FinalFieldBarrierNode;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   114
import org.graalvm.compiler.nodes.java.InstanceOfDynamicNode;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   115
import org.graalvm.compiler.nodes.java.InstanceOfNode;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   116
import org.graalvm.compiler.nodes.java.LoadFieldNode;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   117
import org.graalvm.compiler.nodes.java.LoadIndexedNode;
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   118
import org.graalvm.compiler.nodes.java.LogicCompareAndSwapNode;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   119
import org.graalvm.compiler.nodes.java.LoweredAtomicReadAndWriteNode;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   120
import org.graalvm.compiler.nodes.java.MonitorEnterNode;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   121
import org.graalvm.compiler.nodes.java.MonitorIdNode;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   122
import org.graalvm.compiler.nodes.java.NewArrayNode;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   123
import org.graalvm.compiler.nodes.java.NewInstanceNode;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   124
import org.graalvm.compiler.nodes.java.RawMonitorEnterNode;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   125
import org.graalvm.compiler.nodes.java.StoreFieldNode;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   126
import org.graalvm.compiler.nodes.java.StoreIndexedNode;
50330
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   127
import org.graalvm.compiler.nodes.java.UnsafeCompareAndExchangeNode;
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   128
import org.graalvm.compiler.nodes.java.UnsafeCompareAndSwapNode;
50330
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   129
import org.graalvm.compiler.nodes.java.ValueCompareAndSwapNode;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   130
import org.graalvm.compiler.nodes.memory.HeapAccess.BarrierType;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   131
import org.graalvm.compiler.nodes.memory.ReadNode;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   132
import org.graalvm.compiler.nodes.memory.WriteNode;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   133
import org.graalvm.compiler.nodes.memory.address.AddressNode;
54084
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
   134
import org.graalvm.compiler.nodes.memory.address.IndexAddressNode;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   135
import org.graalvm.compiler.nodes.memory.address.OffsetAddressNode;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   136
import org.graalvm.compiler.nodes.spi.Lowerable;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   137
import org.graalvm.compiler.nodes.spi.LoweringProvider;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   138
import org.graalvm.compiler.nodes.spi.LoweringTool;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   139
import org.graalvm.compiler.nodes.type.StampTool;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   140
import org.graalvm.compiler.nodes.util.GraphUtil;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   141
import org.graalvm.compiler.nodes.virtual.AllocatedObjectNode;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   142
import org.graalvm.compiler.nodes.virtual.CommitAllocationNode;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   143
import org.graalvm.compiler.nodes.virtual.VirtualArrayNode;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   144
import org.graalvm.compiler.nodes.virtual.VirtualInstanceNode;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   145
import org.graalvm.compiler.nodes.virtual.VirtualObjectNode;
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   146
import org.graalvm.compiler.options.OptionValues;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   147
import org.graalvm.compiler.phases.util.Providers;
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   148
import org.graalvm.compiler.replacements.SnippetLowerableMemoryNode.SnippetLowering;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   149
import org.graalvm.compiler.replacements.nodes.BinaryMathIntrinsicNode;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   150
import org.graalvm.compiler.replacements.nodes.UnaryMathIntrinsicNode;
49873
26ebfe8ce852 8199755: Update Graal
dlong
parents: 48861
diff changeset
   151
import jdk.internal.vm.compiler.word.LocationIdentity;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   152
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   153
import jdk.vm.ci.code.CodeUtil;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   154
import jdk.vm.ci.code.MemoryBarriers;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   155
import jdk.vm.ci.code.TargetDescription;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   156
import jdk.vm.ci.meta.DeoptimizationAction;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   157
import jdk.vm.ci.meta.DeoptimizationReason;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   158
import jdk.vm.ci.meta.JavaKind;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   159
import jdk.vm.ci.meta.MetaAccessProvider;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   160
import jdk.vm.ci.meta.ResolvedJavaField;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   161
import jdk.vm.ci.meta.ResolvedJavaMethod;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   162
import jdk.vm.ci.meta.ResolvedJavaType;
50858
2d3e99a72541 8205824: Update Graal
never
parents: 50330
diff changeset
   163
import jdk.vm.ci.meta.SpeculationLog;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   164
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
 * VM-independent lowerings for standard Java nodes. VM-specific methods are abstract and must be
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   167
 * implemented by VM-specific subclasses.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   168
 */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   169
public abstract class DefaultJavaLoweringProvider implements LoweringProvider {
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
    protected final MetaAccessProvider metaAccess;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   172
    protected final ForeignCallsProvider foreignCalls;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   173
    protected final TargetDescription target;
47798
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
   174
    private final boolean useCompressedOops;
50330
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   175
    private final ResolvedJavaType objectArrayType;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   176
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   177
    private BoxingSnippets.Templates boxingSnippets;
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   178
    private ConstantStringIndexOfSnippets.Templates indexOfSnippets;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   179
47798
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
   180
    public DefaultJavaLoweringProvider(MetaAccessProvider metaAccess, ForeignCallsProvider foreignCalls, TargetDescription target, boolean useCompressedOops) {
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   181
        this.metaAccess = metaAccess;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   182
        this.foreignCalls = foreignCalls;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   183
        this.target = target;
47798
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
   184
        this.useCompressedOops = useCompressedOops;
50330
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   185
        this.objectArrayType = metaAccess.lookupJavaType(Object[].class);
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   186
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   187
46640
70bdce04c59b 8183991: Update Graal
iveresov
parents: 46551
diff changeset
   188
    public void initialize(OptionValues options, Iterable<DebugHandlersFactory> factories, SnippetCounter.Group.Factory factory, Providers providers, SnippetReflectionProvider snippetReflection) {
70bdce04c59b 8183991: Update Graal
iveresov
parents: 46551
diff changeset
   189
        boxingSnippets = new BoxingSnippets.Templates(options, factories, factory, providers, snippetReflection, target);
70bdce04c59b 8183991: Update Graal
iveresov
parents: 46551
diff changeset
   190
        indexOfSnippets = new ConstantStringIndexOfSnippets.Templates(options, factories, providers, snippetReflection, target);
70bdce04c59b 8183991: Update Graal
iveresov
parents: 46551
diff changeset
   191
        providers.getReplacements().registerSnippetTemplateCache(new SnippetCounterNode.SnippetCounterSnippets.Templates(options, factories, providers, snippetReflection, target));
43972
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
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   194
    public final TargetDescription getTarget() {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   195
        return target;
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
52578
7dd81e82d083 8210777: Update Graal
dlong
parents: 51436
diff changeset
   198
    public MetaAccessProvider getMetaAccess() {
7dd81e82d083 8210777: Update Graal
dlong
parents: 51436
diff changeset
   199
        return metaAccess;
7dd81e82d083 8210777: Update Graal
dlong
parents: 51436
diff changeset
   200
    }
7dd81e82d083 8210777: Update Graal
dlong
parents: 51436
diff changeset
   201
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   202
    @Override
50330
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   203
    @SuppressWarnings("try")
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   204
    public void lower(Node n, LoweringTool tool) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   205
        assert n instanceof Lowerable;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   206
        StructuredGraph graph = (StructuredGraph) n.graph();
50330
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   207
        try (DebugCloseable context = n.withNodeSourcePosition()) {
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   208
            if (n instanceof LoadFieldNode) {
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   209
                lowerLoadFieldNode((LoadFieldNode) n, tool);
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   210
            } else if (n instanceof StoreFieldNode) {
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   211
                lowerStoreFieldNode((StoreFieldNode) n, tool);
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   212
            } else if (n instanceof LoadIndexedNode) {
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   213
                lowerLoadIndexedNode((LoadIndexedNode) n, tool);
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   214
            } else if (n instanceof StoreIndexedNode) {
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   215
                lowerStoreIndexedNode((StoreIndexedNode) n, tool);
54084
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
   216
            } else if (n instanceof IndexAddressNode) {
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
   217
                lowerIndexAddressNode((IndexAddressNode) n);
50330
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   218
            } else if (n instanceof ArrayLengthNode) {
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   219
                lowerArrayLengthNode((ArrayLengthNode) n, tool);
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   220
            } else if (n instanceof LoadHubNode) {
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   221
                lowerLoadHubNode((LoadHubNode) n, tool);
58299
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   222
            } else if (n instanceof LoadHubOrNullNode) {
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   223
                lowerLoadHubOrNullNode((LoadHubOrNullNode) n, tool);
50330
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   224
            } else if (n instanceof LoadArrayComponentHubNode) {
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   225
                lowerLoadArrayComponentHubNode((LoadArrayComponentHubNode) n);
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   226
            } else if (n instanceof MonitorEnterNode) {
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   227
                lowerMonitorEnterNode((MonitorEnterNode) n, tool, graph);
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   228
            } else if (n instanceof UnsafeCompareAndSwapNode) {
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   229
                lowerCompareAndSwapNode((UnsafeCompareAndSwapNode) n);
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   230
            } else if (n instanceof UnsafeCompareAndExchangeNode) {
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   231
                lowerCompareAndExchangeNode((UnsafeCompareAndExchangeNode) n);
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   232
            } else if (n instanceof AtomicReadAndWriteNode) {
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   233
                lowerAtomicReadAndWriteNode((AtomicReadAndWriteNode) n);
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   234
            } else if (n instanceof RawLoadNode) {
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   235
                lowerUnsafeLoadNode((RawLoadNode) n, tool);
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   236
            } else if (n instanceof UnsafeMemoryLoadNode) {
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   237
                lowerUnsafeMemoryLoadNode((UnsafeMemoryLoadNode) n);
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   238
            } else if (n instanceof RawStoreNode) {
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   239
                lowerUnsafeStoreNode((RawStoreNode) n);
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   240
            } else if (n instanceof UnsafeMemoryStoreNode) {
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   241
                lowerUnsafeMemoryStoreNode((UnsafeMemoryStoreNode) n);
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   242
            } else if (n instanceof JavaReadNode) {
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   243
                lowerJavaReadNode((JavaReadNode) n);
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   244
            } else if (n instanceof JavaWriteNode) {
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   245
                lowerJavaWriteNode((JavaWriteNode) n);
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   246
            } else if (n instanceof CommitAllocationNode) {
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   247
                lowerCommitAllocationNode((CommitAllocationNode) n, tool);
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   248
            } else if (n instanceof BoxNode) {
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   249
                boxingSnippets.lower((BoxNode) n, tool);
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   250
            } else if (n instanceof UnboxNode) {
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   251
                boxingSnippets.lower((UnboxNode) n, tool);
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   252
            } else if (n instanceof VerifyHeapNode) {
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   253
                lowerVerifyHeap((VerifyHeapNode) n);
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   254
            } else if (n instanceof UnaryMathIntrinsicNode) {
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   255
                lowerUnaryMath((UnaryMathIntrinsicNode) n, tool);
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   256
            } else if (n instanceof BinaryMathIntrinsicNode) {
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   257
                lowerBinaryMath((BinaryMathIntrinsicNode) n, tool);
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   258
            } else if (n instanceof StringIndexOfNode) {
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   259
                lowerIndexOf((StringIndexOfNode) n);
51436
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   260
            } else if (n instanceof StringLatin1IndexOfNode) {
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   261
                lowerLatin1IndexOf((StringLatin1IndexOfNode) n);
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   262
            } else if (n instanceof StringUTF16IndexOfNode) {
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   263
                lowerUTF16IndexOf((StringUTF16IndexOfNode) n);
50330
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   264
            } else if (n instanceof UnpackEndianHalfNode) {
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   265
                lowerSecondHalf((UnpackEndianHalfNode) n);
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   266
            } else {
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   267
                throw GraalError.shouldNotReachHere("Node implementing Lowerable not handled: " + n);
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   268
            }
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   269
        }
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
47798
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
   272
    private void lowerSecondHalf(UnpackEndianHalfNode n) {
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
   273
        ByteOrder byteOrder = target.arch.getByteOrder();
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
   274
        n.lower(byteOrder);
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
   275
    }
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
   276
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   277
    private void lowerIndexOf(StringIndexOfNode n) {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   278
        if (n.getArgument(3).isConstant()) {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   279
            SnippetLowering lowering = new SnippetLowering() {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   280
                @Override
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   281
                public void lower(SnippetLowerableMemoryNode node, LoweringTool tool) {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   282
                    if (tool.getLoweringStage() != LoweringTool.StandardLoweringStage.LOW_TIER) {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   283
                        return;
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   284
                    }
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   285
                    indexOfSnippets.lower(node, tool);
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   286
                }
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   287
            };
48190
25cfedf27edc 8192814: Update Graal
dlong
parents: 47798
diff changeset
   288
            SnippetLowerableMemoryNode snippetLower = new SnippetLowerableMemoryNode(lowering, NamedLocationIdentity.getArrayLocation(JavaKind.Char), n.stamp(NodeView.DEFAULT), n.toArgumentArray());
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   289
            n.graph().add(snippetLower);
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   290
            n.graph().replaceFixedWithFixed(n, snippetLower);
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   291
        }
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   292
    }
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   293
51436
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   294
    private void lowerLatin1IndexOf(StringLatin1IndexOfNode n) {
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   295
        if (n.getArgument(2).isConstant()) {
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   296
            SnippetLowering lowering = new SnippetLowering() {
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   297
                @Override
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   298
                public void lower(SnippetLowerableMemoryNode node, LoweringTool tool) {
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   299
                    if (tool.getLoweringStage() != LoweringTool.StandardLoweringStage.LOW_TIER) {
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   300
                        return;
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   301
                    }
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   302
                    indexOfSnippets.lowerLatin1(node, tool);
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   303
                }
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   304
            };
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   305
            SnippetLowerableMemoryNode snippetLower = new SnippetLowerableMemoryNode(lowering, NamedLocationIdentity.getArrayLocation(JavaKind.Byte), n.stamp(NodeView.DEFAULT), n.toArgumentArray());
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   306
            n.graph().add(snippetLower);
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   307
            n.graph().replaceFixedWithFixed(n, snippetLower);
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   308
        }
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   309
    }
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   310
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   311
    private void lowerUTF16IndexOf(StringUTF16IndexOfNode n) {
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   312
        if (n.getArgument(2).isConstant()) {
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   313
            SnippetLowering lowering = new SnippetLowering() {
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   314
                @Override
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   315
                public void lower(SnippetLowerableMemoryNode node, LoweringTool tool) {
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   316
                    if (tool.getLoweringStage() != LoweringTool.StandardLoweringStage.LOW_TIER) {
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   317
                        return;
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   318
                    }
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   319
                    indexOfSnippets.lowerUTF16(node, tool);
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   320
                }
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   321
            };
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   322
            SnippetLowerableMemoryNode snippetLower = new SnippetLowerableMemoryNode(lowering, NamedLocationIdentity.getArrayLocation(JavaKind.Byte), n.stamp(NodeView.DEFAULT), n.toArgumentArray());
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   323
            n.graph().add(snippetLower);
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   324
            n.graph().replaceFixedWithFixed(n, snippetLower);
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   325
        }
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   326
    }
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   327
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   328
    private void lowerBinaryMath(BinaryMathIntrinsicNode math, LoweringTool tool) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   329
        if (tool.getLoweringStage() == LoweringTool.StandardLoweringStage.HIGH_TIER) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   330
            return;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   331
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   332
        ResolvedJavaMethod method = math.graph().method();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   333
        if (method != null) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   334
            if (method.getAnnotation(Snippet.class) != null) {
54084
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
   335
                // In the context of SnippetStub, i.e., Graal-generated stubs, use the LIR
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
   336
                // lowering to emit the stub assembly code instead of the Node lowering.
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   337
                return;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   338
            }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   339
            if (method.getName().equalsIgnoreCase(math.getOperation().name()) && tool.getMetaAccess().lookupJavaType(Math.class).equals(method.getDeclaringClass())) {
54084
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
   340
                // A root compilation of the intrinsic method should emit the full assembly
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
   341
                // implementation.
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   342
                return;
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
        }
54084
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
   345
        StructuredGraph graph = math.graph();
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
   346
        ForeignCallNode call = graph.add(new ForeignCallNode(foreignCalls, math.getOperation().foreignCallDescriptor, math.getX(), math.getY()));
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
   347
        graph.addAfterFixed(tool.lastFixedNode(), call);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
   348
        math.replaceAtUsages(call);
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   349
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   350
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   351
    private void lowerUnaryMath(UnaryMathIntrinsicNode math, LoweringTool tool) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   352
        if (tool.getLoweringStage() == LoweringTool.StandardLoweringStage.HIGH_TIER) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   353
            return;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   354
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   355
        ResolvedJavaMethod method = math.graph().method();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   356
        if (method != null) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   357
            if (method.getName().equalsIgnoreCase(math.getOperation().name()) && tool.getMetaAccess().lookupJavaType(Math.class).equals(method.getDeclaringClass())) {
54084
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
   358
                // A root compilation of the intrinsic method should emit the full assembly
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
   359
                // implementation.
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   360
                return;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   361
            }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   362
        }
54084
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
   363
        StructuredGraph graph = math.graph();
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
   364
        ForeignCallNode call = math.graph().add(new ForeignCallNode(foreignCalls, math.getOperation().foreignCallDescriptor, math.getValue()));
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
   365
        graph.addAfterFixed(tool.lastFixedNode(), call);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
   366
        math.replaceAtUsages(call);
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   367
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   368
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   369
    protected void lowerVerifyHeap(VerifyHeapNode n) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   370
        GraphUtil.removeFixedWithUnusedInputs(n);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   371
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   372
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   373
    protected AddressNode createOffsetAddress(StructuredGraph graph, ValueNode object, long offset) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   374
        ValueNode o = ConstantNode.forIntegerKind(target.wordJavaKind, offset, graph);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   375
        return graph.unique(new OffsetAddressNode(object, o));
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   376
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   377
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   378
    protected AddressNode createFieldAddress(StructuredGraph graph, ValueNode object, ResolvedJavaField field) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   379
        int offset = fieldOffset(field);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   380
        if (offset >= 0) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   381
            return createOffsetAddress(graph, object, offset);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   382
        } else {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   383
            return null;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   384
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   385
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   386
47798
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
   387
    protected abstract JavaKind getStorageKind(ResolvedJavaField field);
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
   388
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   389
    protected void lowerLoadFieldNode(LoadFieldNode loadField, LoweringTool tool) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   390
        assert loadField.getStackKind() != JavaKind.Illegal;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   391
        StructuredGraph graph = loadField.graph();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   392
        ResolvedJavaField field = loadField.field();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   393
        ValueNode object = loadField.isStatic() ? staticFieldBase(graph, field) : loadField.object();
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   394
        object = createNullCheckedValue(object, loadField, tool);
48190
25cfedf27edc 8192814: Update Graal
dlong
parents: 47798
diff changeset
   395
        Stamp loadStamp = loadStamp(loadField.stamp(NodeView.DEFAULT), getStorageKind(field));
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   396
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   397
        AddressNode address = createFieldAddress(graph, object, field);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   398
        assert address != null : "Field that is loaded must not be eliminated: " + field.getDeclaringClass().toJavaName(true) + "." + field.getName();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   399
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   400
        ReadNode memoryRead = graph.add(new ReadNode(address, fieldLocationIdentity(field), loadStamp, fieldLoadBarrierType(field)));
47798
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
   401
        ValueNode readValue = implicitLoadConvert(graph, getStorageKind(field), memoryRead);
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   402
        loadField.replaceAtUsages(readValue);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   403
        graph.replaceFixed(loadField, memoryRead);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   404
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   405
        if (loadField.isVolatile()) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   406
            MembarNode preMembar = graph.add(new MembarNode(JMM_PRE_VOLATILE_READ));
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   407
            graph.addBeforeFixed(memoryRead, preMembar);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   408
            MembarNode postMembar = graph.add(new MembarNode(JMM_POST_VOLATILE_READ));
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   409
            graph.addAfterFixed(memoryRead, postMembar);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   410
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   411
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   412
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   413
    protected void lowerStoreFieldNode(StoreFieldNode storeField, LoweringTool tool) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   414
        StructuredGraph graph = storeField.graph();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   415
        ResolvedJavaField field = storeField.field();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   416
        ValueNode object = storeField.isStatic() ? staticFieldBase(graph, field) : storeField.object();
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   417
        object = createNullCheckedValue(object, storeField, tool);
47798
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
   418
        ValueNode value = implicitStoreConvert(graph, getStorageKind(storeField.field()), storeField.value());
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   419
        AddressNode address = createFieldAddress(graph, object, field);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   420
        assert address != null;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   421
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   422
        WriteNode memoryWrite = graph.add(new WriteNode(address, fieldLocationIdentity(field), value, fieldStoreBarrierType(storeField.field())));
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   423
        memoryWrite.setStateAfter(storeField.stateAfter());
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   424
        graph.replaceFixedWithFixed(storeField, memoryWrite);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   425
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   426
        if (storeField.isVolatile()) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   427
            MembarNode preMembar = graph.add(new MembarNode(JMM_PRE_VOLATILE_WRITE));
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   428
            graph.addBeforeFixed(memoryWrite, preMembar);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   429
            MembarNode postMembar = graph.add(new MembarNode(JMM_POST_VOLATILE_WRITE));
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   430
            graph.addAfterFixed(memoryWrite, postMembar);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   431
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   432
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   433
52578
7dd81e82d083 8210777: Update Graal
dlong
parents: 51436
diff changeset
   434
    public static final IntegerStamp POSITIVE_ARRAY_INDEX_STAMP = StampFactory.forInteger(32, 0, Integer.MAX_VALUE - 1);
7dd81e82d083 8210777: Update Graal
dlong
parents: 51436
diff changeset
   435
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   436
    /**
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   437
     * Create a PiNode on the index proving that the index is positive. On some platforms this is
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   438
     * important to allow the index to be used as an int in the address mode.
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   439
     */
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   440
    public AddressNode createArrayIndexAddress(StructuredGraph graph, ValueNode array, JavaKind elementKind, ValueNode index, GuardingNode boundsCheck) {
52578
7dd81e82d083 8210777: Update Graal
dlong
parents: 51436
diff changeset
   441
        ValueNode positiveIndex = graph.maybeAddOrUnique(PiNode.create(index, POSITIVE_ARRAY_INDEX_STAMP, boundsCheck != null ? boundsCheck.asNode() : null));
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   442
        return createArrayAddress(graph, array, elementKind, positiveIndex);
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   443
    }
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   444
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   445
    public AddressNode createArrayAddress(StructuredGraph graph, ValueNode array, JavaKind elementKind, ValueNode index) {
55509
d58442b8abc1 8225497: Update Graal
jwilhelm
parents: 54914
diff changeset
   446
        return createArrayAddress(graph, array, elementKind, elementKind, index);
d58442b8abc1 8225497: Update Graal
jwilhelm
parents: 54914
diff changeset
   447
    }
d58442b8abc1 8225497: Update Graal
jwilhelm
parents: 54914
diff changeset
   448
d58442b8abc1 8225497: Update Graal
jwilhelm
parents: 54914
diff changeset
   449
    public AddressNode createArrayAddress(StructuredGraph graph, ValueNode array, JavaKind arrayKind, JavaKind elementKind, ValueNode index) {
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   450
        ValueNode wordIndex;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   451
        if (target.wordSize > 4) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   452
            wordIndex = graph.unique(new SignExtendNode(index, target.wordSize * 8));
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   453
        } else {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   454
            assert target.wordSize == 4 : "unsupported word size";
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   455
            wordIndex = 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
52578
7dd81e82d083 8210777: Update Graal
dlong
parents: 51436
diff changeset
   458
        int shift = CodeUtil.log2(metaAccess.getArrayIndexScale(elementKind));
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   459
        ValueNode scaledIndex = graph.unique(new LeftShiftNode(wordIndex, ConstantNode.forInt(shift, graph)));
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   460
55509
d58442b8abc1 8225497: Update Graal
jwilhelm
parents: 54914
diff changeset
   461
        int base = metaAccess.getArrayBaseOffset(arrayKind);
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   462
        ValueNode offset = graph.unique(new AddNode(scaledIndex, ConstantNode.forIntegerKind(target.wordJavaKind, base, graph)));
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
        return graph.unique(new OffsetAddressNode(array, offset));
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   465
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   466
54084
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
   467
    protected void lowerIndexAddressNode(IndexAddressNode indexAddress) {
55509
d58442b8abc1 8225497: Update Graal
jwilhelm
parents: 54914
diff changeset
   468
        AddressNode lowered = createArrayAddress(indexAddress.graph(), indexAddress.getArray(), indexAddress.getArrayKind(), indexAddress.getElementKind(), indexAddress.getIndex());
54084
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
   469
        indexAddress.replaceAndDelete(lowered);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
   470
    }
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
   471
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   472
    protected void lowerLoadIndexedNode(LoadIndexedNode loadIndexed, LoweringTool tool) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   473
        StructuredGraph graph = loadIndexed.graph();
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   474
        ValueNode array = loadIndexed.array();
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   475
        array = createNullCheckedValue(array, loadIndexed, tool);
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   476
        JavaKind elementKind = loadIndexed.elementKind();
48190
25cfedf27edc 8192814: Update Graal
dlong
parents: 47798
diff changeset
   477
        Stamp loadStamp = loadStamp(loadIndexed.stamp(NodeView.DEFAULT), elementKind);
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   478
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   479
        GuardingNode boundsCheck = getBoundsCheck(loadIndexed, array, tool);
52578
7dd81e82d083 8210777: Update Graal
dlong
parents: 51436
diff changeset
   480
        ValueNode index = loadIndexed.index();
7dd81e82d083 8210777: Update Graal
dlong
parents: 51436
diff changeset
   481
        if (UseIndexMasking.getValue(graph.getOptions())) {
7dd81e82d083 8210777: Update Graal
dlong
parents: 51436
diff changeset
   482
            index = proxyIndex(loadIndexed, index, array, tool);
7dd81e82d083 8210777: Update Graal
dlong
parents: 51436
diff changeset
   483
        }
7dd81e82d083 8210777: Update Graal
dlong
parents: 51436
diff changeset
   484
        AddressNode address = createArrayIndexAddress(graph, array, elementKind, index, boundsCheck);
7dd81e82d083 8210777: Update Graal
dlong
parents: 51436
diff changeset
   485
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   486
        ReadNode memoryRead = graph.add(new ReadNode(address, NamedLocationIdentity.getArrayLocation(elementKind), loadStamp, BarrierType.NONE));
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   487
        memoryRead.setGuard(boundsCheck);
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   488
        ValueNode readValue = implicitLoadConvert(graph, elementKind, memoryRead);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   489
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   490
        loadIndexed.replaceAtUsages(readValue);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   491
        graph.replaceFixed(loadIndexed, memoryRead);
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
    protected void lowerStoreIndexedNode(StoreIndexedNode storeIndexed, LoweringTool tool) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   495
        StructuredGraph graph = storeIndexed.graph();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   496
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   497
        ValueNode value = storeIndexed.value();
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   498
        ValueNode array = storeIndexed.array();
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   499
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   500
        array = this.createNullCheckedValue(array, storeIndexed, tool);
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   501
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   502
        GuardingNode boundsCheck = getBoundsCheck(storeIndexed, array, tool);
43972
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
        JavaKind elementKind = storeIndexed.elementKind();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   505
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   506
        LogicNode condition = null;
50330
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   507
        if (storeIndexed.getStoreCheck() == null && elementKind == JavaKind.Object && !StampTool.isPointerAlwaysNull(value)) {
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   508
            /* Array store check. */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   509
            TypeReference arrayType = StampTool.typeReferenceOrNull(array);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   510
            if (arrayType != null && arrayType.isExact()) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   511
                ResolvedJavaType elementType = arrayType.getType().getComponentType();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   512
                if (!elementType.isJavaLangObject()) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   513
                    TypeReference typeReference = TypeReference.createTrusted(storeIndexed.graph().getAssumptions(), elementType);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   514
                    LogicNode typeTest = graph.addOrUniqueWithInputs(InstanceOfNode.create(typeReference, value));
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   515
                    condition = LogicNode.or(graph.unique(IsNullNode.create(value)), typeTest, GraalDirectives.UNLIKELY_PROBABILITY);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   516
                }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   517
            } else {
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
                 * The guard on the read hub should be the null check of the array that was
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   520
                 * introduced earlier.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   521
                 */
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   522
                ValueNode arrayClass = createReadHub(graph, array, tool);
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   523
                ValueNode componentHub = createReadArrayComponentHub(graph, arrayClass, storeIndexed);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   524
                LogicNode typeTest = graph.unique(InstanceOfDynamicNode.create(graph.getAssumptions(), tool.getConstantReflection(), componentHub, value, false));
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   525
                condition = LogicNode.or(graph.unique(IsNullNode.create(value)), typeTest, GraalDirectives.UNLIKELY_PROBABILITY);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   526
            }
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
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   529
        AddressNode address = createArrayIndexAddress(graph, array, elementKind, storeIndexed.index(), boundsCheck);
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   530
        WriteNode memoryWrite = graph.add(new WriteNode(address, NamedLocationIdentity.getArrayLocation(elementKind), implicitStoreConvert(graph, elementKind, value),
55509
d58442b8abc1 8225497: Update Graal
jwilhelm
parents: 54914
diff changeset
   531
                        arrayStoreBarrierType(storeIndexed.elementKind())));
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   532
        memoryWrite.setGuard(boundsCheck);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   533
        if (condition != null) {
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   534
            tool.createGuard(storeIndexed, condition, DeoptimizationReason.ArrayStoreException, DeoptimizationAction.InvalidateReprofile);
43972
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
        memoryWrite.setStateAfter(storeIndexed.stateAfter());
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   537
        graph.replaceFixedWithFixed(storeIndexed, memoryWrite);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   538
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   539
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   540
    protected void lowerArrayLengthNode(ArrayLengthNode arrayLengthNode, LoweringTool tool) {
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   541
        arrayLengthNode.replaceAtUsages(createReadArrayLength(arrayLengthNode.array(), arrayLengthNode, tool));
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   542
        StructuredGraph graph = arrayLengthNode.graph();
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   543
        graph.removeFixed(arrayLengthNode);
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   544
    }
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   545
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   546
    /**
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   547
     * Creates a read node that read the array length and is guarded by a null-check.
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   548
     *
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   549
     * The created node is placed before {@code before} in the CFG.
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   550
     */
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   551
    protected ReadNode createReadArrayLength(ValueNode array, FixedNode before, LoweringTool tool) {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   552
        StructuredGraph graph = array.graph();
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   553
        ValueNode canonicalArray = this.createNullCheckedValue(skipPiWhileNonNull(array), before, tool);
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   554
        AddressNode address = createOffsetAddress(graph, canonicalArray, arrayLengthOffset());
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   555
        ReadNode readArrayLength = graph.add(new ReadNode(address, ARRAY_LENGTH_LOCATION, StampFactory.positiveInt(), BarrierType.NONE));
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   556
        graph.addBeforeFixed(before, readArrayLength);
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   557
        return readArrayLength;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   558
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   559
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   560
    protected void lowerLoadHubNode(LoadHubNode loadHub, LoweringTool tool) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   561
        StructuredGraph graph = loadHub.graph();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   562
        if (tool.getLoweringStage() != LoweringTool.StandardLoweringStage.LOW_TIER) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   563
            return;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   564
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   565
        if (graph.getGuardsStage().allowsFloatingGuards()) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   566
            return;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   567
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   568
        ValueNode hub = createReadHub(graph, loadHub.getValue(), tool);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   569
        loadHub.replaceAtUsagesAndDelete(hub);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   570
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   571
58299
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   572
    protected void lowerLoadHubOrNullNode(LoadHubOrNullNode loadHubOrNullNode, LoweringTool tool) {
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   573
        StructuredGraph graph = loadHubOrNullNode.graph();
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   574
        if (tool.getLoweringStage() != LoweringTool.StandardLoweringStage.LOW_TIER) {
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   575
            return;
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   576
        }
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   577
        if (graph.getGuardsStage().allowsFloatingGuards()) {
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   578
            return;
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   579
        }
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   580
        final FixedWithNextNode predecessor = tool.lastFixedNode();
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   581
        final ValueNode value = loadHubOrNullNode.getValue();
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   582
        AbstractPointerStamp stamp = (AbstractPointerStamp) value.stamp(NodeView.DEFAULT);
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   583
        final LogicNode isNull = graph.addOrUniqueWithInputs(IsNullNode.create(value));
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   584
        final EndNode trueEnd = graph.add(new EndNode());
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   585
        final EndNode falseEnd = graph.add(new EndNode());
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   586
        final IfNode ifNode = graph.add(new IfNode(isNull, trueEnd, falseEnd, 0.5));
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   587
        final MergeNode merge = graph.add(new MergeNode());
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   588
        merge.addForwardEnd(trueEnd);
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   589
        merge.addForwardEnd(falseEnd);
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   590
        final AbstractPointerStamp hubStamp = (AbstractPointerStamp) loadHubOrNullNode.stamp(NodeView.DEFAULT);
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   591
        ValueNode nullHub = ConstantNode.forConstant(hubStamp.asAlwaysNull(), JavaConstant.NULL_POINTER, tool.getMetaAccess(), graph);
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   592
        final ValueNode nonNullValue = graph.addOrUniqueWithInputs(PiNode.create(value, stamp.asNonNull(), ifNode.falseSuccessor()));
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   593
        ValueNode hub = createReadHub(graph, nonNullValue, tool);
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   594
        ValueNode[] values = new ValueNode[]{nullHub, hub};
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   595
        final PhiNode hubPhi = graph.unique(new ValuePhiNode(hubStamp, merge, values));
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   596
        final FixedNode oldNext = predecessor.next();
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   597
        predecessor.setNext(ifNode);
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   598
        merge.setNext(oldNext);
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   599
        loadHubOrNullNode.replaceAtUsagesAndDelete(hubPhi);
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   600
    }
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   601
50330
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   602
    protected void lowerLoadArrayComponentHubNode(LoadArrayComponentHubNode loadHub) {
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   603
        StructuredGraph graph = loadHub.graph();
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   604
        ValueNode hub = createReadArrayComponentHub(graph, loadHub.getValue(), loadHub);
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   605
        graph.replaceFixed(loadHub, hub);
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   606
    }
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   607
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   608
    protected void lowerMonitorEnterNode(MonitorEnterNode monitorEnter, LoweringTool tool, StructuredGraph graph) {
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   609
        ValueNode object = createNullCheckedValue(monitorEnter.object(), monitorEnter, tool);
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   610
        ValueNode hub = graph.addOrUnique(LoadHubNode.create(object, tool.getStampProvider(), tool.getMetaAccess(), tool.getConstantReflection()));
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   611
        RawMonitorEnterNode rawMonitorEnter = graph.add(new RawMonitorEnterNode(object, hub, monitorEnter.getMonitorId()));
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   612
        rawMonitorEnter.setStateBefore(monitorEnter.stateBefore());
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   613
        rawMonitorEnter.setStateAfter(monitorEnter.stateAfter());
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   614
        graph.replaceFixedWithFixed(monitorEnter, rawMonitorEnter);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   615
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   616
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   617
    protected void lowerCompareAndSwapNode(UnsafeCompareAndSwapNode cas) {
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   618
        StructuredGraph graph = cas.graph();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   619
        JavaKind valueKind = cas.getValueKind();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   620
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   621
        ValueNode expectedValue = implicitStoreConvert(graph, valueKind, cas.expected());
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   622
        ValueNode newValue = implicitStoreConvert(graph, valueKind, cas.newValue());
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   623
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   624
        AddressNode address = graph.unique(new OffsetAddressNode(cas.object(), cas.offset()));
50330
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   625
        BarrierType barrierType = guessStoreBarrierType(cas.object(), expectedValue);
49873
26ebfe8ce852 8199755: Update Graal
dlong
parents: 48861
diff changeset
   626
        LogicCompareAndSwapNode atomicNode = graph.add(new LogicCompareAndSwapNode(address, cas.getLocationIdentity(), expectedValue, newValue, barrierType));
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   627
        atomicNode.setStateAfter(cas.stateAfter());
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   628
        graph.replaceFixedWithFixed(cas, atomicNode);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   629
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   630
50330
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   631
    protected void lowerCompareAndExchangeNode(UnsafeCompareAndExchangeNode cas) {
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   632
        StructuredGraph graph = cas.graph();
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   633
        JavaKind valueKind = cas.getValueKind();
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   634
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   635
        ValueNode expectedValue = implicitStoreConvert(graph, valueKind, cas.expected());
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   636
        ValueNode newValue = implicitStoreConvert(graph, valueKind, cas.newValue());
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   637
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   638
        AddressNode address = graph.unique(new OffsetAddressNode(cas.object(), cas.offset()));
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   639
        BarrierType barrierType = guessStoreBarrierType(cas.object(), expectedValue);
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   640
        ValueCompareAndSwapNode atomicNode = graph.add(new ValueCompareAndSwapNode(address, expectedValue, newValue, cas.getLocationIdentity(), barrierType));
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   641
        ValueNode coercedNode = implicitLoadConvert(graph, valueKind, atomicNode, true);
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   642
        atomicNode.setStateAfter(cas.stateAfter());
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   643
        cas.replaceAtUsages(coercedNode);
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   644
        graph.replaceFixedWithFixed(cas, atomicNode);
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   645
    }
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   646
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   647
    protected void lowerAtomicReadAndWriteNode(AtomicReadAndWriteNode n) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   648
        StructuredGraph graph = n.graph();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   649
        JavaKind valueKind = n.getValueKind();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   650
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   651
        ValueNode newValue = implicitStoreConvert(graph, valueKind, n.newValue());
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   652
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   653
        AddressNode address = graph.unique(new OffsetAddressNode(n.object(), n.offset()));
50330
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   654
        BarrierType barrierType = guessStoreBarrierType(n.object(), n.newValue());
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   655
        LIRKind lirAccessKind = LIRKind.fromJavaKind(target.arch, valueKind);
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   656
        LoweredAtomicReadAndWriteNode memoryRead = graph.add(new LoweredAtomicReadAndWriteNode(address, n.getLocationIdentity(), newValue, lirAccessKind, barrierType));
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   657
        memoryRead.setStateAfter(n.stateAfter());
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   658
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   659
        ValueNode readValue = implicitLoadConvert(graph, valueKind, memoryRead);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   660
        n.stateAfter().replaceFirstInput(n, memoryRead);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   661
        n.replaceAtUsages(readValue);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   662
        graph.replaceFixedWithFixed(n, memoryRead);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   663
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   664
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   665
    /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   666
     * @param tool utility for performing the lowering
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   667
     */
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   668
    protected void lowerUnsafeLoadNode(RawLoadNode load, LoweringTool tool) {
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   669
        StructuredGraph graph = load.graph();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   670
        if (load instanceof GuardedUnsafeLoadNode) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   671
            GuardedUnsafeLoadNode guardedLoad = (GuardedUnsafeLoadNode) load;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   672
            GuardingNode guard = guardedLoad.getGuard();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   673
            if (guard == null) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   674
                // can float freely if the guard folded away
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   675
                ReadNode memoryRead = createUnsafeRead(graph, load, null);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   676
                memoryRead.setForceFixed(false);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   677
                graph.replaceFixedWithFixed(load, memoryRead);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   678
            } else {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   679
                // must be guarded, but flows below the guard
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   680
                ReadNode memoryRead = createUnsafeRead(graph, load, guard);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   681
                graph.replaceFixedWithFixed(load, memoryRead);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   682
            }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   683
        } else {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   684
            // never had a guarding condition so it must be fixed, creation of the read will force
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   685
            // it to be fixed
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   686
            ReadNode memoryRead = createUnsafeRead(graph, load, null);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   687
            graph.replaceFixedWithFixed(load, memoryRead);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   688
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   689
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   690
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   691
    protected AddressNode createUnsafeAddress(StructuredGraph graph, ValueNode object, ValueNode offset) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   692
        if (object.isConstant() && object.asConstant().isDefaultForKind()) {
48190
25cfedf27edc 8192814: Update Graal
dlong
parents: 47798
diff changeset
   693
            return graph.addOrUniqueWithInputs(OffsetAddressNode.create(offset));
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   694
        } else {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   695
            return graph.unique(new OffsetAddressNode(object, offset));
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   696
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   697
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   698
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   699
    protected ReadNode createUnsafeRead(StructuredGraph graph, RawLoadNode load, GuardingNode guard) {
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   700
        boolean compressible = load.accessKind() == JavaKind.Object;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   701
        JavaKind readKind = load.accessKind();
48190
25cfedf27edc 8192814: Update Graal
dlong
parents: 47798
diff changeset
   702
        Stamp loadStamp = loadStamp(load.stamp(NodeView.DEFAULT), readKind, compressible);
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   703
        AddressNode address = createUnsafeAddress(graph, load.object(), load.offset());
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   704
        ReadNode memoryRead = graph.add(new ReadNode(address, load.getLocationIdentity(), loadStamp, BarrierType.NONE));
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   705
        if (guard == null) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   706
            // An unsafe read must not float otherwise it may float above
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   707
            // a test guaranteeing the read is safe.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   708
            memoryRead.setForceFixed(true);
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   709
        } else {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   710
            memoryRead.setGuard(guard);
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   711
        }
46963
089674d9949b 8186681: Update Graal
iveresov
parents: 46640
diff changeset
   712
        ValueNode readValue = performBooleanCoercionIfNecessary(implicitLoadConvert(graph, readKind, memoryRead, compressible), readKind);
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   713
        load.replaceAtUsages(readValue);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   714
        return memoryRead;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   715
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   716
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   717
    protected void lowerUnsafeMemoryLoadNode(UnsafeMemoryLoadNode load) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   718
        StructuredGraph graph = load.graph();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   719
        JavaKind readKind = load.getKind();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   720
        assert readKind != JavaKind.Object;
48190
25cfedf27edc 8192814: Update Graal
dlong
parents: 47798
diff changeset
   721
        Stamp loadStamp = loadStamp(load.stamp(NodeView.DEFAULT), readKind, false);
25cfedf27edc 8192814: Update Graal
dlong
parents: 47798
diff changeset
   722
        AddressNode address = graph.addOrUniqueWithInputs(OffsetAddressNode.create(load.getAddress()));
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   723
        ReadNode memoryRead = graph.add(new ReadNode(address, load.getLocationIdentity(), loadStamp, BarrierType.NONE));
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   724
        // An unsafe read must not float otherwise it may float above
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   725
        // a test guaranteeing the read is safe.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   726
        memoryRead.setForceFixed(true);
46963
089674d9949b 8186681: Update Graal
iveresov
parents: 46640
diff changeset
   727
        ValueNode readValue = performBooleanCoercionIfNecessary(implicitLoadConvert(graph, readKind, memoryRead, false), readKind);
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   728
        load.replaceAtUsages(readValue);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   729
        graph.replaceFixedWithFixed(load, memoryRead);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   730
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   731
46963
089674d9949b 8186681: Update Graal
iveresov
parents: 46640
diff changeset
   732
    private static ValueNode performBooleanCoercionIfNecessary(ValueNode readValue, JavaKind readKind) {
089674d9949b 8186681: Update Graal
iveresov
parents: 46640
diff changeset
   733
        if (readKind == JavaKind.Boolean) {
089674d9949b 8186681: Update Graal
iveresov
parents: 46640
diff changeset
   734
            StructuredGraph graph = readValue.graph();
089674d9949b 8186681: Update Graal
iveresov
parents: 46640
diff changeset
   735
            IntegerEqualsNode eq = graph.addOrUnique(new IntegerEqualsNode(readValue, ConstantNode.forInt(0, graph)));
089674d9949b 8186681: Update Graal
iveresov
parents: 46640
diff changeset
   736
            return graph.addOrUnique(new ConditionalNode(eq, ConstantNode.forBoolean(false, graph), ConstantNode.forBoolean(true, graph)));
089674d9949b 8186681: Update Graal
iveresov
parents: 46640
diff changeset
   737
        }
089674d9949b 8186681: Update Graal
iveresov
parents: 46640
diff changeset
   738
        return readValue;
089674d9949b 8186681: Update Graal
iveresov
parents: 46640
diff changeset
   739
    }
089674d9949b 8186681: Update Graal
iveresov
parents: 46640
diff changeset
   740
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   741
    protected void lowerUnsafeStoreNode(RawStoreNode store) {
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   742
        StructuredGraph graph = store.graph();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   743
        boolean compressible = store.value().getStackKind() == JavaKind.Object;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   744
        JavaKind valueKind = store.accessKind();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   745
        ValueNode value = implicitStoreConvert(graph, valueKind, store.value(), compressible);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   746
        AddressNode address = createUnsafeAddress(graph, store.object(), store.offset());
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   747
        WriteNode write = graph.add(new WriteNode(address, store.getLocationIdentity(), value, unsafeStoreBarrierType(store)));
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   748
        write.setStateAfter(store.stateAfter());
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   749
        graph.replaceFixedWithFixed(store, write);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   750
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   751
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   752
    protected void lowerUnsafeMemoryStoreNode(UnsafeMemoryStoreNode store) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   753
        StructuredGraph graph = store.graph();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   754
        assert store.getValue().getStackKind() != JavaKind.Object;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   755
        JavaKind valueKind = store.getKind();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   756
        ValueNode value = implicitStoreConvert(graph, valueKind, store.getValue(), false);
48190
25cfedf27edc 8192814: Update Graal
dlong
parents: 47798
diff changeset
   757
        AddressNode address = graph.addOrUniqueWithInputs(OffsetAddressNode.create(store.getAddress()));
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   758
        WriteNode write = graph.add(new WriteNode(address, store.getLocationIdentity(), value, BarrierType.NONE));
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   759
        write.setStateAfter(store.stateAfter());
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   760
        graph.replaceFixedWithFixed(store, write);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   761
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   762
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   763
    protected void lowerJavaReadNode(JavaReadNode read) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   764
        StructuredGraph graph = read.graph();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   765
        JavaKind valueKind = read.getReadKind();
48190
25cfedf27edc 8192814: Update Graal
dlong
parents: 47798
diff changeset
   766
        Stamp loadStamp = loadStamp(read.stamp(NodeView.DEFAULT), valueKind, read.isCompressible());
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   767
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   768
        ReadNode memoryRead = graph.add(new ReadNode(read.getAddress(), read.getLocationIdentity(), loadStamp, read.getBarrierType()));
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   769
        GuardingNode guard = read.getGuard();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   770
        ValueNode readValue = implicitLoadConvert(graph, valueKind, memoryRead, read.isCompressible());
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   771
        if (guard == null) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   772
            // An unsafe read must not float otherwise it may float above
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   773
            // a test guaranteeing the read is safe.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   774
            memoryRead.setForceFixed(true);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   775
        } else {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   776
            memoryRead.setGuard(guard);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   777
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   778
        read.replaceAtUsages(readValue);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   779
        graph.replaceFixed(read, memoryRead);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   780
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   781
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   782
    protected void lowerJavaWriteNode(JavaWriteNode write) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   783
        StructuredGraph graph = write.graph();
47798
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
   784
        ValueNode value = implicitStoreConvert(graph, write.getWriteKind(), write.value(), write.isCompressible());
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   785
        WriteNode memoryWrite = graph.add(new WriteNode(write.getAddress(), write.getLocationIdentity(), value, write.getBarrierType()));
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   786
        memoryWrite.setStateAfter(write.stateAfter());
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   787
        graph.replaceFixedWithFixed(write, memoryWrite);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   788
        memoryWrite.setGuard(write.getGuard());
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   789
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   790
49873
26ebfe8ce852 8199755: Update Graal
dlong
parents: 48861
diff changeset
   791
    @SuppressWarnings("try")
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   792
    protected void lowerCommitAllocationNode(CommitAllocationNode commit, LoweringTool tool) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   793
        StructuredGraph graph = commit.graph();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   794
        if (graph.getGuardsStage() == StructuredGraph.GuardsStage.FIXED_DEOPTS) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   795
            List<AbstractNewObjectNode> recursiveLowerings = new ArrayList<>();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   796
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   797
            ValueNode[] allocations = new ValueNode[commit.getVirtualObjects().size()];
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   798
            BitSet omittedValues = new BitSet();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   799
            int valuePos = 0;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   800
            for (int objIndex = 0; objIndex < commit.getVirtualObjects().size(); objIndex++) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   801
                VirtualObjectNode virtual = commit.getVirtualObjects().get(objIndex);
50330
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   802
                try (DebugCloseable nsp = graph.withNodeSourcePosition(virtual)) {
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   803
                    int entryCount = virtual.entryCount();
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   804
                    AbstractNewObjectNode newObject;
49873
26ebfe8ce852 8199755: Update Graal
dlong
parents: 48861
diff changeset
   805
                    if (virtual instanceof VirtualInstanceNode) {
26ebfe8ce852 8199755: Update Graal
dlong
parents: 48861
diff changeset
   806
                        newObject = graph.add(createNewInstanceFromVirtual(virtual));
26ebfe8ce852 8199755: Update Graal
dlong
parents: 48861
diff changeset
   807
                    } else {
26ebfe8ce852 8199755: Update Graal
dlong
parents: 48861
diff changeset
   808
                        newObject = graph.add(createNewArrayFromVirtual(virtual, ConstantNode.forInt(entryCount, graph)));
26ebfe8ce852 8199755: Update Graal
dlong
parents: 48861
diff changeset
   809
                    }
57537
ecc6e394475f 8226771: Update Graal
dlong
parents: 55509
diff changeset
   810
                    // The final STORE_STORE barrier will be emitted by finishAllocatedObjects
ecc6e394475f 8226771: Update Graal
dlong
parents: 55509
diff changeset
   811
                    newObject.clearEmitMemoryBarrier();
50330
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   812
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   813
                    recursiveLowerings.add(newObject);
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   814
                    graph.addBeforeFixed(commit, newObject);
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   815
                    allocations[objIndex] = newObject;
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   816
                    for (int i = 0; i < entryCount; i++) {
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   817
                        ValueNode value = commit.getValues().get(valuePos);
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   818
                        if (value instanceof VirtualObjectNode) {
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   819
                            value = allocations[commit.getVirtualObjects().indexOf(value)];
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   820
                        }
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   821
                        if (value == null) {
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   822
                            omittedValues.set(valuePos);
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   823
                        } else if (!(value.isConstant() && value.asConstant().isDefaultForKind())) {
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   824
                            // Constant.illegal is always the defaultForKind, so it is skipped
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   825
                            JavaKind valueKind = value.getStackKind();
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   826
                            JavaKind entryKind = virtual.entryKind(i);
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   827
50330
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   828
                            // Truffle requires some leniency in terms of what can be put where:
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   829
                            assert valueKind.getStackKind() == entryKind.getStackKind() ||
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   830
                                            (valueKind == JavaKind.Long || valueKind == JavaKind.Double || (valueKind == JavaKind.Int && virtual instanceof VirtualArrayNode));
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   831
                            AddressNode address = null;
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   832
                            BarrierType barrierType = null;
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   833
                            if (virtual instanceof VirtualInstanceNode) {
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   834
                                ResolvedJavaField field = ((VirtualInstanceNode) virtual).field(i);
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   835
                                long offset = fieldOffset(field);
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   836
                                if (offset >= 0) {
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   837
                                    address = createOffsetAddress(graph, newObject, offset);
55509
d58442b8abc1 8225497: Update Graal
jwilhelm
parents: 54914
diff changeset
   838
                                    barrierType = fieldInitializationBarrier(entryKind);
50330
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   839
                                }
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   840
                            } else {
52578
7dd81e82d083 8210777: Update Graal
dlong
parents: 51436
diff changeset
   841
                                address = createOffsetAddress(graph, newObject, metaAccess.getArrayBaseOffset(entryKind) + i * metaAccess.getArrayIndexScale(entryKind));
55509
d58442b8abc1 8225497: Update Graal
jwilhelm
parents: 54914
diff changeset
   842
                                barrierType = arrayInitializationBarrier(entryKind);
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   843
                            }
50330
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   844
                            if (address != null) {
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   845
                                WriteNode write = new WriteNode(address, LocationIdentity.init(), implicitStoreConvert(graph, entryKind, value), barrierType);
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   846
                                graph.addAfterFixed(newObject, graph.add(write));
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   847
                            }
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   848
                        }
50330
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   849
                        valuePos++;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   850
                    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   851
                }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   852
            }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   853
            valuePos = 0;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   854
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   855
            for (int objIndex = 0; objIndex < commit.getVirtualObjects().size(); objIndex++) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   856
                VirtualObjectNode virtual = commit.getVirtualObjects().get(objIndex);
50330
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   857
                try (DebugCloseable nsp = graph.withNodeSourcePosition(virtual)) {
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   858
                    int entryCount = virtual.entryCount();
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   859
                    ValueNode newObject = allocations[objIndex];
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   860
                    for (int i = 0; i < entryCount; i++) {
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   861
                        if (omittedValues.get(valuePos)) {
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   862
                            ValueNode value = commit.getValues().get(valuePos);
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   863
                            assert value instanceof VirtualObjectNode;
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   864
                            ValueNode allocValue = allocations[commit.getVirtualObjects().indexOf(value)];
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   865
                            if (!(allocValue.isConstant() && allocValue.asConstant().isDefaultForKind())) {
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   866
                                assert virtual.entryKind(i) == JavaKind.Object && allocValue.getStackKind() == JavaKind.Object;
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   867
                                AddressNode address;
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   868
                                BarrierType barrierType;
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   869
                                if (virtual instanceof VirtualInstanceNode) {
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   870
                                    VirtualInstanceNode virtualInstance = (VirtualInstanceNode) virtual;
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   871
                                    address = createFieldAddress(graph, newObject, virtualInstance.field(i));
54914
9feb4852536f 8223346: Update Graal
jwilhelm
parents: 54084
diff changeset
   872
                                    barrierType = fieldStoreBarrierType(virtualInstance.field(i));
50330
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   873
                                } else {
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   874
                                    address = createArrayAddress(graph, newObject, virtual.entryKind(i), ConstantNode.forInt(i, graph));
55509
d58442b8abc1 8225497: Update Graal
jwilhelm
parents: 54914
diff changeset
   875
                                    barrierType = arrayStoreBarrierType(virtual.entryKind(i));
50330
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   876
                                }
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   877
                                if (address != null) {
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   878
                                    WriteNode write = new WriteNode(address, LocationIdentity.init(), implicitStoreConvert(graph, JavaKind.Object, allocValue), barrierType);
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   879
                                    graph.addBeforeFixed(commit, graph.add(write));
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   880
                                }
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   881
                            }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   882
                        }
50330
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   883
                        valuePos++;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   884
                    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   885
                }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   886
            }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   887
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   888
            finishAllocatedObjects(tool, commit, allocations);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   889
            graph.removeFixed(commit);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   890
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   891
            for (AbstractNewObjectNode recursiveLowering : recursiveLowerings) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   892
                recursiveLowering.lower(tool);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   893
            }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   894
        }
50330
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   895
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   896
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   897
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   898
    public NewInstanceNode createNewInstanceFromVirtual(VirtualObjectNode virtual) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   899
        return new NewInstanceNode(virtual.type(), true);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   900
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   901
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   902
    protected NewArrayNode createNewArrayFromVirtual(VirtualObjectNode virtual, ValueNode length) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   903
        return new NewArrayNode(((VirtualArrayNode) virtual).componentType(), length, true);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   904
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   905
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   906
    public void finishAllocatedObjects(LoweringTool tool, CommitAllocationNode commit, ValueNode[] allocations) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   907
        StructuredGraph graph = commit.graph();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   908
        for (int objIndex = 0; objIndex < commit.getVirtualObjects().size(); objIndex++) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   909
            FixedValueAnchorNode anchor = graph.add(new FixedValueAnchorNode(allocations[objIndex]));
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   910
            allocations[objIndex] = anchor;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   911
            graph.addBeforeFixed(commit, anchor);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   912
        }
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46371
diff changeset
   913
        /*
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46371
diff changeset
   914
         * Note that the FrameState that is assigned to these MonitorEnterNodes isn't the correct
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46371
diff changeset
   915
         * state. It will be the state from before the allocation occurred instead of a valid state
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46371
diff changeset
   916
         * after the locking is performed. In practice this should be fine since these are newly
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46371
diff changeset
   917
         * allocated objects. The bytecodes themselves permit allocating an object, doing a
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46371
diff changeset
   918
         * monitorenter and then dropping all references to the object which would produce the same
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46371
diff changeset
   919
         * state, though that would normally produce an IllegalMonitorStateException. In HotSpot
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46371
diff changeset
   920
         * some form of fast path locking should always occur so the FrameState should never
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46371
diff changeset
   921
         * actually be used.
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46371
diff changeset
   922
         */
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46371
diff changeset
   923
        ArrayList<MonitorEnterNode> enters = null;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   924
        for (int objIndex = 0; objIndex < commit.getVirtualObjects().size(); objIndex++) {
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46371
diff changeset
   925
            List<MonitorIdNode> locks = commit.getLocks(objIndex);
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46371
diff changeset
   926
            if (locks.size() > 1) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46371
diff changeset
   927
                // Ensure that the lock operations are performed in lock depth order
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46371
diff changeset
   928
                ArrayList<MonitorIdNode> newList = new ArrayList<>(locks);
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46371
diff changeset
   929
                newList.sort((a, b) -> Integer.compare(a.getLockDepth(), b.getLockDepth()));
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46371
diff changeset
   930
                locks = newList;
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46371
diff changeset
   931
            }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46371
diff changeset
   932
            int lastDepth = -1;
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46371
diff changeset
   933
            for (MonitorIdNode monitorId : locks) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46371
diff changeset
   934
                assert lastDepth < monitorId.getLockDepth();
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46371
diff changeset
   935
                lastDepth = monitorId.getLockDepth();
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   936
                MonitorEnterNode enter = graph.add(new MonitorEnterNode(allocations[objIndex], monitorId));
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   937
                graph.addBeforeFixed(commit, enter);
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46371
diff changeset
   938
                if (enters == null) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46371
diff changeset
   939
                    enters = new ArrayList<>();
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46371
diff changeset
   940
                }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46371
diff changeset
   941
                enters.add(enter);
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46371
diff changeset
   942
            }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46371
diff changeset
   943
        }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46371
diff changeset
   944
        for (Node usage : commit.usages().snapshot()) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46371
diff changeset
   945
            if (usage instanceof AllocatedObjectNode) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46371
diff changeset
   946
                AllocatedObjectNode addObject = (AllocatedObjectNode) usage;
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46371
diff changeset
   947
                int index = commit.getVirtualObjects().indexOf(addObject.getVirtualObject());
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46371
diff changeset
   948
                addObject.replaceAtUsagesAndDelete(allocations[index]);
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46371
diff changeset
   949
            } else {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46371
diff changeset
   950
                assert enters != null;
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46371
diff changeset
   951
                commit.replaceAtUsages(InputType.Memory, enters.get(enters.size() - 1));
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46371
diff changeset
   952
            }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46371
diff changeset
   953
        }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46371
diff changeset
   954
        if (enters != null) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46371
diff changeset
   955
            for (MonitorEnterNode enter : enters) {
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   956
                enter.lower(tool);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   957
            }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   958
        }
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46371
diff changeset
   959
        assert commit.hasNoUsages();
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   960
        insertAllocationBarrier(commit, graph);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   961
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   962
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   963
    /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   964
     * Insert the required {@link MemoryBarriers#STORE_STORE} barrier for an allocation and also
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   965
     * include the {@link MemoryBarriers#LOAD_STORE} required for final fields if any final fields
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   966
     * are being written, as if {@link FinalFieldBarrierNode} were emitted.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   967
     */
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   968
    private static void insertAllocationBarrier(CommitAllocationNode commit, StructuredGraph graph) {
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   969
        int barrier = MemoryBarriers.STORE_STORE;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   970
        outer: for (VirtualObjectNode vobj : commit.getVirtualObjects()) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   971
            for (ResolvedJavaField field : vobj.type().getInstanceFields(true)) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   972
                if (field.isFinal()) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   973
                    barrier = barrier | MemoryBarriers.LOAD_STORE;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   974
                    break outer;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   975
                }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   976
            }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   977
        }
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   978
        graph.addAfterFixed(commit, graph.add(new MembarNode(barrier, LocationIdentity.init())));
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   979
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   980
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   981
    /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   982
     * @param field the field whose barrier type should be returned
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   983
     */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   984
    protected BarrierType fieldLoadBarrierType(ResolvedJavaField field) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   985
        return BarrierType.NONE;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   986
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   987
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   988
    protected BarrierType fieldStoreBarrierType(ResolvedJavaField field) {
55509
d58442b8abc1 8225497: Update Graal
jwilhelm
parents: 54914
diff changeset
   989
        if (getStorageKind(field) == JavaKind.Object) {
54914
9feb4852536f 8223346: Update Graal
jwilhelm
parents: 54084
diff changeset
   990
            return BarrierType.FIELD;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   991
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   992
        return BarrierType.NONE;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   993
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   994
55509
d58442b8abc1 8225497: Update Graal
jwilhelm
parents: 54914
diff changeset
   995
    protected BarrierType arrayStoreBarrierType(JavaKind elementKind) {
d58442b8abc1 8225497: Update Graal
jwilhelm
parents: 54914
diff changeset
   996
        if (elementKind == JavaKind.Object) {
54914
9feb4852536f 8223346: Update Graal
jwilhelm
parents: 54084
diff changeset
   997
            return BarrierType.ARRAY;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   998
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   999
        return BarrierType.NONE;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1000
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1001
55509
d58442b8abc1 8225497: Update Graal
jwilhelm
parents: 54914
diff changeset
  1002
    public BarrierType fieldInitializationBarrier(JavaKind entryKind) {
d58442b8abc1 8225497: Update Graal
jwilhelm
parents: 54914
diff changeset
  1003
        return entryKind == JavaKind.Object ? BarrierType.FIELD : BarrierType.NONE;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1004
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1005
55509
d58442b8abc1 8225497: Update Graal
jwilhelm
parents: 54914
diff changeset
  1006
    public BarrierType arrayInitializationBarrier(JavaKind entryKind) {
d58442b8abc1 8225497: Update Graal
jwilhelm
parents: 54914
diff changeset
  1007
        return entryKind == JavaKind.Object ? BarrierType.ARRAY : BarrierType.NONE;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1008
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1009
50330
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
  1010
    private BarrierType unsafeStoreBarrierType(RawStoreNode store) {
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
  1011
        if (!store.needsBarrier()) {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
  1012
            return BarrierType.NONE;
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
  1013
        }
50330
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
  1014
        return guessStoreBarrierType(store.object(), store.value());
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1015
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1016
50330
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
  1017
    private BarrierType guessStoreBarrierType(ValueNode object, ValueNode value) {
49873
26ebfe8ce852 8199755: Update Graal
dlong
parents: 48861
diff changeset
  1018
        if (value.getStackKind() == JavaKind.Object && object.getStackKind() == JavaKind.Object) {
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1019
            ResolvedJavaType type = StampTool.typeOrNull(object);
50330
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
  1020
            // Array types must use a precise barrier, so if the type is unknown or is a supertype
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
  1021
            // of Object[] then treat it as an array.
54914
9feb4852536f 8223346: Update Graal
jwilhelm
parents: 54084
diff changeset
  1022
            if (type != null && type.isArray()) {
55509
d58442b8abc1 8225497: Update Graal
jwilhelm
parents: 54914
diff changeset
  1023
                return BarrierType.ARRAY;
54914
9feb4852536f 8223346: Update Graal
jwilhelm
parents: 54084
diff changeset
  1024
            } else if (type == null || type.isAssignableFrom(objectArrayType)) {
9feb4852536f 8223346: Update Graal
jwilhelm
parents: 54084
diff changeset
  1025
                return BarrierType.UNKNOWN;
50330
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
  1026
            } else {
54914
9feb4852536f 8223346: Update Graal
jwilhelm
parents: 54084
diff changeset
  1027
                return BarrierType.FIELD;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1028
            }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1029
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1030
        return BarrierType.NONE;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1031
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1032
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1033
    public abstract int fieldOffset(ResolvedJavaField field);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1034
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1035
    public FieldLocationIdentity fieldLocationIdentity(ResolvedJavaField field) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1036
        return new FieldLocationIdentity(field);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1037
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1038
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1039
    public abstract ValueNode staticFieldBase(StructuredGraph graph, ResolvedJavaField field);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1040
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1041
    public abstract int arrayLengthOffset();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1042
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1043
    public Stamp loadStamp(Stamp stamp, JavaKind kind) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1044
        return loadStamp(stamp, kind, true);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1045
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1046
47798
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
  1047
    private boolean useCompressedOops(JavaKind kind, boolean compressible) {
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
  1048
        return kind == JavaKind.Object && compressible && useCompressedOops;
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
  1049
    }
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
  1050
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
  1051
    protected abstract Stamp loadCompressedStamp(ObjectStamp stamp);
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
  1052
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1053
    /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1054
     * @param compressible whether the stamp should be compressible
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1055
     */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1056
    protected Stamp loadStamp(Stamp stamp, JavaKind kind, boolean compressible) {
47798
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
  1057
        if (useCompressedOops(kind, compressible)) {
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
  1058
            return loadCompressedStamp((ObjectStamp) stamp);
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
  1059
        }
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
  1060
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1061
        switch (kind) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1062
            case Boolean:
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1063
            case Byte:
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1064
                return IntegerStamp.OPS.getNarrow().foldStamp(32, 8, stamp);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1065
            case Char:
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1066
            case Short:
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1067
                return IntegerStamp.OPS.getNarrow().foldStamp(32, 16, stamp);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1068
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1069
        return stamp;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1070
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1071
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1072
    public final ValueNode implicitLoadConvert(StructuredGraph graph, JavaKind kind, ValueNode value) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1073
        return implicitLoadConvert(graph, kind, value, true);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1074
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1075
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1076
    public ValueNode implicitLoadConvert(JavaKind kind, ValueNode value) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1077
        return implicitLoadConvert(kind, value, true);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1078
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1079
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1080
    protected final ValueNode implicitLoadConvert(StructuredGraph graph, JavaKind kind, ValueNode value, boolean compressible) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1081
        ValueNode ret = implicitLoadConvert(kind, value, compressible);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1082
        if (!ret.isAlive()) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1083
            ret = graph.addOrUnique(ret);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1084
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1085
        return ret;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1086
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1087
47798
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
  1088
    protected abstract ValueNode newCompressionNode(CompressionOp op, ValueNode value);
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
  1089
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1090
    /**
47798
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
  1091
     * @param compressible whether the convert should be compressible
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1092
     */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1093
    protected ValueNode implicitLoadConvert(JavaKind kind, ValueNode value, boolean compressible) {
47798
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
  1094
        if (useCompressedOops(kind, compressible)) {
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
  1095
            return newCompressionNode(CompressionOp.Uncompress, value);
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
  1096
        }
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
  1097
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1098
        switch (kind) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1099
            case Byte:
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1100
            case Short:
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1101
                return new SignExtendNode(value, 32);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1102
            case Boolean:
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1103
            case Char:
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1104
                return new ZeroExtendNode(value, 32);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1105
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1106
        return value;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1107
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1108
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1109
    public final ValueNode implicitStoreConvert(StructuredGraph graph, JavaKind kind, ValueNode value) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1110
        return implicitStoreConvert(graph, kind, value, true);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1111
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1112
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1113
    public ValueNode implicitStoreConvert(JavaKind kind, ValueNode value) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1114
        return implicitStoreConvert(kind, value, true);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1115
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1116
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1117
    protected final ValueNode implicitStoreConvert(StructuredGraph graph, JavaKind kind, ValueNode value, boolean compressible) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1118
        ValueNode ret = implicitStoreConvert(kind, value, compressible);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1119
        if (!ret.isAlive()) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1120
            ret = graph.addOrUnique(ret);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1121
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1122
        return ret;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1123
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1124
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1125
    /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1126
     * @param compressible whether the covert should be compressible
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1127
     */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1128
    protected ValueNode implicitStoreConvert(JavaKind kind, ValueNode value, boolean compressible) {
47798
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
  1129
        if (useCompressedOops(kind, compressible)) {
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
  1130
            return newCompressionNode(CompressionOp.Compress, value);
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
  1131
        }
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
  1132
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1133
        switch (kind) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1134
            case Boolean:
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1135
            case Byte:
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1136
                return new NarrowNode(value, 8);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1137
            case Char:
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1138
            case Short:
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1139
                return new NarrowNode(value, 16);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1140
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1141
        return value;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1142
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1143
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1144
    protected abstract ValueNode createReadHub(StructuredGraph graph, ValueNode object, LoweringTool tool);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1145
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1146
    protected abstract ValueNode createReadArrayComponentHub(StructuredGraph graph, ValueNode arrayHub, FixedNode anchor);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1147
52578
7dd81e82d083 8210777: Update Graal
dlong
parents: 51436
diff changeset
  1148
    protected ValueNode proxyIndex(AccessIndexedNode n, ValueNode index, ValueNode array, LoweringTool tool) {
7dd81e82d083 8210777: Update Graal
dlong
parents: 51436
diff changeset
  1149
        StructuredGraph graph = index.graph();
7dd81e82d083 8210777: Update Graal
dlong
parents: 51436
diff changeset
  1150
        ValueNode arrayLength = readOrCreateArrayLength(n, array, tool, graph);
7dd81e82d083 8210777: Update Graal
dlong
parents: 51436
diff changeset
  1151
        ValueNode lengthMinusOne = SubNode.create(arrayLength, ConstantNode.forInt(1), NodeView.DEFAULT);
7dd81e82d083 8210777: Update Graal
dlong
parents: 51436
diff changeset
  1152
        return branchlessMax(branchlessMin(index, lengthMinusOne, NodeView.DEFAULT), ConstantNode.forInt(0), NodeView.DEFAULT);
7dd81e82d083 8210777: Update Graal
dlong
parents: 51436
diff changeset
  1153
    }
7dd81e82d083 8210777: Update Graal
dlong
parents: 51436
diff changeset
  1154
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
  1155
    protected GuardingNode getBoundsCheck(AccessIndexedNode n, ValueNode array, LoweringTool tool) {
50330
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
  1156
        if (n.getBoundsCheck() != null) {
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
  1157
            return n.getBoundsCheck();
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
  1158
        }
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
  1159
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1160
        StructuredGraph graph = n.graph();
52578
7dd81e82d083 8210777: Update Graal
dlong
parents: 51436
diff changeset
  1161
        ValueNode arrayLength = readOrCreateArrayLength(n, array, tool, graph);
7dd81e82d083 8210777: Update Graal
dlong
parents: 51436
diff changeset
  1162
7dd81e82d083 8210777: Update Graal
dlong
parents: 51436
diff changeset
  1163
        LogicNode boundsCheck = IntegerBelowNode.create(n.index(), arrayLength, NodeView.DEFAULT);
7dd81e82d083 8210777: Update Graal
dlong
parents: 51436
diff changeset
  1164
        if (boundsCheck.isTautology()) {
7dd81e82d083 8210777: Update Graal
dlong
parents: 51436
diff changeset
  1165
            return null;
7dd81e82d083 8210777: Update Graal
dlong
parents: 51436
diff changeset
  1166
        }
7dd81e82d083 8210777: Update Graal
dlong
parents: 51436
diff changeset
  1167
        return tool.createGuard(n, graph.addOrUniqueWithInputs(boundsCheck), BoundsCheckException, InvalidateReprofile);
7dd81e82d083 8210777: Update Graal
dlong
parents: 51436
diff changeset
  1168
    }
7dd81e82d083 8210777: Update Graal
dlong
parents: 51436
diff changeset
  1169
7dd81e82d083 8210777: Update Graal
dlong
parents: 51436
diff changeset
  1170
    private ValueNode readOrCreateArrayLength(AccessIndexedNode n, ValueNode array, LoweringTool tool, StructuredGraph graph) {
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1171
        ValueNode arrayLength = readArrayLength(array, tool.getConstantReflection());
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1172
        if (arrayLength == null) {
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
  1173
            arrayLength = createReadArrayLength(array, n, tool);
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1174
        } else {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1175
            arrayLength = arrayLength.isAlive() ? arrayLength : graph.addOrUniqueWithInputs(arrayLength);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1176
        }
52578
7dd81e82d083 8210777: Update Graal
dlong
parents: 51436
diff changeset
  1177
        return arrayLength;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1178
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1179
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1180
    protected GuardingNode createNullCheck(ValueNode object, FixedNode before, LoweringTool tool) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1181
        if (StampTool.isPointerNonNull(object)) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1182
            return null;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1183
        }
50858
2d3e99a72541 8205824: Update Graal
never
parents: 50330
diff changeset
  1184
        return tool.createGuard(before, before.graph().unique(IsNullNode.create(object)), NullCheckException, InvalidateReprofile, SpeculationLog.NO_SPECULATION, true, null);
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1185
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1186
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
  1187
    protected ValueNode createNullCheckedValue(ValueNode object, FixedNode before, LoweringTool tool) {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
  1188
        GuardingNode nullCheck = createNullCheck(object, before, tool);
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
  1189
        if (nullCheck == null) {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
  1190
            return object;
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
  1191
        }
48190
25cfedf27edc 8192814: Update Graal
dlong
parents: 47798
diff changeset
  1192
        return before.graph().maybeAddOrUnique(PiNode.create(object, (object.stamp(NodeView.DEFAULT)).join(StampFactory.objectNonNull()), (ValueNode) nullCheck));
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
  1193
    }
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
  1194
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1195
    @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1196
    public ValueNode reconstructArrayIndex(JavaKind elementKind, AddressNode address) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1197
        StructuredGraph graph = address.graph();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1198
        ValueNode offset = ((OffsetAddressNode) address).getOffset();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1199
52578
7dd81e82d083 8210777: Update Graal
dlong
parents: 51436
diff changeset
  1200
        int base = metaAccess.getArrayBaseOffset(elementKind);
48190
25cfedf27edc 8192814: Update Graal
dlong
parents: 47798
diff changeset
  1201
        ValueNode scaledIndex = graph.unique(new SubNode(offset, ConstantNode.forIntegerStamp(offset.stamp(NodeView.DEFAULT), base, graph)));
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1202
52578
7dd81e82d083 8210777: Update Graal
dlong
parents: 51436
diff changeset
  1203
        int shift = CodeUtil.log2(metaAccess.getArrayIndexScale(elementKind));
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1204
        ValueNode ret = graph.unique(new RightShiftNode(scaledIndex, ConstantNode.forInt(shift, graph)));
48190
25cfedf27edc 8192814: Update Graal
dlong
parents: 47798
diff changeset
  1205
        return IntegerConvertNode.convert(ret, StampFactory.forKind(JavaKind.Int), graph, NodeView.DEFAULT);
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1206
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1207
}