src/jdk.internal.vm.compiler/share/classes/org.graalvm.compiler.nodes/src/org/graalvm/compiler/nodes/calc/IntegerLowerThanNode.java
author dlong
Tue, 24 Sep 2019 12:47:15 -0400
changeset 58299 6df94ce3ab2f
parent 54601 c40b2a190173
permissions -rw-r--r--
8229201: Update Graal Reviewed-by: kvn
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
     1
/*
58299
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 54601
diff changeset
     2
 * Copyright (c) 2017, 2019, Oracle and/or its affiliates. All rights reserved.
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
     4
 *
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
     7
 * published by the Free Software Foundation.
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
     8
 *
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
     9
 * This code is distributed in the hope that it will be useful, but WITHOUT
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
    10
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
    11
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
    12
 * version 2 for more details (a copy is included in the LICENSE file that
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
    13
 * accompanied this code).
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
    14
 *
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
    15
 * You should have received a copy of the GNU General Public License version
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
    16
 * 2 along with this work; if not, write to the Free Software Foundation,
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
    17
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
    18
 *
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
    19
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
    20
 * or visit www.oracle.com if you need additional information or have any
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
    21
 * questions.
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
    22
 */
50858
2d3e99a72541 8205824: Update Graal
never
parents: 49451
diff changeset
    23
2d3e99a72541 8205824: Update Graal
never
parents: 49451
diff changeset
    24
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
    25
package org.graalvm.compiler.nodes.calc;
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
    26
49451
e06f9607f370 8198969: Update Graal
iveresov
parents: 48861
diff changeset
    27
import static jdk.vm.ci.code.CodeUtil.mask;
e06f9607f370 8198969: Update Graal
iveresov
parents: 48861
diff changeset
    28
48861
47f19ff9903c 8194819: Update Graal
iveresov
parents: 48190
diff changeset
    29
import org.graalvm.compiler.core.common.calc.CanonicalCondition;
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
    30
import org.graalvm.compiler.core.common.type.IntegerStamp;
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
    31
import org.graalvm.compiler.core.common.type.Stamp;
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
    32
import org.graalvm.compiler.graph.NodeClass;
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
    33
import org.graalvm.compiler.nodeinfo.NodeInfo;
46371
0337d0617e7b 8178088: Update Graal
iveresov
parents: 46344
diff changeset
    34
import org.graalvm.compiler.nodes.ConstantNode;
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
    35
import org.graalvm.compiler.nodes.LogicConstantNode;
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
    36
import org.graalvm.compiler.nodes.LogicNegationNode;
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
    37
import org.graalvm.compiler.nodes.LogicNode;
48190
25cfedf27edc 8192814: Update Graal
dlong
parents: 47216
diff changeset
    38
import org.graalvm.compiler.nodes.NodeView;
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
    39
import org.graalvm.compiler.nodes.ValueNode;
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
    40
import org.graalvm.compiler.nodes.util.GraphUtil;
48861
47f19ff9903c 8194819: Update Graal
iveresov
parents: 48190
diff changeset
    41
import org.graalvm.compiler.options.OptionValues;
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
    42
52578
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
    43
import jdk.vm.ci.code.CodeUtil;
48861
47f19ff9903c 8194819: Update Graal
iveresov
parents: 48190
diff changeset
    44
import jdk.vm.ci.meta.ConstantReflectionProvider;
52578
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
    45
import jdk.vm.ci.meta.JavaConstant;
48861
47f19ff9903c 8194819: Update Graal
iveresov
parents: 48190
diff changeset
    46
import jdk.vm.ci.meta.MetaAccessProvider;
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
    47
import jdk.vm.ci.meta.TriState;
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
    48
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
    49
/**
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
    50
 * Common super-class for "a < b" comparisons both {@linkplain IntegerLowerThanNode signed} and
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
    51
 * {@linkplain IntegerBelowNode unsigned}.
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
    52
 */
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
    53
@NodeInfo()
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
    54
public abstract class IntegerLowerThanNode extends CompareNode {
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
    55
    public static final NodeClass<IntegerLowerThanNode> TYPE = NodeClass.create(IntegerLowerThanNode.class);
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
    56
    private final LowerOp op;
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
    57
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
    58
    protected IntegerLowerThanNode(NodeClass<? extends CompareNode> c, ValueNode x, ValueNode y, LowerOp op) {
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
    59
        super(c, op.getCondition(), false, x, y);
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
    60
        this.op = op;
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
    61
    }
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
    62
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
    63
    protected LowerOp getOp() {
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
    64
        return op;
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
    65
    }
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
    66
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
    67
    @Override
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
    68
    public Stamp getSucceedingStampForX(boolean negated, Stamp xStampGeneric, Stamp yStampGeneric) {
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
    69
        return getSucceedingStampForX(negated, !negated, xStampGeneric, yStampGeneric, getX(), getY());
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
    70
    }
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
    71
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
    72
    @Override
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
    73
    public Stamp getSucceedingStampForY(boolean negated, Stamp xStampGeneric, Stamp yStampGeneric) {
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
    74
        return getSucceedingStampForX(!negated, !negated, yStampGeneric, xStampGeneric, getY(), getX());
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
    75
    }
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
    76
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
    77
    private Stamp getSucceedingStampForX(boolean mirror, boolean strict, Stamp xStampGeneric, Stamp yStampGeneric, ValueNode forX, ValueNode forY) {
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
    78
        Stamp s = getSucceedingStampForX(mirror, strict, xStampGeneric, yStampGeneric);
49451
e06f9607f370 8198969: Update Graal
iveresov
parents: 48861
diff changeset
    79
        if (s != null && s.isUnrestricted()) {
e06f9607f370 8198969: Update Graal
iveresov
parents: 48861
diff changeset
    80
            s = null;
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
    81
        }
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
    82
        if (forY instanceof AddNode && xStampGeneric instanceof IntegerStamp) {
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
    83
            IntegerStamp xStamp = (IntegerStamp) xStampGeneric;
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
    84
            AddNode addNode = (AddNode) forY;
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
    85
            IntegerStamp aStamp = null;
48190
25cfedf27edc 8192814: Update Graal
dlong
parents: 47216
diff changeset
    86
            if (addNode.getX() == forX && addNode.getY().stamp(NodeView.DEFAULT) instanceof IntegerStamp) {
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
    87
                // x < x + a
48190
25cfedf27edc 8192814: Update Graal
dlong
parents: 47216
diff changeset
    88
                aStamp = (IntegerStamp) addNode.getY().stamp(NodeView.DEFAULT);
25cfedf27edc 8192814: Update Graal
dlong
parents: 47216
diff changeset
    89
            } else if (addNode.getY() == forX && addNode.getX().stamp(NodeView.DEFAULT) instanceof IntegerStamp) {
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
    90
                // x < a + x
48190
25cfedf27edc 8192814: Update Graal
dlong
parents: 47216
diff changeset
    91
                aStamp = (IntegerStamp) addNode.getX().stamp(NodeView.DEFAULT);
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
    92
            }
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
    93
            if (aStamp != null) {
52578
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
    94
                IntegerStamp result = getOp().getSucceedingStampForXLowerXPlusA(mirror, strict, aStamp, xStamp);
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
    95
                result = (IntegerStamp) xStamp.tryImproveWith(result);
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
    96
                if (result != null) {
49451
e06f9607f370 8198969: Update Graal
iveresov
parents: 48861
diff changeset
    97
                    if (s != null) {
e06f9607f370 8198969: Update Graal
iveresov
parents: 48861
diff changeset
    98
                        s = s.improveWith(result);
e06f9607f370 8198969: Update Graal
iveresov
parents: 48861
diff changeset
    99
                    } else {
e06f9607f370 8198969: Update Graal
iveresov
parents: 48861
diff changeset
   100
                        s = result;
e06f9607f370 8198969: Update Graal
iveresov
parents: 48861
diff changeset
   101
                    }
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   102
                }
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   103
            }
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   104
        }
49451
e06f9607f370 8198969: Update Graal
iveresov
parents: 48861
diff changeset
   105
        return s;
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   106
    }
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   107
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   108
    private Stamp getSucceedingStampForX(boolean mirror, boolean strict, Stamp xStampGeneric, Stamp yStampGeneric) {
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   109
        if (xStampGeneric instanceof IntegerStamp) {
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   110
            IntegerStamp xStamp = (IntegerStamp) xStampGeneric;
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   111
            if (yStampGeneric instanceof IntegerStamp) {
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   112
                IntegerStamp yStamp = (IntegerStamp) yStampGeneric;
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   113
                assert yStamp.getBits() == xStamp.getBits();
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   114
                Stamp s = getOp().getSucceedingStampForX(xStamp, yStamp, mirror, strict);
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   115
                if (s != null) {
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   116
                    return s;
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   117
                }
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   118
            }
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   119
        }
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   120
        return null;
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   121
    }
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   122
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   123
    @Override
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   124
    public TriState tryFold(Stamp xStampGeneric, Stamp yStampGeneric) {
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   125
        return getOp().tryFold(xStampGeneric, yStampGeneric);
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   126
    }
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   127
46393
d497d892ab11 8178864: Update Graal
iveresov
parents: 46371
diff changeset
   128
    public abstract static class LowerOp extends CompareOp {
d497d892ab11 8178864: Update Graal
iveresov
parents: 46371
diff changeset
   129
        @Override
48861
47f19ff9903c 8194819: Update Graal
iveresov
parents: 48190
diff changeset
   130
        public LogicNode canonical(ConstantReflectionProvider constantReflection, MetaAccessProvider metaAccess, OptionValues options, Integer smallestCompareWidth, CanonicalCondition condition,
48190
25cfedf27edc 8192814: Update Graal
dlong
parents: 47216
diff changeset
   131
                        boolean unorderedIsTrue, ValueNode forX, ValueNode forY, NodeView view) {
25cfedf27edc 8192814: Update Graal
dlong
parents: 47216
diff changeset
   132
            LogicNode result = super.canonical(constantReflection, metaAccess, options, smallestCompareWidth, condition, unorderedIsTrue, forX, forY, view);
46393
d497d892ab11 8178864: Update Graal
iveresov
parents: 46371
diff changeset
   133
            if (result != null) {
d497d892ab11 8178864: Update Graal
iveresov
parents: 46371
diff changeset
   134
                return result;
d497d892ab11 8178864: Update Graal
iveresov
parents: 46371
diff changeset
   135
            }
48190
25cfedf27edc 8192814: Update Graal
dlong
parents: 47216
diff changeset
   136
            LogicNode synonym = findSynonym(forX, forY, view);
46393
d497d892ab11 8178864: Update Graal
iveresov
parents: 46371
diff changeset
   137
            if (synonym != null) {
d497d892ab11 8178864: Update Graal
iveresov
parents: 46371
diff changeset
   138
                return synonym;
d497d892ab11 8178864: Update Graal
iveresov
parents: 46371
diff changeset
   139
            }
d497d892ab11 8178864: Update Graal
iveresov
parents: 46371
diff changeset
   140
            return null;
d497d892ab11 8178864: Update Graal
iveresov
parents: 46371
diff changeset
   141
        }
d497d892ab11 8178864: Update Graal
iveresov
parents: 46371
diff changeset
   142
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   143
        protected abstract long upperBound(IntegerStamp stamp);
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   144
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   145
        protected abstract long lowerBound(IntegerStamp stamp);
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   146
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   147
        protected abstract int compare(long a, long b);
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   148
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   149
        protected abstract long min(long a, long b);
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   150
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   151
        protected abstract long max(long a, long b);
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   152
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   153
        protected long min(long a, long b, int bits) {
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   154
            return min(cast(a, bits), cast(b, bits));
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   155
        }
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   156
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   157
        protected long max(long a, long b, int bits) {
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   158
            return max(cast(a, bits), cast(b, bits));
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   159
        }
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   160
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   161
        protected abstract long cast(long a, int bits);
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   162
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   163
        protected abstract long minValue(int bits);
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   164
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   165
        protected abstract long maxValue(int bits);
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   166
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   167
        protected abstract IntegerStamp forInteger(int bits, long min, long max);
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   168
48861
47f19ff9903c 8194819: Update Graal
iveresov
parents: 48190
diff changeset
   169
        protected abstract CanonicalCondition getCondition();
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   170
46371
0337d0617e7b 8178088: Update Graal
iveresov
parents: 46344
diff changeset
   171
        protected abstract IntegerLowerThanNode createNode(ValueNode x, ValueNode y);
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   172
48190
25cfedf27edc 8192814: Update Graal
dlong
parents: 47216
diff changeset
   173
        public LogicNode create(ValueNode x, ValueNode y, NodeView view) {
25cfedf27edc 8192814: Update Graal
dlong
parents: 47216
diff changeset
   174
            LogicNode result = CompareNode.tryConstantFoldPrimitive(getCondition(), x, y, false, view);
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   175
            if (result != null) {
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   176
                return result;
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   177
            } else {
48190
25cfedf27edc 8192814: Update Graal
dlong
parents: 47216
diff changeset
   178
                result = findSynonym(x, y, view);
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   179
                if (result != null) {
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   180
                    return result;
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   181
                }
46371
0337d0617e7b 8178088: Update Graal
iveresov
parents: 46344
diff changeset
   182
                return createNode(x, y);
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   183
            }
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   184
        }
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   185
48190
25cfedf27edc 8192814: Update Graal
dlong
parents: 47216
diff changeset
   186
        protected LogicNode findSynonym(ValueNode forX, ValueNode forY, NodeView view) {
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   187
            if (GraphUtil.unproxify(forX) == GraphUtil.unproxify(forY)) {
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   188
                return LogicConstantNode.contradiction();
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   189
            }
52578
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   190
            Stamp xStampGeneric = forX.stamp(view);
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   191
            TriState fold = tryFold(xStampGeneric, forY.stamp(view));
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   192
            if (fold.isTrue()) {
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   193
                return LogicConstantNode.tautology();
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   194
            } else if (fold.isFalse()) {
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   195
                return LogicConstantNode.contradiction();
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   196
            }
48190
25cfedf27edc 8192814: Update Graal
dlong
parents: 47216
diff changeset
   197
            if (forY.stamp(view) instanceof IntegerStamp) {
25cfedf27edc 8192814: Update Graal
dlong
parents: 47216
diff changeset
   198
                IntegerStamp yStamp = (IntegerStamp) forY.stamp(view);
52578
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   199
                IntegerStamp xStamp = (IntegerStamp) xStampGeneric;
46371
0337d0617e7b 8178088: Update Graal
iveresov
parents: 46344
diff changeset
   200
                int bits = yStamp.getBits();
0337d0617e7b 8178088: Update Graal
iveresov
parents: 46344
diff changeset
   201
                if (forX.isJavaConstant() && !forY.isConstant()) {
0337d0617e7b 8178088: Update Graal
iveresov
parents: 46344
diff changeset
   202
                    // bring the constant on the right
0337d0617e7b 8178088: Update Graal
iveresov
parents: 46344
diff changeset
   203
                    long xValue = forX.asJavaConstant().asLong();
0337d0617e7b 8178088: Update Graal
iveresov
parents: 46344
diff changeset
   204
                    if (xValue != maxValue(bits)) {
0337d0617e7b 8178088: Update Graal
iveresov
parents: 46344
diff changeset
   205
                        // c < x <=> !(c >= x) <=> !(x <= c) <=> !(x < c + 1)
48190
25cfedf27edc 8192814: Update Graal
dlong
parents: 47216
diff changeset
   206
                        return LogicNegationNode.create(create(forY, ConstantNode.forIntegerStamp(yStamp, xValue + 1), view));
46371
0337d0617e7b 8178088: Update Graal
iveresov
parents: 46344
diff changeset
   207
                    }
0337d0617e7b 8178088: Update Graal
iveresov
parents: 46344
diff changeset
   208
                }
0337d0617e7b 8178088: Update Graal
iveresov
parents: 46344
diff changeset
   209
                if (forY.isJavaConstant()) {
0337d0617e7b 8178088: Update Graal
iveresov
parents: 46344
diff changeset
   210
                    long yValue = forY.asJavaConstant().asLong();
52578
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   211
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   212
                    // x < MAX <=> x != MAX
46371
0337d0617e7b 8178088: Update Graal
iveresov
parents: 46344
diff changeset
   213
                    if (yValue == maxValue(bits)) {
48190
25cfedf27edc 8192814: Update Graal
dlong
parents: 47216
diff changeset
   214
                        return LogicNegationNode.create(IntegerEqualsNode.create(forX, forY, view));
46371
0337d0617e7b 8178088: Update Graal
iveresov
parents: 46344
diff changeset
   215
                    }
52578
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   216
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   217
                    // x < MIN + 1 <=> x <= MIN <=> x == MIN
46371
0337d0617e7b 8178088: Update Graal
iveresov
parents: 46344
diff changeset
   218
                    if (yValue == minValue(bits) + 1) {
48190
25cfedf27edc 8192814: Update Graal
dlong
parents: 47216
diff changeset
   219
                        return IntegerEqualsNode.create(forX, ConstantNode.forIntegerStamp(yStamp, minValue(bits)), view);
46371
0337d0617e7b 8178088: Update Graal
iveresov
parents: 46344
diff changeset
   220
                    }
52578
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   221
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   222
                    // (x < c && x >= c - 1) => x == c - 1
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   223
                    // If the constant is negative, only signed comparison is allowed.
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   224
                    if (yValue != minValue(bits) && xStamp.lowerBound() == yValue - 1 && (yValue > 0 || getCondition() == CanonicalCondition.LT)) {
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   225
                        return IntegerEqualsNode.create(forX, ConstantNode.forIntegerStamp(yStamp, yValue - 1), view);
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   226
                    }
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   227
46371
0337d0617e7b 8178088: Update Graal
iveresov
parents: 46344
diff changeset
   228
                } else if (forY instanceof AddNode) {
0337d0617e7b 8178088: Update Graal
iveresov
parents: 46344
diff changeset
   229
                    AddNode addNode = (AddNode) forY;
48190
25cfedf27edc 8192814: Update Graal
dlong
parents: 47216
diff changeset
   230
                    LogicNode canonical = canonicalizeXLowerXPlusA(forX, addNode, false, true, view);
46371
0337d0617e7b 8178088: Update Graal
iveresov
parents: 46344
diff changeset
   231
                    if (canonical != null) {
0337d0617e7b 8178088: Update Graal
iveresov
parents: 46344
diff changeset
   232
                        return canonical;
0337d0617e7b 8178088: Update Graal
iveresov
parents: 46344
diff changeset
   233
                    }
0337d0617e7b 8178088: Update Graal
iveresov
parents: 46344
diff changeset
   234
                }
0337d0617e7b 8178088: Update Graal
iveresov
parents: 46344
diff changeset
   235
                if (forX instanceof AddNode) {
0337d0617e7b 8178088: Update Graal
iveresov
parents: 46344
diff changeset
   236
                    AddNode addNode = (AddNode) forX;
48190
25cfedf27edc 8192814: Update Graal
dlong
parents: 47216
diff changeset
   237
                    LogicNode canonical = canonicalizeXLowerXPlusA(forY, addNode, true, false, view);
46371
0337d0617e7b 8178088: Update Graal
iveresov
parents: 46344
diff changeset
   238
                    if (canonical != null) {
0337d0617e7b 8178088: Update Graal
iveresov
parents: 46344
diff changeset
   239
                        return canonical;
0337d0617e7b 8178088: Update Graal
iveresov
parents: 46344
diff changeset
   240
                    }
0337d0617e7b 8178088: Update Graal
iveresov
parents: 46344
diff changeset
   241
                }
0337d0617e7b 8178088: Update Graal
iveresov
parents: 46344
diff changeset
   242
            }
0337d0617e7b 8178088: Update Graal
iveresov
parents: 46344
diff changeset
   243
            return null;
0337d0617e7b 8178088: Update Graal
iveresov
parents: 46344
diff changeset
   244
        }
0337d0617e7b 8178088: Update Graal
iveresov
parents: 46344
diff changeset
   245
52578
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   246
        /**
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   247
         * Exploit the fact that adding the (signed) MIN_VALUE on both side flips signed and
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   248
         * unsigned comparison.
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   249
         *
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   250
         * In particular:
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   251
         * <ul>
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   252
         * <li>{@code x + MIN_VALUE < y + MIN_VALUE <=> x |<| y}</li>
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   253
         * <li>{@code x + MIN_VALUE |<| y + MIN_VALUE <=> x < y}</li>
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   254
         * </ul>
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   255
         */
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   256
        protected static LogicNode canonicalizeRangeFlip(ValueNode forX, ValueNode forY, int bits, boolean signed, NodeView view) {
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   257
            long min = CodeUtil.minValue(bits);
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   258
            long xResidue = 0;
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   259
            ValueNode left = null;
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   260
            JavaConstant leftCst = null;
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   261
            if (forX instanceof AddNode) {
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   262
                AddNode xAdd = (AddNode) forX;
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   263
                if (xAdd.getY().isJavaConstant() && !xAdd.getY().asJavaConstant().isDefaultForKind()) {
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   264
                    long xCst = xAdd.getY().asJavaConstant().asLong();
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   265
                    xResidue = xCst - min;
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   266
                    left = xAdd.getX();
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   267
                }
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   268
            } else if (forX.isJavaConstant()) {
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   269
                leftCst = forX.asJavaConstant();
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   270
            }
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   271
            if (left == null && leftCst == null) {
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   272
                return null;
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   273
            }
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   274
            long yResidue = 0;
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   275
            ValueNode right = null;
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   276
            JavaConstant rightCst = null;
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   277
            if (forY instanceof AddNode) {
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   278
                AddNode yAdd = (AddNode) forY;
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   279
                if (yAdd.getY().isJavaConstant() && !yAdd.getY().asJavaConstant().isDefaultForKind()) {
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   280
                    long yCst = yAdd.getY().asJavaConstant().asLong();
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   281
                    yResidue = yCst - min;
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   282
                    right = yAdd.getX();
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   283
                }
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   284
            } else if (forY.isJavaConstant()) {
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   285
                rightCst = forY.asJavaConstant();
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   286
            }
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   287
            if (right == null && rightCst == null) {
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   288
                return null;
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   289
            }
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   290
            if ((xResidue == 0 && left != null) || (yResidue == 0 && right != null)) {
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   291
                if (left == null) {
54601
c40b2a190173 8221598: Update Graal
jwilhelm
parents: 52578
diff changeset
   292
                    // Fortify: Suppress Null Dereference false positive
c40b2a190173 8221598: Update Graal
jwilhelm
parents: 52578
diff changeset
   293
                    assert leftCst != null;
c40b2a190173 8221598: Update Graal
jwilhelm
parents: 52578
diff changeset
   294
52578
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   295
                    left = ConstantNode.forIntegerBits(bits, leftCst.asLong() - min);
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   296
                } else if (xResidue != 0) {
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   297
                    left = AddNode.create(left, ConstantNode.forIntegerBits(bits, xResidue), view);
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   298
                }
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   299
                if (right == null) {
54601
c40b2a190173 8221598: Update Graal
jwilhelm
parents: 52578
diff changeset
   300
                    // Fortify: Suppress Null Dereference false positive
c40b2a190173 8221598: Update Graal
jwilhelm
parents: 52578
diff changeset
   301
                    assert rightCst != null;
c40b2a190173 8221598: Update Graal
jwilhelm
parents: 52578
diff changeset
   302
52578
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   303
                    right = ConstantNode.forIntegerBits(bits, rightCst.asLong() - min);
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   304
                } else if (yResidue != 0) {
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   305
                    right = AddNode.create(right, ConstantNode.forIntegerBits(bits, yResidue), view);
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   306
                }
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   307
                if (signed) {
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   308
                    return new IntegerBelowNode(left, right);
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   309
                } else {
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   310
                    return new IntegerLessThanNode(left, right);
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   311
                }
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   312
            }
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   313
            return null;
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   314
        }
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   315
48190
25cfedf27edc 8192814: Update Graal
dlong
parents: 47216
diff changeset
   316
        private LogicNode canonicalizeXLowerXPlusA(ValueNode forX, AddNode addNode, boolean mirrored, boolean strict, NodeView view) {
46371
0337d0617e7b 8178088: Update Graal
iveresov
parents: 46344
diff changeset
   317
            // x < x + a
52578
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   318
            // x |<| x + a
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   319
            IntegerStamp xStamp = (IntegerStamp) forX.stamp(view);
46371
0337d0617e7b 8178088: Update Graal
iveresov
parents: 46344
diff changeset
   320
            IntegerStamp succeedingXStamp;
0337d0617e7b 8178088: Update Graal
iveresov
parents: 46344
diff changeset
   321
            boolean exact;
48190
25cfedf27edc 8192814: Update Graal
dlong
parents: 47216
diff changeset
   322
            if (addNode.getX() == forX && addNode.getY().stamp(view) instanceof IntegerStamp) {
25cfedf27edc 8192814: Update Graal
dlong
parents: 47216
diff changeset
   323
                IntegerStamp aStamp = (IntegerStamp) addNode.getY().stamp(view);
52578
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   324
                succeedingXStamp = getSucceedingStampForXLowerXPlusA(mirrored, strict, aStamp, xStamp);
46371
0337d0617e7b 8178088: Update Graal
iveresov
parents: 46344
diff changeset
   325
                exact = aStamp.lowerBound() == aStamp.upperBound();
48190
25cfedf27edc 8192814: Update Graal
dlong
parents: 47216
diff changeset
   326
            } else if (addNode.getY() == forX && addNode.getX().stamp(view) instanceof IntegerStamp) {
25cfedf27edc 8192814: Update Graal
dlong
parents: 47216
diff changeset
   327
                IntegerStamp aStamp = (IntegerStamp) addNode.getX().stamp(view);
52578
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   328
                succeedingXStamp = getSucceedingStampForXLowerXPlusA(mirrored, strict, aStamp, xStamp);
46371
0337d0617e7b 8178088: Update Graal
iveresov
parents: 46344
diff changeset
   329
                exact = aStamp.lowerBound() == aStamp.upperBound();
0337d0617e7b 8178088: Update Graal
iveresov
parents: 46344
diff changeset
   330
            } else {
0337d0617e7b 8178088: Update Graal
iveresov
parents: 46344
diff changeset
   331
                return null;
0337d0617e7b 8178088: Update Graal
iveresov
parents: 46344
diff changeset
   332
            }
48190
25cfedf27edc 8192814: Update Graal
dlong
parents: 47216
diff changeset
   333
            if (succeedingXStamp.join(forX.stamp(view)).isEmpty()) {
46371
0337d0617e7b 8178088: Update Graal
iveresov
parents: 46344
diff changeset
   334
                return LogicConstantNode.contradiction();
0337d0617e7b 8178088: Update Graal
iveresov
parents: 46344
diff changeset
   335
            } else if (exact && !succeedingXStamp.isEmpty()) {
0337d0617e7b 8178088: Update Graal
iveresov
parents: 46344
diff changeset
   336
                int bits = succeedingXStamp.getBits();
0337d0617e7b 8178088: Update Graal
iveresov
parents: 46344
diff changeset
   337
                if (compare(lowerBound(succeedingXStamp), minValue(bits)) > 0) {
0337d0617e7b 8178088: Update Graal
iveresov
parents: 46344
diff changeset
   338
                    // x must be in [L..MAX] <=> x >= L <=> !(x < L)
48190
25cfedf27edc 8192814: Update Graal
dlong
parents: 47216
diff changeset
   339
                    return LogicNegationNode.create(create(forX, ConstantNode.forIntegerStamp(succeedingXStamp, lowerBound(succeedingXStamp)), view));
46371
0337d0617e7b 8178088: Update Graal
iveresov
parents: 46344
diff changeset
   340
                } else if (compare(upperBound(succeedingXStamp), maxValue(bits)) < 0) {
0337d0617e7b 8178088: Update Graal
iveresov
parents: 46344
diff changeset
   341
                    // x must be in [MIN..H] <=> x <= H <=> !(H < x)
48190
25cfedf27edc 8192814: Update Graal
dlong
parents: 47216
diff changeset
   342
                    return LogicNegationNode.create(create(ConstantNode.forIntegerStamp(succeedingXStamp, upperBound(succeedingXStamp)), forX, view));
46371
0337d0617e7b 8178088: Update Graal
iveresov
parents: 46344
diff changeset
   343
                }
0337d0617e7b 8178088: Update Graal
iveresov
parents: 46344
diff changeset
   344
            }
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   345
            return null;
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   346
        }
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   347
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   348
        protected TriState tryFold(Stamp xStampGeneric, Stamp yStampGeneric) {
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   349
            if (xStampGeneric instanceof IntegerStamp && yStampGeneric instanceof IntegerStamp) {
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   350
                IntegerStamp xStamp = (IntegerStamp) xStampGeneric;
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   351
                IntegerStamp yStamp = (IntegerStamp) yStampGeneric;
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   352
                if (compare(upperBound(xStamp), lowerBound(yStamp)) < 0) {
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   353
                    return TriState.TRUE;
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   354
                }
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   355
                if (compare(lowerBound(xStamp), upperBound(yStamp)) >= 0) {
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   356
                    return TriState.FALSE;
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   357
                }
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   358
            }
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   359
            return TriState.UNKNOWN;
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   360
        }
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   361
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   362
        protected IntegerStamp getSucceedingStampForX(IntegerStamp xStamp, IntegerStamp yStamp, boolean mirror, boolean strict) {
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   363
            int bits = xStamp.getBits();
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   364
            assert yStamp.getBits() == bits;
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   365
            if (mirror) {
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   366
                long low = lowerBound(yStamp);
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   367
                if (strict) {
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   368
                    if (low == maxValue(bits)) {
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   369
                        return null;
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   370
                    }
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   371
                    low += 1;
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   372
                }
49451
e06f9607f370 8198969: Update Graal
iveresov
parents: 48861
diff changeset
   373
                if (compare(low, lowerBound(xStamp)) > 0 || upperBound(xStamp) != (xStamp.upperBound() & mask(xStamp.getBits()))) {
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   374
                    return forInteger(bits, low, upperBound(xStamp));
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   375
                }
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   376
            } else {
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   377
                // x < y, i.e., x < y <= Y_UPPER_BOUND so x <= Y_UPPER_BOUND - 1
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   378
                long low = upperBound(yStamp);
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   379
                if (strict) {
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   380
                    if (low == minValue(bits)) {
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   381
                        return null;
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   382
                    }
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   383
                    low -= 1;
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   384
                }
49451
e06f9607f370 8198969: Update Graal
iveresov
parents: 48861
diff changeset
   385
                if (compare(low, upperBound(xStamp)) < 0 || lowerBound(xStamp) != (xStamp.lowerBound() & mask(xStamp.getBits()))) {
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   386
                    return forInteger(bits, lowerBound(xStamp), low);
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   387
                }
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   388
            }
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   389
            return null;
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   390
        }
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   391
52578
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   392
        protected IntegerStamp getSucceedingStampForXLowerXPlusA(boolean mirrored, boolean strict, IntegerStamp aStamp, IntegerStamp xStamp) {
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   393
            int bits = aStamp.getBits();
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   394
            long min = minValue(bits);
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   395
            long max = maxValue(bits);
52578
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   396
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   397
            /*
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   398
             * if x < x + a <=> x + a didn't overflow:
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   399
             *
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   400
             * x is outside ]MAX - a, MAX], i.e., inside [MIN, MAX - a]
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   401
             *
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   402
             * if a is negative those bounds wrap around correctly.
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   403
             *
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   404
             * If a is exactly zero this gives an unbounded stamp (any integer) in the positive case
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   405
             * and an empty stamp in the negative case: if x |<| x is true, then either x has no
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   406
             * value or any value...
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   407
             *
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   408
             * This does not use upper/lowerBound from LowerOp because it's about the (signed)
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   409
             * addition not the comparison.
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   410
             */
46371
0337d0617e7b 8178088: Update Graal
iveresov
parents: 46344
diff changeset
   411
            if (mirrored) {
52578
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   412
                if (aStamp.contains(0)) {
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   413
                    // a may be zero
52578
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   414
                    return aStamp.unrestricted();
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   415
                }
52578
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   416
                return forInteger(bits, min(max - aStamp.lowerBound() + 1, max - aStamp.upperBound() + 1, bits), min(max, upperBound(xStamp)));
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   417
            } else {
52578
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   418
                long aLower = aStamp.lowerBound();
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   419
                long aUpper = aStamp.upperBound();
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   420
                if (strict) {
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   421
                    if (aLower == 0) {
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   422
                        aLower = 1;
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   423
                    }
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   424
                    if (aUpper == 0) {
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   425
                        aUpper = -1;
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   426
                    }
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   427
                    if (aLower > aUpper) {
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   428
                        // impossible
52578
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   429
                        return aStamp.empty();
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   430
                    }
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   431
                }
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   432
                if (aLower < 0 && aUpper > 0) {
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   433
                    // a may be zero
52578
7dd81e82d083 8210777: Update Graal
dlong
parents: 50858
diff changeset
   434
                    return aStamp.unrestricted();
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   435
                }
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   436
                return forInteger(bits, min, max(max - aLower, max - aUpper, bits));
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   437
            }
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   438
        }
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   439
    }
694c102fd8ed 8177046: Update Graal
iveresov
parents:
diff changeset
   440
}