src/jdk.internal.vm.compiler/share/classes/org.graalvm.compiler.core.common/src/org/graalvm/compiler/core/common/type/IntegerStamp.java
author dlong
Thu, 31 Oct 2019 16:54:16 -0700
changeset 58877 aec7bf35d6f5
parent 58299 6df94ce3ab2f
permissions -rw-r--r--
8233273: Update Graal Reviewed-by: kvn
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
     1
/*
58299
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 54601
diff changeset
     2
 * Copyright (c) 2012, 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.core.common.type;
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 org.graalvm.compiler.core.common.calc.FloatConvert.I2D;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    28
import static org.graalvm.compiler.core.common.calc.FloatConvert.I2F;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    29
import static org.graalvm.compiler.core.common.calc.FloatConvert.L2D;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    30
import static org.graalvm.compiler.core.common.calc.FloatConvert.L2F;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    31
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    32
import java.nio.ByteBuffer;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    33
import java.util.Formatter;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    34
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    35
import org.graalvm.compiler.core.common.LIRKind;
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
    36
import org.graalvm.compiler.core.common.NumUtil;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    37
import org.graalvm.compiler.core.common.spi.LIRKindTool;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    38
import org.graalvm.compiler.core.common.type.ArithmeticOpTable.BinaryOp;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    39
import org.graalvm.compiler.core.common.type.ArithmeticOpTable.FloatConvertOp;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    40
import org.graalvm.compiler.core.common.type.ArithmeticOpTable.IntegerConvertOp;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    41
import org.graalvm.compiler.core.common.type.ArithmeticOpTable.ShiftOp;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    42
import org.graalvm.compiler.core.common.type.ArithmeticOpTable.UnaryOp;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    43
import org.graalvm.compiler.debug.GraalError;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    44
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    45
import jdk.vm.ci.code.CodeUtil;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    46
import jdk.vm.ci.meta.Constant;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    47
import jdk.vm.ci.meta.JavaConstant;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    48
import jdk.vm.ci.meta.JavaKind;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    49
import jdk.vm.ci.meta.MetaAccessProvider;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    50
import jdk.vm.ci.meta.PrimitiveConstant;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    51
import jdk.vm.ci.meta.ResolvedJavaType;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    52
import jdk.vm.ci.meta.SerializableConstant;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    53
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    54
/**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    55
 * Describes the possible values of a node that produces an int or long result.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    56
 *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    57
 * The description consists of (inclusive) lower and upper bounds and up (may be set) and down
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    58
 * (always set) bit-masks.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    59
 */
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
    60
public final class IntegerStamp extends PrimitiveStamp {
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    61
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    62
    private final long lowerBound;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    63
    private final long upperBound;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    64
    private final long downMask;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    65
    private final long upMask;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    66
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
    67
    private IntegerStamp(int bits, long lowerBound, long upperBound, long downMask, long upMask) {
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    68
        super(bits, OPS);
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
    69
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    70
        this.lowerBound = lowerBound;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    71
        this.upperBound = upperBound;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    72
        this.downMask = downMask;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    73
        this.upMask = upMask;
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
    74
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    75
        assert lowerBound >= CodeUtil.minValue(bits) : this;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    76
        assert upperBound <= CodeUtil.maxValue(bits) : this;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    77
        assert (downMask & CodeUtil.mask(bits)) == downMask : this;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    78
        assert (upMask & CodeUtil.mask(bits)) == upMask : this;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    79
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    80
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
    81
    public static IntegerStamp create(int bits, long lowerBoundInput, long upperBoundInput) {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
    82
        return create(bits, lowerBoundInput, upperBoundInput, 0, CodeUtil.mask(bits));
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
    83
    }
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
    84
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
    85
    public static IntegerStamp create(int bits, long lowerBoundInput, long upperBoundInput, long downMask, long upMask) {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
    86
        assert (downMask & ~upMask) == 0 : String.format("\u21ca: %016x \u21c8: %016x", downMask, upMask);
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
    87
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
    88
        // Set lower bound, use masks to make it more precise
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
    89
        long minValue = minValueForMasks(bits, downMask, upMask);
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
    90
        long lowerBoundTmp = Math.max(lowerBoundInput, minValue);
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
    91
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
    92
        // Set upper bound, use masks to make it more precise
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
    93
        long maxValue = maxValueForMasks(bits, downMask, upMask);
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
    94
        long upperBoundTmp = Math.min(upperBoundInput, maxValue);
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
    95
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
    96
        // Assign masks now with the bounds in mind.
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
    97
        final long boundedDownMask;
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
    98
        final long boundedUpMask;
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
    99
        long defaultMask = CodeUtil.mask(bits);
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   100
        if (lowerBoundTmp == upperBoundTmp) {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   101
            boundedDownMask = lowerBoundTmp;
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   102
            boundedUpMask = lowerBoundTmp;
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   103
        } else if (lowerBoundTmp >= 0) {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   104
            int upperBoundLeadingZeros = Long.numberOfLeadingZeros(upperBoundTmp);
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   105
            long differentBits = lowerBoundTmp ^ upperBoundTmp;
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   106
            int sameBitCount = Long.numberOfLeadingZeros(differentBits << upperBoundLeadingZeros);
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   107
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   108
            boundedUpMask = upperBoundTmp | -1L >>> (upperBoundLeadingZeros + sameBitCount);
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   109
            boundedDownMask = upperBoundTmp & ~(-1L >>> (upperBoundLeadingZeros + sameBitCount));
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   110
        } else {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   111
            if (upperBoundTmp >= 0) {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   112
                boundedUpMask = defaultMask;
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   113
                boundedDownMask = 0;
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   114
            } else {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   115
                int lowerBoundLeadingOnes = Long.numberOfLeadingZeros(~lowerBoundTmp);
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   116
                long differentBits = lowerBoundTmp ^ upperBoundTmp;
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   117
                int sameBitCount = Long.numberOfLeadingZeros(differentBits << lowerBoundLeadingOnes);
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   118
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   119
                boundedUpMask = lowerBoundTmp | -1L >>> (lowerBoundLeadingOnes + sameBitCount) | ~(-1L >>> lowerBoundLeadingOnes);
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   120
                boundedDownMask = lowerBoundTmp & ~(-1L >>> (lowerBoundLeadingOnes + sameBitCount)) | ~(-1L >>> lowerBoundLeadingOnes);
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   121
            }
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   122
        }
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   123
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   124
        return new IntegerStamp(bits, lowerBoundTmp, upperBoundTmp, defaultMask & (downMask | boundedDownMask), defaultMask & upMask & boundedUpMask);
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   125
    }
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   126
49451
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
   127
    private static long significantBit(long bits, long value) {
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   128
        return (value >>> (bits - 1)) & 1;
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   129
    }
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   130
49451
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
   131
    private static long minValueForMasks(int bits, long downMask, long upMask) {
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   132
        if (significantBit(bits, upMask) == 0) {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   133
            // Value is always positive. Minimum value always positive.
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   134
            assert significantBit(bits, downMask) == 0;
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   135
            return downMask;
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   136
        } else {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   137
            // Value can be positive or negative. Minimum value always negative.
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   138
            return downMask | (-1L << (bits - 1));
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   139
        }
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   140
    }
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   141
49451
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
   142
    private static long maxValueForMasks(int bits, long downMask, long upMask) {
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   143
        if (significantBit(bits, downMask) == 1) {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   144
            // Value is always negative. Maximum value always negative.
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   145
            assert significantBit(bits, upMask) == 1;
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   146
            return CodeUtil.signExtend(upMask, bits);
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   147
        } else {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   148
            // Value can be positive or negative. Maximum value always positive.
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   149
            return upMask & (CodeUtil.mask(bits) >>> 1);
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   150
        }
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   151
    }
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   152
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   153
    public static IntegerStamp stampForMask(int bits, long downMask, long upMask) {
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   154
        return new IntegerStamp(bits, minValueForMasks(bits, downMask, upMask), maxValueForMasks(bits, downMask, upMask), downMask, upMask);
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   155
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   156
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   157
    @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   158
    public IntegerStamp unrestricted() {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   159
        return new IntegerStamp(getBits(), CodeUtil.minValue(getBits()), CodeUtil.maxValue(getBits()), 0, CodeUtil.mask(getBits()));
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   160
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   161
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   162
    @Override
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   163
    public IntegerStamp empty() {
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   164
        return new IntegerStamp(getBits(), CodeUtil.maxValue(getBits()), CodeUtil.minValue(getBits()), CodeUtil.mask(getBits()), 0);
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
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   167
    @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   168
    public Stamp constant(Constant c, MetaAccessProvider meta) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   169
        if (c instanceof PrimitiveConstant) {
58877
aec7bf35d6f5 8233273: Update Graal
dlong
parents: 58299
diff changeset
   170
            PrimitiveConstant primitiveConstant = (PrimitiveConstant) c;
aec7bf35d6f5 8233273: Update Graal
dlong
parents: 58299
diff changeset
   171
            long value = primitiveConstant.asLong();
aec7bf35d6f5 8233273: Update Graal
dlong
parents: 58299
diff changeset
   172
            if (primitiveConstant.getJavaKind() == JavaKind.Boolean && value == 1) {
aec7bf35d6f5 8233273: Update Graal
dlong
parents: 58299
diff changeset
   173
                // Need to special case booleans as integer stamps are always signed values.
aec7bf35d6f5 8233273: Update Graal
dlong
parents: 58299
diff changeset
   174
                value = -1;
aec7bf35d6f5 8233273: Update Graal
dlong
parents: 58299
diff changeset
   175
            }
aec7bf35d6f5 8233273: Update Graal
dlong
parents: 58299
diff changeset
   176
            Stamp returnedStamp = StampFactory.forInteger(getBits(), value, value);
aec7bf35d6f5 8233273: Update Graal
dlong
parents: 58299
diff changeset
   177
            assert returnedStamp.hasValues();
aec7bf35d6f5 8233273: Update Graal
dlong
parents: 58299
diff changeset
   178
            return returnedStamp;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   179
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   180
        return this;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   181
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   182
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   183
    @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   184
    public SerializableConstant deserialize(ByteBuffer buffer) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   185
        switch (getBits()) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   186
            case 1:
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   187
                return JavaConstant.forBoolean(buffer.get() != 0);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   188
            case 8:
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   189
                return JavaConstant.forByte(buffer.get());
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   190
            case 16:
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   191
                return JavaConstant.forShort(buffer.getShort());
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   192
            case 32:
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   193
                return JavaConstant.forInt(buffer.getInt());
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   194
            case 64:
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   195
                return JavaConstant.forLong(buffer.getLong());
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   196
            default:
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   197
                throw GraalError.shouldNotReachHere();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   198
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   199
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   200
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   201
    @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   202
    public boolean hasValues() {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   203
        return lowerBound <= upperBound;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   204
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   205
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   206
    @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   207
    public JavaKind getStackKind() {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   208
        if (getBits() > 32) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   209
            return JavaKind.Long;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   210
        } else {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   211
            return JavaKind.Int;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   212
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   213
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   214
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   215
    @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   216
    public LIRKind getLIRKind(LIRKindTool tool) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   217
        return tool.getIntegerKind(getBits());
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   218
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   219
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   220
    @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   221
    public ResolvedJavaType javaType(MetaAccessProvider metaAccess) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   222
        switch (getBits()) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   223
            case 1:
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   224
                return metaAccess.lookupJavaType(Boolean.TYPE);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   225
            case 8:
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   226
                return metaAccess.lookupJavaType(Byte.TYPE);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   227
            case 16:
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   228
                return metaAccess.lookupJavaType(Short.TYPE);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   229
            case 32:
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   230
                return metaAccess.lookupJavaType(Integer.TYPE);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   231
            case 64:
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   232
                return metaAccess.lookupJavaType(Long.TYPE);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   233
            default:
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   234
                throw GraalError.shouldNotReachHere();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   235
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   236
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   237
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   238
    /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   239
     * The signed inclusive lower bound on the value described by this stamp.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   240
     */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   241
    public long lowerBound() {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   242
        return lowerBound;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   243
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   244
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   245
    /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   246
     * The signed inclusive upper bound on the value described by this stamp.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   247
     */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   248
    public long upperBound() {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   249
        return upperBound;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   250
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   251
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   252
    /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   253
     * This bit-mask describes the bits that are always set in the value described by this stamp.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   254
     */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   255
    public long downMask() {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   256
        return downMask;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   257
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   258
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   259
    /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   260
     * This bit-mask describes the bits that can be set in the value described by this stamp.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   261
     */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   262
    public long upMask() {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   263
        return upMask;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   264
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   265
46371
0337d0617e7b 8178088: Update Graal
iveresov
parents: 46344
diff changeset
   266
    @Override
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   267
    public boolean isUnrestricted() {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   268
        return lowerBound == CodeUtil.minValue(getBits()) && upperBound == CodeUtil.maxValue(getBits()) && downMask == 0 && upMask == CodeUtil.mask(getBits());
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
    public boolean contains(long value) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   272
        return value >= lowerBound && value <= upperBound && (value & downMask) == downMask && (value & upMask) == (value & CodeUtil.mask(getBits()));
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   273
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   274
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   275
    public boolean isPositive() {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   276
        return lowerBound() >= 0;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   277
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   278
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   279
    public boolean isNegative() {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   280
        return upperBound() <= 0;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   281
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   282
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   283
    public boolean isStrictlyPositive() {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   284
        return lowerBound() > 0;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   285
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   286
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   287
    public boolean isStrictlyNegative() {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   288
        return upperBound() < 0;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   289
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   290
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   291
    public boolean canBePositive() {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   292
        return upperBound() > 0;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   293
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   294
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   295
    public boolean canBeNegative() {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   296
        return lowerBound() < 0;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   297
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   298
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   299
    @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   300
    public String toString() {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   301
        StringBuilder str = new StringBuilder();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   302
        str.append('i');
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   303
        str.append(getBits());
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   304
        if (hasValues()) {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   305
            if (lowerBound == upperBound) {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   306
                str.append(" [").append(lowerBound).append(']');
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   307
            } else if (lowerBound != CodeUtil.minValue(getBits()) || upperBound != CodeUtil.maxValue(getBits())) {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   308
                str.append(" [").append(lowerBound).append(" - ").append(upperBound).append(']');
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   309
            }
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   310
            if (downMask != 0) {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   311
                str.append(" \u21ca");
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   312
                new Formatter(str).format("%016x", downMask);
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   313
            }
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   314
            if (upMask != CodeUtil.mask(getBits())) {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   315
                str.append(" \u21c8");
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   316
                new Formatter(str).format("%016x", upMask);
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   317
            }
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   318
        } else {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   319
            str.append("<empty>");
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   320
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   321
        return str.toString();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   322
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   323
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   324
    private IntegerStamp createStamp(IntegerStamp other, long newUpperBound, long newLowerBound, long newDownMask, long newUpMask) {
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   325
        assert getBits() == other.getBits();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   326
        if (newLowerBound > newUpperBound || (newDownMask & (~newUpMask)) != 0 || (newUpMask == 0 && (newLowerBound > 0 || newUpperBound < 0))) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   327
            return empty();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   328
        } else if (newLowerBound == lowerBound && newUpperBound == upperBound && newDownMask == downMask && newUpMask == upMask) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   329
            return this;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   330
        } else if (newLowerBound == other.lowerBound && newUpperBound == other.upperBound && newDownMask == other.downMask && newUpMask == other.upMask) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   331
            return other;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   332
        } else {
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   333
            return IntegerStamp.create(getBits(), newLowerBound, newUpperBound, newDownMask, newUpMask);
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   334
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   335
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   336
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   337
    @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   338
    public Stamp meet(Stamp otherStamp) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   339
        if (otherStamp == this) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   340
            return this;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   341
        }
49451
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
   342
        if (isEmpty()) {
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
   343
            return otherStamp;
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
   344
        }
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
   345
        if (otherStamp.isEmpty()) {
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
   346
            return this;
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
   347
        }
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   348
        IntegerStamp other = (IntegerStamp) otherStamp;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   349
        return createStamp(other, Math.max(upperBound, other.upperBound), Math.min(lowerBound, other.lowerBound), downMask & other.downMask, upMask | other.upMask);
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
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   352
    @Override
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   353
    public IntegerStamp join(Stamp otherStamp) {
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   354
        if (otherStamp == this) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   355
            return this;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   356
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   357
        IntegerStamp other = (IntegerStamp) otherStamp;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   358
        long newDownMask = downMask | other.downMask;
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   359
        long newLowerBound = Math.max(lowerBound, other.lowerBound);
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   360
        long newUpperBound = Math.min(upperBound, other.upperBound);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   361
        long newUpMask = upMask & other.upMask;
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   362
        return createStamp(other, newUpperBound, newLowerBound, newDownMask, newUpMask);
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   363
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   364
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   365
    @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   366
    public boolean isCompatible(Stamp stamp) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   367
        if (this == stamp) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   368
            return true;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   369
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   370
        if (stamp instanceof IntegerStamp) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   371
            IntegerStamp other = (IntegerStamp) stamp;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   372
            return getBits() == other.getBits();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   373
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   374
        return false;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   375
    }
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
    @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   378
    public boolean isCompatible(Constant constant) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   379
        if (constant instanceof PrimitiveConstant) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   380
            PrimitiveConstant prim = (PrimitiveConstant) constant;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   381
            return prim.getJavaKind().isNumericInteger();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   382
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   383
        return false;
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
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   386
    public long unsignedUpperBound() {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   387
        if (sameSignBounds()) {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   388
            return CodeUtil.zeroExtend(upperBound(), getBits());
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   389
        }
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   390
        return NumUtil.maxValueUnsigned(getBits());
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   391
    }
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   392
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   393
    public long unsignedLowerBound() {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   394
        if (sameSignBounds()) {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   395
            return CodeUtil.zeroExtend(lowerBound(), getBits());
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   396
        }
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   397
        return 0;
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   398
    }
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   399
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   400
    private boolean sameSignBounds() {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   401
        return NumUtil.sameSign(lowerBound, upperBound);
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   402
    }
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   403
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   404
    @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   405
    public int hashCode() {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   406
        final int prime = 31;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   407
        int result = 1;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   408
        result = prime * result + super.hashCode();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   409
        result = prime * result + (int) (lowerBound ^ (lowerBound >>> 32));
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   410
        result = prime * result + (int) (upperBound ^ (upperBound >>> 32));
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   411
        result = prime * result + (int) (downMask ^ (downMask >>> 32));
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   412
        result = prime * result + (int) (upMask ^ (upMask >>> 32));
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   413
        return result;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   414
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   415
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   416
    @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   417
    public boolean equals(Object obj) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   418
        if (this == obj) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   419
            return true;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   420
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   421
        if (obj == null || getClass() != obj.getClass() || !super.equals(obj)) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   422
            return false;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   423
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   424
        IntegerStamp other = (IntegerStamp) obj;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   425
        if (lowerBound != other.lowerBound || upperBound != other.upperBound || downMask != other.downMask || upMask != other.upMask) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   426
            return false;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   427
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   428
        return super.equals(other);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   429
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   430
49451
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
   431
    private static long upMaskFor(int bits, long lowerBound, long upperBound) {
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   432
        long mask = lowerBound | upperBound;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   433
        if (mask == 0) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   434
            return 0;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   435
        } else {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   436
            return ((-1L) >>> Long.numberOfLeadingZeros(mask)) & CodeUtil.mask(bits);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   437
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   438
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   439
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   440
    /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   441
     * Checks if the 2 stamps represent values of the same sign. Returns true if the two stamps are
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   442
     * both positive of null or if they are both strictly negative
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   443
     *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   444
     * @return true if the two stamps are both positive of null or if they are both strictly
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   445
     *         negative
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   446
     */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   447
    public static boolean sameSign(IntegerStamp s1, IntegerStamp s2) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   448
        return s1.isPositive() && s2.isPositive() || s1.isStrictlyNegative() && s2.isStrictlyNegative();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   449
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   450
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   451
    @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   452
    public JavaConstant asConstant() {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   453
        if (lowerBound == upperBound) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   454
            switch (getBits()) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   455
                case 1:
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   456
                    return JavaConstant.forBoolean(lowerBound != 0);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   457
                case 8:
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   458
                    return JavaConstant.forByte((byte) lowerBound);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   459
                case 16:
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   460
                    return JavaConstant.forShort((short) lowerBound);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   461
                case 32:
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   462
                    return JavaConstant.forInt((int) lowerBound);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   463
                case 64:
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   464
                    return JavaConstant.forLong(lowerBound);
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
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   467
        return null;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   468
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   469
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   470
    public static boolean addCanOverflow(IntegerStamp a, IntegerStamp b) {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   471
        assert a.getBits() == b.getBits();
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   472
        return addOverflowsPositively(a.upperBound(), b.upperBound(), a.getBits()) ||
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   473
                        addOverflowsNegatively(a.lowerBound(), b.lowerBound(), a.getBits());
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   474
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   475
    }
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   476
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   477
    public static boolean addOverflowsPositively(long x, long y, int bits) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   478
        long result = x + y;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   479
        if (bits == 64) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   480
            return (~x & ~y & result) < 0;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   481
        } else {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   482
            return result > CodeUtil.maxValue(bits);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   483
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   484
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   485
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   486
    public static boolean addOverflowsNegatively(long x, long y, int bits) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   487
        long result = x + y;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   488
        if (bits == 64) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   489
            return (x & y & ~result) < 0;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   490
        } else {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   491
            return result < CodeUtil.minValue(bits);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   492
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   493
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   494
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   495
    public static long carryBits(long x, long y) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   496
        return (x + y) ^ x ^ y;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   497
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   498
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   499
    private static long saturate(long v, int bits) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   500
        if (bits < 64) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   501
            long max = CodeUtil.maxValue(bits);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   502
            if (v > max) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   503
                return max;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   504
            }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   505
            long min = CodeUtil.minValue(bits);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   506
            if (v < min) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   507
                return min;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   508
            }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   509
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   510
        return v;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   511
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   512
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   513
    public static boolean multiplicationOverflows(long a, long b, int bits) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   514
        assert bits <= 64 && bits >= 0;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   515
        long result = a * b;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   516
        // result is positive if the sign is the same
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   517
        boolean positive = (a >= 0 && b >= 0) || (a < 0 && b < 0);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   518
        if (bits == 64) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   519
            if (a > 0 && b > 0) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   520
                return a > 0x7FFFFFFF_FFFFFFFFL / b;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   521
            } else if (a > 0 && b <= 0) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   522
                return b < 0x80000000_00000000L / a;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   523
            } else if (a <= 0 && b > 0) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   524
                return a < 0x80000000_00000000L / b;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   525
            } else {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   526
                // a<=0 && b <=0
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   527
                return a != 0 && b < 0x7FFFFFFF_FFFFFFFFL / a;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   528
            }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   529
        } else {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   530
            if (positive) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   531
                return result > CodeUtil.maxValue(bits);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   532
            } else {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   533
                return result < CodeUtil.minValue(bits);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   534
            }
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
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   537
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   538
    public static boolean multiplicationCanOverflow(IntegerStamp a, IntegerStamp b) {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   539
        // see IntegerStamp#foldStamp for details
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   540
        assert a.getBits() == b.getBits();
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   541
        if (a.upMask() == 0) {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   542
            return false;
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   543
        } else if (b.upMask() == 0) {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   544
            return false;
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   545
        }
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   546
        if (a.isUnrestricted()) {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   547
            return true;
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   548
        }
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   549
        if (b.isUnrestricted()) {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   550
            return true;
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   551
        }
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   552
        int bits = a.getBits();
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   553
        long minNegA = a.lowerBound();
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   554
        long maxNegA = Math.min(0, a.upperBound());
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   555
        long minPosA = Math.max(0, a.lowerBound());
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   556
        long maxPosA = a.upperBound();
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   557
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   558
        long minNegB = b.lowerBound();
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   559
        long maxNegB = Math.min(0, b.upperBound());
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   560
        long minPosB = Math.max(0, b.lowerBound());
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   561
        long maxPosB = b.upperBound();
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   562
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   563
        boolean mayOverflow = false;
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   564
        if (a.canBePositive()) {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   565
            if (b.canBePositive()) {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   566
                mayOverflow |= IntegerStamp.multiplicationOverflows(maxPosA, maxPosB, bits);
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   567
                mayOverflow |= IntegerStamp.multiplicationOverflows(minPosA, minPosB, bits);
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   568
            }
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   569
            if (b.canBeNegative()) {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   570
                mayOverflow |= IntegerStamp.multiplicationOverflows(minPosA, maxNegB, bits);
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   571
                mayOverflow |= IntegerStamp.multiplicationOverflows(maxPosA, minNegB, bits);
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   572
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   573
            }
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   574
        }
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   575
        if (a.canBeNegative()) {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   576
            if (b.canBePositive()) {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   577
                mayOverflow |= IntegerStamp.multiplicationOverflows(maxNegA, minPosB, bits);
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   578
                mayOverflow |= IntegerStamp.multiplicationOverflows(minNegA, maxPosB, bits);
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   579
            }
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   580
            if (b.canBeNegative()) {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   581
                mayOverflow |= IntegerStamp.multiplicationOverflows(minNegA, minNegB, bits);
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   582
                mayOverflow |= IntegerStamp.multiplicationOverflows(maxNegA, maxNegB, bits);
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   583
            }
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   584
        }
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   585
        return mayOverflow;
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   586
    }
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   587
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   588
    public static boolean subtractionCanOverflow(IntegerStamp x, IntegerStamp y) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   589
        assert x.getBits() == y.getBits();
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   590
        return subtractionOverflows(x.lowerBound(), y.upperBound(), x.getBits()) || subtractionOverflows(x.upperBound(), y.lowerBound(), x.getBits());
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   591
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   592
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   593
    public static boolean subtractionOverflows(long x, long y, int bits) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   594
        long result = x - y;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   595
        if (bits == 64) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   596
            return (((x ^ y) & (x ^ result)) < 0);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   597
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   598
        return result < CodeUtil.minValue(bits) || result > CodeUtil.maxValue(bits);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   599
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   600
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   601
    public static final ArithmeticOpTable OPS = new ArithmeticOpTable(
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   602
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   603
                    new UnaryOp.Neg() {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   604
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   605
                        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   606
                        public Constant foldConstant(Constant value) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   607
                            PrimitiveConstant c = (PrimitiveConstant) value;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   608
                            return JavaConstant.forIntegerKind(c.getJavaKind(), -c.asLong());
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   609
                        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   610
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   611
                        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   612
                        public Stamp foldStamp(Stamp s) {
49451
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
   613
                            if (s.isEmpty()) {
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
   614
                                return s;
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
   615
                            }
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   616
                            IntegerStamp stamp = (IntegerStamp) s;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   617
                            int bits = stamp.getBits();
47798
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
   618
                            if (stamp.lowerBound == stamp.upperBound) {
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
   619
                                long value = CodeUtil.convert(-stamp.lowerBound(), stamp.getBits(), false);
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
   620
                                return StampFactory.forInteger(stamp.getBits(), value, value);
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
   621
                            }
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   622
                            if (stamp.lowerBound() != CodeUtil.minValue(bits)) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   623
                                // TODO(ls) check if the mask calculation is correct...
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   624
                                return StampFactory.forInteger(bits, -stamp.upperBound(), -stamp.lowerBound());
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   625
                            } else {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   626
                                return stamp.unrestricted();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   627
                            }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   628
                        }
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
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   631
                    new BinaryOp.Add(true, true) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   632
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   633
                        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   634
                        public Constant foldConstant(Constant const1, Constant const2) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   635
                            PrimitiveConstant a = (PrimitiveConstant) const1;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   636
                            PrimitiveConstant b = (PrimitiveConstant) const2;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   637
                            assert a.getJavaKind() == b.getJavaKind();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   638
                            return JavaConstant.forIntegerKind(a.getJavaKind(), a.asLong() + b.asLong());
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   639
                        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   640
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   641
                        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   642
                        public Stamp foldStamp(Stamp stamp1, Stamp stamp2) {
49451
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
   643
                            if (stamp1.isEmpty()) {
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
   644
                                return stamp1;
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
   645
                            }
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
   646
                            if (stamp2.isEmpty()) {
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
   647
                                return stamp2;
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
   648
                            }
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   649
                            IntegerStamp a = (IntegerStamp) stamp1;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   650
                            IntegerStamp b = (IntegerStamp) stamp2;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   651
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   652
                            int bits = a.getBits();
54601
c40b2a190173 8221598: Update Graal
jwilhelm
parents: 52910
diff changeset
   653
                            assert bits == b.getBits() : String.format("stamp1.bits=%d, stamp2.bits=%d", bits, b.getBits());
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   654
47798
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
   655
                            if (a.lowerBound == a.upperBound && b.lowerBound == b.upperBound) {
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
   656
                                long value = CodeUtil.convert(a.lowerBound() + b.lowerBound(), a.getBits(), false);
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
   657
                                return StampFactory.forInteger(a.getBits(), value, value);
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
   658
                            }
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
   659
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   660
                            if (a.isUnrestricted()) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   661
                                return a;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   662
                            } else if (b.isUnrestricted()) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   663
                                return b;
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
                            long defaultMask = CodeUtil.mask(bits);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   666
                            long variableBits = (a.downMask() ^ a.upMask()) | (b.downMask() ^ b.upMask());
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   667
                            long variableBitsWithCarry = variableBits | (carryBits(a.downMask(), b.downMask()) ^ carryBits(a.upMask(), b.upMask()));
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   668
                            long newDownMask = (a.downMask() + b.downMask()) & ~variableBitsWithCarry;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   669
                            long newUpMask = (a.downMask() + b.downMask()) | variableBitsWithCarry;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   670
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   671
                            newDownMask &= defaultMask;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   672
                            newUpMask &= defaultMask;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   673
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   674
                            long newLowerBound;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   675
                            long newUpperBound;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   676
                            boolean lowerOverflowsPositively = addOverflowsPositively(a.lowerBound(), b.lowerBound(), bits);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   677
                            boolean upperOverflowsPositively = addOverflowsPositively(a.upperBound(), b.upperBound(), bits);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   678
                            boolean lowerOverflowsNegatively = addOverflowsNegatively(a.lowerBound(), b.lowerBound(), bits);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   679
                            boolean upperOverflowsNegatively = addOverflowsNegatively(a.upperBound(), b.upperBound(), bits);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   680
                            if ((lowerOverflowsNegatively && !upperOverflowsNegatively) || (!lowerOverflowsPositively && upperOverflowsPositively)) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   681
                                newLowerBound = CodeUtil.minValue(bits);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   682
                                newUpperBound = CodeUtil.maxValue(bits);
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
                                newLowerBound = CodeUtil.signExtend((a.lowerBound() + b.lowerBound()) & defaultMask, bits);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   685
                                newUpperBound = CodeUtil.signExtend((a.upperBound() + b.upperBound()) & defaultMask, bits);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   686
                            }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   687
                            IntegerStamp limit = StampFactory.forInteger(bits, newLowerBound, newUpperBound);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   688
                            newUpMask &= limit.upMask();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   689
                            newUpperBound = CodeUtil.signExtend(newUpperBound & newUpMask, bits);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   690
                            newDownMask |= limit.downMask();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   691
                            newLowerBound |= newDownMask;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   692
                            return new IntegerStamp(bits, newLowerBound, newUpperBound, newDownMask, newUpMask);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   693
                        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   694
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   695
                        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   696
                        public boolean isNeutral(Constant value) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   697
                            PrimitiveConstant n = (PrimitiveConstant) value;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   698
                            return n.asLong() == 0;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   699
                        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   700
                    },
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   701
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   702
                    new BinaryOp.Sub(true, false) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   703
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   704
                        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   705
                        public Constant foldConstant(Constant const1, Constant const2) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   706
                            PrimitiveConstant a = (PrimitiveConstant) const1;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   707
                            PrimitiveConstant b = (PrimitiveConstant) const2;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   708
                            assert a.getJavaKind() == b.getJavaKind();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   709
                            return JavaConstant.forIntegerKind(a.getJavaKind(), a.asLong() - b.asLong());
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   710
                        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   711
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   712
                        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   713
                        public Stamp foldStamp(Stamp a, Stamp b) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   714
                            return OPS.getAdd().foldStamp(a, OPS.getNeg().foldStamp(b));
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
                        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   718
                        public boolean isNeutral(Constant value) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   719
                            PrimitiveConstant n = (PrimitiveConstant) value;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   720
                            return n.asLong() == 0;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   721
                        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   722
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   723
                        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   724
                        public Constant getZero(Stamp s) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   725
                            IntegerStamp stamp = (IntegerStamp) s;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   726
                            return JavaConstant.forPrimitiveInt(stamp.getBits(), 0);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   727
                        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   728
                    },
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   729
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   730
                    new BinaryOp.Mul(true, true) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   731
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   732
                        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   733
                        public Constant foldConstant(Constant const1, Constant const2) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   734
                            PrimitiveConstant a = (PrimitiveConstant) const1;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   735
                            PrimitiveConstant b = (PrimitiveConstant) const2;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   736
                            assert a.getJavaKind() == b.getJavaKind();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   737
                            return JavaConstant.forIntegerKind(a.getJavaKind(), a.asLong() * b.asLong());
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   738
                        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   739
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   740
                        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   741
                        public Stamp foldStamp(Stamp stamp1, Stamp stamp2) {
49451
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
   742
                            if (stamp1.isEmpty()) {
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
   743
                                return stamp1;
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
   744
                            }
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
   745
                            if (stamp2.isEmpty()) {
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
   746
                                return stamp2;
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
   747
                            }
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   748
                            IntegerStamp a = (IntegerStamp) stamp1;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   749
                            IntegerStamp b = (IntegerStamp) stamp2;
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
                            int bits = a.getBits();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   752
                            assert bits == b.getBits();
47798
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
   753
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
   754
                            if (a.lowerBound == a.upperBound && b.lowerBound == b.upperBound) {
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
   755
                                long value = CodeUtil.convert(a.lowerBound() * b.lowerBound(), a.getBits(), false);
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
   756
                                return StampFactory.forInteger(a.getBits(), value, value);
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
   757
                            }
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
   758
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   759
                            // if a==0 or b==0 result of a*b is always 0
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   760
                            if (a.upMask() == 0) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   761
                                return a;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   762
                            } else if (b.upMask() == 0) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   763
                                return b;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   764
                            } else {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   765
                                // if a has the full range or b, the result will also have it
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   766
                                if (a.isUnrestricted()) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   767
                                    return a;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   768
                                } else if (b.isUnrestricted()) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   769
                                    return b;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   770
                                }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   771
                                // a!=0 && b !=0 holds
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   772
                                long newLowerBound = Long.MAX_VALUE;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   773
                                long newUpperBound = Long.MIN_VALUE;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   774
                                /*
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   775
                                 * Based on the signs of the incoming stamps lower and upper bound
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   776
                                 * of the result of the multiplication may be swapped. LowerBound
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   777
                                 * can become upper bound if both signs are negative, and so on. To
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   778
                                 * determine the new values for lower and upper bound we need to
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   779
                                 * look at the max and min of the cases blow:
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
                                 * @formatter:off
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   782
                                 *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   783
                                 * a.lowerBound * b.lowerBound
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   784
                                 * a.lowerBound * b.upperBound
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   785
                                 * a.upperBound * b.lowerBound
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   786
                                 * a.upperBound * b.upperBound
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   787
                                 *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   788
                                 * @formatter:on
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
                                 * We are only interested in those cases that are relevant due to
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   791
                                 * the sign of the involved stamps (whether a stamp includes
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   792
                                 * negative and / or positive values). Based on the signs, the maximum
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   793
                                 * or minimum of the above multiplications form the new lower and
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   794
                                 * upper bounds.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   795
                                 *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   796
                                 * The table below contains the interesting candidates for lower and
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   797
                                 * upper bound after multiplication.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   798
                                 *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   799
                                 * For example if we consider two stamps a & b that both contain
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   800
                                 * negative and positive values, the product of minNegA * minNegB
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   801
                                 * (both the smallest negative value for each stamp) can only be the
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   802
                                 * highest positive number. The other candidates can be computed in
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   803
                                 * a similar fashion. Some of them can never be a new minimum or
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   804
                                 * maximum and are therefore excluded.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   805
                                 *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   806
                                 *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   807
                                 * @formatter:off
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   808
                                 *
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   809
                                 *          [x................0................y]
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   810
                                 *          -------------------------------------
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   811
                                 *          [minNeg     maxNeg minPos     maxPos]
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   812
                                 *
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   813
                                 *          where maxNeg = min(0,y) && minPos = max(0,x)
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   814
                                 *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   815
                                 *
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   816
                                 *                 |minNegA  maxNegA    minPosA  maxPosA
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   817
                                 *         _______ |____________________________________
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   818
                                 *         minNegB | MAX        /     :     /      MIN
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   819
                                 *         maxNegB |  /        MIN    :    MAX      /
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   820
                                 *                 |------------------+-----------------
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   821
                                 *         minPosB |  /        MAX    :    MIN      /
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   822
                                 *         maxPosB | MIN        /     :     /      MAX
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   823
                                 *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   824
                                 * @formatter:on
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   825
                                 */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   826
                                // We materialize all factors here. If they are needed, the signs of
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   827
                                // the stamp will ensure the correct value is used.
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   828
                                long minNegA = a.lowerBound();
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   829
                                long maxNegA = Math.min(0, a.upperBound());
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   830
                                long minPosA = Math.max(0, a.lowerBound());
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   831
                                long maxPosA = a.upperBound();
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   832
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   833
                                long minNegB = b.lowerBound();
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   834
                                long maxNegB = Math.min(0, b.upperBound());
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   835
                                long minPosB = Math.max(0, b.lowerBound());
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   836
                                long maxPosB = b.upperBound();
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   837
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   838
                                // multiplication has shift semantics
47798
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
   839
                                long newUpMask = ~CodeUtil.mask(Math.min(64, Long.numberOfTrailingZeros(a.upMask) + Long.numberOfTrailingZeros(b.upMask))) & CodeUtil.mask(bits);
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   840
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   841
                                if (a.canBePositive()) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   842
                                    if (b.canBePositive()) {
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   843
                                        if (multiplicationOverflows(maxPosA, maxPosB, bits)) {
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   844
                                            return a.unrestricted();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   845
                                        }
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   846
                                        long maxCandidate = maxPosA * maxPosB;
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   847
                                        if (multiplicationOverflows(minPosA, minPosB, bits)) {
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   848
                                            return a.unrestricted();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   849
                                        }
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   850
                                        long minCandidate = minPosA * minPosB;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   851
                                        newLowerBound = Math.min(newLowerBound, minCandidate);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   852
                                        newUpperBound = Math.max(newUpperBound, maxCandidate);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   853
                                    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   854
                                    if (b.canBeNegative()) {
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   855
                                        if (multiplicationOverflows(minPosA, maxNegB, bits)) {
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   856
                                            return a.unrestricted();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   857
                                        }
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   858
                                        long maxCandidate = minPosA * maxNegB;
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   859
                                        if (multiplicationOverflows(maxPosA, minNegB, bits)) {
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   860
                                            return a.unrestricted();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   861
                                        }
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   862
                                        long minCandidate = maxPosA * minNegB;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   863
                                        newLowerBound = Math.min(newLowerBound, minCandidate);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   864
                                        newUpperBound = Math.max(newUpperBound, maxCandidate);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   865
                                    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   866
                                }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   867
                                if (a.canBeNegative()) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   868
                                    if (b.canBePositive()) {
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   869
                                        if (multiplicationOverflows(maxNegA, minPosB, bits)) {
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   870
                                            return a.unrestricted();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   871
                                        }
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   872
                                        long maxCandidate = maxNegA * minPosB;
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   873
                                        if (multiplicationOverflows(minNegA, maxPosB, bits)) {
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   874
                                            return a.unrestricted();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   875
                                        }
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   876
                                        long minCandidate = minNegA * maxPosB;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   877
                                        newLowerBound = Math.min(newLowerBound, minCandidate);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   878
                                        newUpperBound = Math.max(newUpperBound, maxCandidate);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   879
                                    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   880
                                    if (b.canBeNegative()) {
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   881
                                        if (multiplicationOverflows(minNegA, minNegB, bits)) {
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   882
                                            return a.unrestricted();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   883
                                        }
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   884
                                        long maxCandidate = minNegA * minNegB;
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   885
                                        if (multiplicationOverflows(maxNegA, maxNegB, bits)) {
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   886
                                            return a.unrestricted();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   887
                                        }
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   888
                                        long minCandidate = maxNegA * maxNegB;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   889
                                        newLowerBound = Math.min(newLowerBound, minCandidate);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   890
                                        newUpperBound = Math.max(newUpperBound, maxCandidate);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   891
                                    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   892
                                }
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
                                assert newLowerBound <= newUpperBound;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   895
                                return StampFactory.forIntegerWithMask(bits, newLowerBound, newUpperBound, 0, newUpMask);
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
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   899
                        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   900
                        public boolean isNeutral(Constant value) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   901
                            PrimitiveConstant n = (PrimitiveConstant) value;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   902
                            return n.asLong() == 1;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   903
                        }
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
46963
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   906
                    new BinaryOp.MulHigh(true, true) {
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   907
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   908
                        @Override
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   909
                        public Constant foldConstant(Constant const1, Constant const2) {
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   910
                            PrimitiveConstant a = (PrimitiveConstant) const1;
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   911
                            PrimitiveConstant b = (PrimitiveConstant) const2;
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   912
                            assert a.getJavaKind() == b.getJavaKind();
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   913
                            return JavaConstant.forIntegerKind(a.getJavaKind(), multiplyHigh(a.asLong(), b.asLong(), a.getJavaKind()));
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   914
                        }
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   915
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   916
                        @Override
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   917
                        public Stamp foldStamp(Stamp stamp1, Stamp stamp2) {
49451
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
   918
                            if (stamp1.isEmpty()) {
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
   919
                                return stamp1;
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
   920
                            }
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
   921
                            if (stamp2.isEmpty()) {
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
   922
                                return stamp2;
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
   923
                            }
46963
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   924
                            IntegerStamp a = (IntegerStamp) stamp1;
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   925
                            IntegerStamp b = (IntegerStamp) stamp2;
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   926
                            JavaKind javaKind = a.getStackKind();
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   927
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   928
                            assert a.getBits() == b.getBits();
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   929
                            assert javaKind == b.getStackKind();
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   930
                            assert (javaKind == JavaKind.Int || javaKind == JavaKind.Long);
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   931
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   932
                            if (a.isEmpty() || b.isEmpty()) {
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   933
                                return a.empty();
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   934
                            } else if (a.isUnrestricted() || b.isUnrestricted()) {
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   935
                                return a.unrestricted();
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   936
                            }
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   937
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   938
                            long[] xExtremes = {a.lowerBound(), a.upperBound()};
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   939
                            long[] yExtremes = {b.lowerBound(), b.upperBound()};
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   940
                            long min = Long.MAX_VALUE;
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   941
                            long max = Long.MIN_VALUE;
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   942
                            for (long x : xExtremes) {
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   943
                                for (long y : yExtremes) {
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   944
                                    long result = multiplyHigh(x, y, javaKind);
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   945
                                    min = Math.min(min, result);
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   946
                                    max = Math.max(max, result);
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   947
                                }
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   948
                            }
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   949
                            return StampFactory.forInteger(javaKind, min, max);
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   950
                        }
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   951
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   952
                        @Override
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   953
                        public boolean isNeutral(Constant value) {
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   954
                            return false;
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   955
                        }
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   956
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   957
                        private long multiplyHigh(long x, long y, JavaKind javaKind) {
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   958
                            if (javaKind == JavaKind.Int) {
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   959
                                return (x * y) >> 32;
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   960
                            } else {
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   961
                                assert javaKind == JavaKind.Long;
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   962
                                long x0 = x & 0xFFFFFFFFL;
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   963
                                long x1 = x >> 32;
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   964
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   965
                                long y0 = y & 0xFFFFFFFFL;
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   966
                                long y1 = y >> 32;
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   967
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   968
                                long z0 = x0 * y0;
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   969
                                long t = x1 * y0 + (z0 >>> 32);
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   970
                                long z1 = t & 0xFFFFFFFFL;
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   971
                                long z2 = t >> 32;
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   972
                                z1 += x0 * y1;
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   973
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   974
                                return x1 * y1 + z2 + (z1 >> 32);
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   975
                            }
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   976
                        }
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   977
                    },
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   978
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   979
                    new BinaryOp.UMulHigh(true, true) {
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   980
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   981
                        @Override
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   982
                        public Constant foldConstant(Constant const1, Constant const2) {
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   983
                            PrimitiveConstant a = (PrimitiveConstant) const1;
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   984
                            PrimitiveConstant b = (PrimitiveConstant) const2;
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   985
                            assert a.getJavaKind() == b.getJavaKind();
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   986
                            return JavaConstant.forIntegerKind(a.getJavaKind(), multiplyHighUnsigned(a.asLong(), b.asLong(), a.getJavaKind()));
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   987
                        }
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   988
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   989
                        @Override
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   990
                        public Stamp foldStamp(Stamp stamp1, Stamp stamp2) {
49451
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
   991
                            if (stamp1.isEmpty()) {
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
   992
                                return stamp1;
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
   993
                            }
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
   994
                            if (stamp2.isEmpty()) {
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
   995
                                return stamp2;
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
   996
                            }
46963
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   997
                            IntegerStamp a = (IntegerStamp) stamp1;
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   998
                            IntegerStamp b = (IntegerStamp) stamp2;
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
   999
                            JavaKind javaKind = a.getStackKind();
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1000
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1001
                            assert a.getBits() == b.getBits();
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1002
                            assert javaKind == b.getStackKind();
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1003
                            assert (javaKind == JavaKind.Int || javaKind == JavaKind.Long);
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1004
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1005
                            if (a.isEmpty() || b.isEmpty()) {
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1006
                                return a.empty();
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1007
                            } else if (a.isUnrestricted() || b.isUnrestricted()) {
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1008
                                return a.unrestricted();
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1009
                            }
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1010
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1011
                            // Note that the minima and maxima are calculated using signed min/max
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1012
                            // functions, while the values themselves are unsigned.
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1013
                            long[] xExtremes = getUnsignedExtremes(a);
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1014
                            long[] yExtremes = getUnsignedExtremes(b);
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1015
                            long min = Long.MAX_VALUE;
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1016
                            long max = Long.MIN_VALUE;
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1017
                            for (long x : xExtremes) {
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1018
                                for (long y : yExtremes) {
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1019
                                    long result = multiplyHighUnsigned(x, y, javaKind);
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1020
                                    min = Math.min(min, result);
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1021
                                    max = Math.max(max, result);
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1022
                                }
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1023
                            }
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1024
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1025
                            // if min is negative, then the value can reach into the unsigned range
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1026
                            if (min == max || min >= 0) {
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1027
                                return StampFactory.forInteger(javaKind, min, max);
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1028
                            } else {
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1029
                                return StampFactory.forKind(javaKind);
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1030
                            }
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1031
                        }
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1032
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1033
                        @Override
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1034
                        public boolean isNeutral(Constant value) {
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1035
                            return false;
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1036
                        }
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1037
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1038
                        private long[] getUnsignedExtremes(IntegerStamp stamp) {
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1039
                            if (stamp.lowerBound() < 0 && stamp.upperBound() >= 0) {
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1040
                                /*
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1041
                                 * If -1 and 0 are both in the signed range, then we can't say
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1042
                                 * anything about the unsigned range, so we have to return [0,
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1043
                                 * MAX_UNSIGNED].
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1044
                                 */
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1045
                                return new long[]{0, -1L};
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1046
                            } else {
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1047
                                return new long[]{stamp.lowerBound(), stamp.upperBound()};
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1048
                            }
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1049
                        }
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1050
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1051
                        private long multiplyHighUnsigned(long x, long y, JavaKind javaKind) {
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1052
                            if (javaKind == JavaKind.Int) {
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1053
                                long xl = x & 0xFFFFFFFFL;
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1054
                                long yl = y & 0xFFFFFFFFL;
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1055
                                long r = xl * yl;
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1056
                                return (int) (r >>> 32);
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1057
                            } else {
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1058
                                assert javaKind == JavaKind.Long;
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1059
                                long x0 = x & 0xFFFFFFFFL;
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1060
                                long x1 = x >>> 32;
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1061
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1062
                                long y0 = y & 0xFFFFFFFFL;
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1063
                                long y1 = y >>> 32;
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1064
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1065
                                long z0 = x0 * y0;
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1066
                                long t = x1 * y0 + (z0 >>> 32);
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1067
                                long z1 = t & 0xFFFFFFFFL;
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1068
                                long z2 = t >>> 32;
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1069
                                z1 += x0 * y1;
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1070
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1071
                                return x1 * y1 + z2 + (z1 >>> 32);
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1072
                            }
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1073
                        }
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1074
                    },
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1075
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1076
                    new BinaryOp.Div(true, false) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1077
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1078
                        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1079
                        public Constant foldConstant(Constant const1, Constant const2) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1080
                            PrimitiveConstant a = (PrimitiveConstant) const1;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1081
                            PrimitiveConstant b = (PrimitiveConstant) const2;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1082
                            assert a.getJavaKind() == b.getJavaKind();
47798
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
  1083
                            if (b.asLong() == 0) {
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
  1084
                                return null;
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
  1085
                            }
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1086
                            return JavaConstant.forIntegerKind(a.getJavaKind(), a.asLong() / b.asLong());
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1087
                        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1088
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1089
                        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1090
                        public Stamp foldStamp(Stamp stamp1, Stamp stamp2) {
49451
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
  1091
                            if (stamp1.isEmpty()) {
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
  1092
                                return stamp1;
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
  1093
                            }
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
  1094
                            if (stamp2.isEmpty()) {
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
  1095
                                return stamp2;
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
  1096
                            }
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1097
                            IntegerStamp a = (IntegerStamp) stamp1;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1098
                            IntegerStamp b = (IntegerStamp) stamp2;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1099
                            assert a.getBits() == b.getBits();
47798
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
  1100
                            if (a.lowerBound == a.upperBound && b.lowerBound == b.upperBound && b.lowerBound != 0) {
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
  1101
                                long value = CodeUtil.convert(a.lowerBound() / b.lowerBound(), a.getBits(), false);
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
  1102
                                return StampFactory.forInteger(a.getBits(), value, value);
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
  1103
                            } else if (b.isStrictlyPositive()) {
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
  1104
                                long newLowerBound = a.lowerBound() < 0 ? a.lowerBound() / b.lowerBound() : a.lowerBound() / b.upperBound();
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
  1105
                                long newUpperBound = a.upperBound() < 0 ? a.upperBound() / b.upperBound() : a.upperBound() / b.lowerBound();
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1106
                                return StampFactory.forInteger(a.getBits(), newLowerBound, newUpperBound);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1107
                            } else {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1108
                                return a.unrestricted();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1109
                            }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1110
                        }
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
                        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1113
                        public boolean isNeutral(Constant value) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1114
                            PrimitiveConstant n = (PrimitiveConstant) value;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1115
                            return n.asLong() == 1;
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
                    },
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1118
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1119
                    new BinaryOp.Rem(false, false) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1120
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1121
                        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1122
                        public Constant foldConstant(Constant const1, Constant const2) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1123
                            PrimitiveConstant a = (PrimitiveConstant) const1;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1124
                            PrimitiveConstant b = (PrimitiveConstant) const2;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1125
                            assert a.getJavaKind() == b.getJavaKind();
47798
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
  1126
                            if (b.asLong() == 0) {
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
  1127
                                return null;
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
  1128
                            }
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1129
                            return JavaConstant.forIntegerKind(a.getJavaKind(), a.asLong() % b.asLong());
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1130
                        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1131
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1132
                        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1133
                        public Stamp foldStamp(Stamp stamp1, Stamp stamp2) {
49451
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
  1134
                            if (stamp1.isEmpty()) {
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
  1135
                                return stamp1;
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
  1136
                            }
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
  1137
                            if (stamp2.isEmpty()) {
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
  1138
                                return stamp2;
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
  1139
                            }
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1140
                            IntegerStamp a = (IntegerStamp) stamp1;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1141
                            IntegerStamp b = (IntegerStamp) stamp2;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1142
                            assert a.getBits() == b.getBits();
47798
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
  1143
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
  1144
                            if (a.lowerBound == a.upperBound && b.lowerBound == b.upperBound && b.lowerBound != 0) {
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
  1145
                                long value = CodeUtil.convert(a.lowerBound() % b.lowerBound(), a.getBits(), false);
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
  1146
                                return StampFactory.forInteger(a.getBits(), value, value);
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
  1147
                            }
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
  1148
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1149
                            // zero is always possible
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1150
                            long newLowerBound = Math.min(a.lowerBound(), 0);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1151
                            long newUpperBound = Math.max(a.upperBound(), 0);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1152
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1153
                            /* the maximum absolute value of the result, derived from b */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1154
                            long magnitude;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1155
                            if (b.lowerBound() == CodeUtil.minValue(b.getBits())) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1156
                                // Math.abs(...) - 1 does not work in a case
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1157
                                magnitude = CodeUtil.maxValue(b.getBits());
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1158
                            } else {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1159
                                magnitude = Math.max(Math.abs(b.lowerBound()), Math.abs(b.upperBound())) - 1;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1160
                            }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1161
                            newLowerBound = Math.max(newLowerBound, -magnitude);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1162
                            newUpperBound = Math.min(newUpperBound, magnitude);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1163
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1164
                            return StampFactory.forInteger(a.getBits(), newLowerBound, newUpperBound);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1165
                        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1166
                    },
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1167
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1168
                    new UnaryOp.Not() {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1169
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1170
                        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1171
                        public Constant foldConstant(Constant c) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1172
                            PrimitiveConstant value = (PrimitiveConstant) c;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1173
                            return JavaConstant.forIntegerKind(value.getJavaKind(), ~value.asLong());
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1174
                        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1175
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1176
                        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1177
                        public Stamp foldStamp(Stamp stamp) {
49451
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
  1178
                            if (stamp.isEmpty()) {
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
  1179
                                return stamp;
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
  1180
                            }
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1181
                            IntegerStamp integerStamp = (IntegerStamp) stamp;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1182
                            int bits = integerStamp.getBits();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1183
                            long defaultMask = CodeUtil.mask(bits);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1184
                            return new IntegerStamp(bits, ~integerStamp.upperBound(), ~integerStamp.lowerBound(), (~integerStamp.upMask()) & defaultMask, (~integerStamp.downMask()) & defaultMask);
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
                    },
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1187
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1188
                    new BinaryOp.And(true, true) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1189
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1190
                        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1191
                        public Constant foldConstant(Constant const1, Constant const2) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1192
                            PrimitiveConstant a = (PrimitiveConstant) const1;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1193
                            PrimitiveConstant b = (PrimitiveConstant) const2;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1194
                            assert a.getJavaKind() == b.getJavaKind();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1195
                            return JavaConstant.forIntegerKind(a.getJavaKind(), a.asLong() & b.asLong());
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1196
                        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1197
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1198
                        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1199
                        public Stamp foldStamp(Stamp stamp1, Stamp stamp2) {
49451
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
  1200
                            if (stamp1.isEmpty()) {
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
  1201
                                return stamp1;
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
  1202
                            }
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
  1203
                            if (stamp2.isEmpty()) {
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
  1204
                                return stamp2;
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
  1205
                            }
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1206
                            IntegerStamp a = (IntegerStamp) stamp1;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1207
                            IntegerStamp b = (IntegerStamp) stamp2;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1208
                            assert a.getBits() == b.getBits();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1209
                            return stampForMask(a.getBits(), a.downMask() & b.downMask(), a.upMask() & b.upMask());
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1210
                        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1211
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1212
                        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1213
                        public boolean isNeutral(Constant value) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1214
                            PrimitiveConstant n = (PrimitiveConstant) value;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1215
                            int bits = n.getJavaKind().getBitCount();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1216
                            long mask = CodeUtil.mask(bits);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1217
                            return (n.asLong() & mask) == mask;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1218
                        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1219
                    },
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1220
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1221
                    new BinaryOp.Or(true, true) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1222
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1223
                        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1224
                        public Constant foldConstant(Constant const1, Constant const2) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1225
                            PrimitiveConstant a = (PrimitiveConstant) const1;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1226
                            PrimitiveConstant b = (PrimitiveConstant) const2;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1227
                            assert a.getJavaKind() == b.getJavaKind();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1228
                            return JavaConstant.forIntegerKind(a.getJavaKind(), a.asLong() | b.asLong());
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1229
                        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1230
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1231
                        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1232
                        public Stamp foldStamp(Stamp stamp1, Stamp stamp2) {
49451
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
  1233
                            if (stamp1.isEmpty()) {
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
  1234
                                return stamp1;
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
  1235
                            }
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
  1236
                            if (stamp2.isEmpty()) {
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
  1237
                                return stamp2;
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
  1238
                            }
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1239
                            IntegerStamp a = (IntegerStamp) stamp1;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1240
                            IntegerStamp b = (IntegerStamp) stamp2;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1241
                            assert a.getBits() == b.getBits();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1242
                            return stampForMask(a.getBits(), a.downMask() | b.downMask(), a.upMask() | b.upMask());
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1243
                        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1244
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1245
                        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1246
                        public boolean isNeutral(Constant value) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1247
                            PrimitiveConstant n = (PrimitiveConstant) value;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1248
                            return n.asLong() == 0;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1249
                        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1250
                    },
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1251
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1252
                    new BinaryOp.Xor(true, true) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1253
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1254
                        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1255
                        public Constant foldConstant(Constant const1, Constant const2) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1256
                            PrimitiveConstant a = (PrimitiveConstant) const1;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1257
                            PrimitiveConstant b = (PrimitiveConstant) const2;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1258
                            assert a.getJavaKind() == b.getJavaKind();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1259
                            return JavaConstant.forIntegerKind(a.getJavaKind(), a.asLong() ^ b.asLong());
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1260
                        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1261
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1262
                        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1263
                        public Stamp foldStamp(Stamp stamp1, Stamp stamp2) {
49451
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
  1264
                            if (stamp1.isEmpty()) {
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
  1265
                                return stamp1;
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
  1266
                            }
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
  1267
                            if (stamp2.isEmpty()) {
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
  1268
                                return stamp2;
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
  1269
                            }
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1270
                            IntegerStamp a = (IntegerStamp) stamp1;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1271
                            IntegerStamp b = (IntegerStamp) stamp2;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1272
                            assert a.getBits() == b.getBits();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1273
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1274
                            long variableBits = (a.downMask() ^ a.upMask()) | (b.downMask() ^ b.upMask());
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1275
                            long newDownMask = (a.downMask() ^ b.downMask()) & ~variableBits;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1276
                            long newUpMask = (a.downMask() ^ b.downMask()) | variableBits;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1277
                            return stampForMask(a.getBits(), newDownMask, newUpMask);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1278
                        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1279
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1280
                        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1281
                        public boolean isNeutral(Constant value) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1282
                            PrimitiveConstant n = (PrimitiveConstant) value;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1283
                            return n.asLong() == 0;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1284
                        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1285
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1286
                        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1287
                        public Constant getZero(Stamp s) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1288
                            IntegerStamp stamp = (IntegerStamp) s;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1289
                            return JavaConstant.forPrimitiveInt(stamp.getBits(), 0);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1290
                        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1291
                    },
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1292
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1293
                    new ShiftOp.Shl() {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1294
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1295
                        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1296
                        public Constant foldConstant(Constant value, int amount) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1297
                            PrimitiveConstant c = (PrimitiveConstant) value;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1298
                            switch (c.getJavaKind()) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1299
                                case Int:
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1300
                                    return JavaConstant.forInt(c.asInt() << amount);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1301
                                case Long:
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1302
                                    return JavaConstant.forLong(c.asLong() << amount);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1303
                                default:
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1304
                                    throw GraalError.shouldNotReachHere();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1305
                            }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1306
                        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1307
54601
c40b2a190173 8221598: Update Graal
jwilhelm
parents: 52910
diff changeset
  1308
                        private boolean testNoSignChangeAfterShifting(int bits, long value, int shiftAmount) {
c40b2a190173 8221598: Update Graal
jwilhelm
parents: 52910
diff changeset
  1309
                            long removedBits = -1L << (bits - shiftAmount - 1);
c40b2a190173 8221598: Update Graal
jwilhelm
parents: 52910
diff changeset
  1310
                            if (value < 0) {
c40b2a190173 8221598: Update Graal
jwilhelm
parents: 52910
diff changeset
  1311
                                return (value & removedBits) == removedBits;
c40b2a190173 8221598: Update Graal
jwilhelm
parents: 52910
diff changeset
  1312
                            } else {
c40b2a190173 8221598: Update Graal
jwilhelm
parents: 52910
diff changeset
  1313
                                return (value & removedBits) == 0;
c40b2a190173 8221598: Update Graal
jwilhelm
parents: 52910
diff changeset
  1314
                            }
c40b2a190173 8221598: Update Graal
jwilhelm
parents: 52910
diff changeset
  1315
                        }
c40b2a190173 8221598: Update Graal
jwilhelm
parents: 52910
diff changeset
  1316
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1317
                        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1318
                        public Stamp foldStamp(Stamp stamp, IntegerStamp shift) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1319
                            IntegerStamp value = (IntegerStamp) stamp;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1320
                            int bits = value.getBits();
46963
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1321
                            if (value.isEmpty()) {
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1322
                                return value;
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1323
                            } else if (shift.isEmpty()) {
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1324
                                return StampFactory.forInteger(bits).empty();
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1325
                            } else if (value.upMask() == 0) {
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1326
                                return value;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1327
                            }
46963
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1328
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1329
                            int shiftMask = getShiftAmountMask(stamp);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1330
                            int shiftBits = Integer.bitCount(shiftMask);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1331
                            if (shift.lowerBound() == shift.upperBound()) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1332
                                int shiftAmount = (int) (shift.lowerBound() & shiftMask);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1333
                                if (shiftAmount == 0) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1334
                                    return value;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1335
                                }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1336
                                // the mask of bits that will be lost or shifted into the sign bit
54601
c40b2a190173 8221598: Update Graal
jwilhelm
parents: 52910
diff changeset
  1337
                                if (testNoSignChangeAfterShifting(bits, value.lowerBound(), shiftAmount) && testNoSignChangeAfterShifting(bits, value.upperBound(), shiftAmount)) {
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1338
                                    /*
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1339
                                     * use a better stamp if neither lower nor upper bound can lose
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1340
                                     * bits
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1341
                                     */
54601
c40b2a190173 8221598: Update Graal
jwilhelm
parents: 52910
diff changeset
  1342
                                    IntegerStamp result = new IntegerStamp(bits, value.lowerBound() << shiftAmount, value.upperBound() << shiftAmount,
c40b2a190173 8221598: Update Graal
jwilhelm
parents: 52910
diff changeset
  1343
                                                    (value.downMask() << shiftAmount) & CodeUtil.mask(bits),
c40b2a190173 8221598: Update Graal
jwilhelm
parents: 52910
diff changeset
  1344
                                                    (value.upMask() << shiftAmount) & CodeUtil.mask(bits));
c40b2a190173 8221598: Update Graal
jwilhelm
parents: 52910
diff changeset
  1345
                                    return result;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1346
                                }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1347
                            }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1348
                            if ((shift.lowerBound() >>> shiftBits) == (shift.upperBound() >>> shiftBits)) {
46963
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1349
                                long defaultMask = CodeUtil.mask(bits);
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1350
                                long downMask = defaultMask;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1351
                                long upMask = 0;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1352
                                for (long i = shift.lowerBound(); i <= shift.upperBound(); i++) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1353
                                    if (shift.contains(i)) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1354
                                        downMask &= value.downMask() << (i & shiftMask);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1355
                                        upMask |= value.upMask() << (i & shiftMask);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1356
                                    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1357
                                }
49451
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
  1358
                                return IntegerStamp.stampForMask(bits, downMask, upMask & defaultMask);
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1359
                            }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1360
                            return value.unrestricted();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1361
                        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1362
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1363
                        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1364
                        public int getShiftAmountMask(Stamp s) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1365
                            IntegerStamp stamp = (IntegerStamp) s;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1366
                            assert CodeUtil.isPowerOf2(stamp.getBits());
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1367
                            return stamp.getBits() - 1;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1368
                        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1369
                    },
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1370
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1371
                    new ShiftOp.Shr() {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1372
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1373
                        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1374
                        public Constant foldConstant(Constant value, int amount) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1375
                            PrimitiveConstant c = (PrimitiveConstant) value;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1376
                            switch (c.getJavaKind()) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1377
                                case Int:
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1378
                                    return JavaConstant.forInt(c.asInt() >> amount);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1379
                                case Long:
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1380
                                    return JavaConstant.forLong(c.asLong() >> amount);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1381
                                default:
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1382
                                    throw GraalError.shouldNotReachHere();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1383
                            }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1384
                        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1385
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1386
                        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1387
                        public Stamp foldStamp(Stamp stamp, IntegerStamp shift) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1388
                            IntegerStamp value = (IntegerStamp) stamp;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1389
                            int bits = value.getBits();
46963
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1390
                            if (value.isEmpty()) {
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1391
                                return value;
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1392
                            } else if (shift.isEmpty()) {
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1393
                                return StampFactory.forInteger(bits).empty();
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1394
                            } else if (shift.lowerBound() == shift.upperBound()) {
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1395
                                long shiftCount = shift.lowerBound() & getShiftAmountMask(stamp);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1396
                                if (shiftCount == 0) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1397
                                    return stamp;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1398
                                }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1399
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1400
                                int extraBits = 64 - bits;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1401
                                long defaultMask = CodeUtil.mask(bits);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1402
                                // shifting back and forth performs sign extension
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1403
                                long downMask = (value.downMask() << extraBits) >> (shiftCount + extraBits) & defaultMask;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1404
                                long upMask = (value.upMask() << extraBits) >> (shiftCount + extraBits) & defaultMask;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1405
                                return new IntegerStamp(bits, value.lowerBound() >> shiftCount, value.upperBound() >> shiftCount, downMask, upMask);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1406
                            }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1407
                            long mask = IntegerStamp.upMaskFor(bits, value.lowerBound(), value.upperBound());
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1408
                            return IntegerStamp.stampForMask(bits, 0, mask);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1409
                        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1410
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1411
                        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1412
                        public int getShiftAmountMask(Stamp s) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1413
                            IntegerStamp stamp = (IntegerStamp) s;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1414
                            assert CodeUtil.isPowerOf2(stamp.getBits());
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1415
                            return stamp.getBits() - 1;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1416
                        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1417
                    },
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1418
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1419
                    new ShiftOp.UShr() {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1420
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1421
                        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1422
                        public Constant foldConstant(Constant value, int amount) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1423
                            PrimitiveConstant c = (PrimitiveConstant) value;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1424
                            switch (c.getJavaKind()) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1425
                                case Int:
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1426
                                    return JavaConstant.forInt(c.asInt() >>> amount);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1427
                                case Long:
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1428
                                    return JavaConstant.forLong(c.asLong() >>> amount);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1429
                                default:
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1430
                                    throw GraalError.shouldNotReachHere();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1431
                            }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1432
                        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1433
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1434
                        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1435
                        public Stamp foldStamp(Stamp stamp, IntegerStamp shift) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1436
                            IntegerStamp value = (IntegerStamp) stamp;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1437
                            int bits = value.getBits();
46963
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1438
                            if (value.isEmpty()) {
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1439
                                return value;
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1440
                            } else if (shift.isEmpty()) {
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1441
                                return StampFactory.forInteger(bits).empty();
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1442
                            }
089674d9949b 8186681: Update Graal
iveresov
parents: 46371
diff changeset
  1443
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1444
                            if (shift.lowerBound() == shift.upperBound()) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1445
                                long shiftCount = shift.lowerBound() & getShiftAmountMask(stamp);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1446
                                if (shiftCount == 0) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1447
                                    return stamp;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1448
                                }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1449
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1450
                                long downMask = value.downMask() >>> shiftCount;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1451
                                long upMask = value.upMask() >>> shiftCount;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1452
                                if (value.lowerBound() < 0) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1453
                                    return new IntegerStamp(bits, downMask, upMask, downMask, upMask);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1454
                                } else {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1455
                                    return new IntegerStamp(bits, value.lowerBound() >>> shiftCount, value.upperBound() >>> shiftCount, downMask, upMask);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1456
                                }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1457
                            }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1458
                            long mask = IntegerStamp.upMaskFor(bits, value.lowerBound(), value.upperBound());
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1459
                            return IntegerStamp.stampForMask(bits, 0, mask);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1460
                        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1461
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1462
                        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1463
                        public int getShiftAmountMask(Stamp s) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1464
                            IntegerStamp stamp = (IntegerStamp) s;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1465
                            assert CodeUtil.isPowerOf2(stamp.getBits());
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1466
                            return stamp.getBits() - 1;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1467
                        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1468
                    },
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1469
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1470
                    new UnaryOp.Abs() {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1471
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1472
                        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1473
                        public Constant foldConstant(Constant value) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1474
                            PrimitiveConstant c = (PrimitiveConstant) value;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1475
                            return JavaConstant.forIntegerKind(c.getJavaKind(), Math.abs(c.asLong()));
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1476
                        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1477
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1478
                        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1479
                        public Stamp foldStamp(Stamp input) {
49451
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
  1480
                            if (input.isEmpty()) {
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
  1481
                                return input;
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
  1482
                            }
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1483
                            IntegerStamp stamp = (IntegerStamp) input;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1484
                            int bits = stamp.getBits();
47798
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
  1485
                            if (stamp.lowerBound == stamp.upperBound) {
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
  1486
                                long value = CodeUtil.convert(Math.abs(stamp.lowerBound()), stamp.getBits(), false);
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
  1487
                                return StampFactory.forInteger(stamp.getBits(), value, value);
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
  1488
                            }
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1489
                            if (stamp.lowerBound() == CodeUtil.minValue(bits)) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1490
                                return input.unrestricted();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1491
                            } else {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1492
                                long limit = Math.max(-stamp.lowerBound(), stamp.upperBound());
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1493
                                return StampFactory.forInteger(bits, 0, limit);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1494
                            }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1495
                        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1496
                    },
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1497
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1498
                    null,
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1499
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1500
                    new IntegerConvertOp.ZeroExtend() {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1501
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1502
                        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1503
                        public Constant foldConstant(int inputBits, int resultBits, Constant c) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1504
                            PrimitiveConstant value = (PrimitiveConstant) c;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1505
                            return JavaConstant.forPrimitiveInt(resultBits, CodeUtil.zeroExtend(value.asLong(), inputBits));
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1506
                        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1507
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1508
                        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1509
                        public Stamp foldStamp(int inputBits, int resultBits, Stamp input) {
49451
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
  1510
                            if (input.isEmpty()) {
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
  1511
                                return StampFactory.forInteger(resultBits).empty();
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
  1512
                            }
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1513
                            IntegerStamp stamp = (IntegerStamp) input;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1514
                            assert inputBits == stamp.getBits();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1515
                            assert inputBits <= resultBits;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1516
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
  1517
                            if (inputBits == resultBits) {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
  1518
                                return input;
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
  1519
                            }
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
  1520
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
  1521
                            if (input.isEmpty()) {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
  1522
                                return StampFactory.forInteger(resultBits).empty();
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
  1523
                            }
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
  1524
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1525
                            long downMask = CodeUtil.zeroExtend(stamp.downMask(), inputBits);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1526
                            long upMask = CodeUtil.zeroExtend(stamp.upMask(), inputBits);
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
  1527
                            long lowerBound = stamp.unsignedLowerBound();
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
  1528
                            long upperBound = stamp.unsignedUpperBound();
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
  1529
                            return IntegerStamp.create(resultBits, lowerBound, upperBound, downMask, upMask);
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
  1530
                        }
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1531
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
  1532
                        @Override
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
  1533
                        public Stamp invertStamp(int inputBits, int resultBits, Stamp outStamp) {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
  1534
                            IntegerStamp stamp = (IntegerStamp) outStamp;
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
  1535
                            if (stamp.isEmpty()) {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
  1536
                                return StampFactory.forInteger(inputBits).empty();
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1537
                            }
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
  1538
                            return StampFactory.forUnsignedInteger(inputBits, stamp.lowerBound(), stamp.upperBound(), stamp.downMask(), stamp.upMask());
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1539
                        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1540
                    },
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1541
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1542
                    new IntegerConvertOp.SignExtend() {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1543
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1544
                        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1545
                        public Constant foldConstant(int inputBits, int resultBits, Constant c) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1546
                            PrimitiveConstant value = (PrimitiveConstant) c;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1547
                            return JavaConstant.forPrimitiveInt(resultBits, CodeUtil.signExtend(value.asLong(), inputBits));
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1548
                        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1549
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1550
                        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1551
                        public Stamp foldStamp(int inputBits, int resultBits, Stamp input) {
49451
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
  1552
                            if (input.isEmpty()) {
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
  1553
                                return StampFactory.forInteger(resultBits).empty();
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
  1554
                            }
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1555
                            IntegerStamp stamp = (IntegerStamp) input;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1556
                            assert inputBits == stamp.getBits();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1557
                            assert inputBits <= resultBits;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1558
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1559
                            long defaultMask = CodeUtil.mask(resultBits);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1560
                            long downMask = CodeUtil.signExtend(stamp.downMask(), inputBits) & defaultMask;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1561
                            long upMask = CodeUtil.signExtend(stamp.upMask(), inputBits) & defaultMask;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1562
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1563
                            return new IntegerStamp(resultBits, stamp.lowerBound(), stamp.upperBound(), downMask, upMask);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1564
                        }
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
  1565
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
  1566
                        @Override
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
  1567
                        public Stamp invertStamp(int inputBits, int resultBits, Stamp outStamp) {
50330
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49451
diff changeset
  1568
                            if (outStamp.isEmpty()) {
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49451
diff changeset
  1569
                                return StampFactory.forInteger(inputBits).empty();
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49451
diff changeset
  1570
                            }
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
  1571
                            IntegerStamp stamp = (IntegerStamp) outStamp;
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
  1572
                            long mask = CodeUtil.mask(inputBits);
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
  1573
                            return StampFactory.forIntegerWithMask(inputBits, stamp.lowerBound(), stamp.upperBound(), stamp.downMask() & mask, stamp.upMask() & mask);
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
  1574
                        }
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1575
                    },
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1576
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1577
                    new IntegerConvertOp.Narrow() {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1578
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1579
                        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1580
                        public Constant foldConstant(int inputBits, int resultBits, Constant c) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1581
                            PrimitiveConstant value = (PrimitiveConstant) c;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1582
                            return JavaConstant.forPrimitiveInt(resultBits, CodeUtil.narrow(value.asLong(), resultBits));
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1583
                        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1584
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1585
                        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1586
                        public Stamp foldStamp(int inputBits, int resultBits, Stamp input) {
49451
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
  1587
                            if (input.isEmpty()) {
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
  1588
                                return StampFactory.forInteger(resultBits).empty();
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
  1589
                            }
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1590
                            IntegerStamp stamp = (IntegerStamp) input;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1591
                            assert inputBits == stamp.getBits();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1592
                            assert resultBits <= inputBits;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1593
                            if (resultBits == inputBits) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1594
                                return stamp;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1595
                            }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1596
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1597
                            final long upperBound;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1598
                            if (stamp.lowerBound() < CodeUtil.minValue(resultBits)) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1599
                                upperBound = CodeUtil.maxValue(resultBits);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1600
                            } else {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1601
                                upperBound = saturate(stamp.upperBound(), resultBits);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1602
                            }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1603
                            final long lowerBound;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1604
                            if (stamp.upperBound() > CodeUtil.maxValue(resultBits)) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1605
                                lowerBound = CodeUtil.minValue(resultBits);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1606
                            } else {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1607
                                lowerBound = saturate(stamp.lowerBound(), resultBits);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1608
                            }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1609
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1610
                            long defaultMask = CodeUtil.mask(resultBits);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1611
                            long newDownMask = stamp.downMask() & defaultMask;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1612
                            long newUpMask = stamp.upMask() & defaultMask;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1613
                            long newLowerBound = CodeUtil.signExtend((lowerBound | newDownMask) & newUpMask, resultBits);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1614
                            long newUpperBound = CodeUtil.signExtend((upperBound | newDownMask) & newUpMask, resultBits);
58877
aec7bf35d6f5 8233273: Update Graal
dlong
parents: 58299
diff changeset
  1615
aec7bf35d6f5 8233273: Update Graal
dlong
parents: 58299
diff changeset
  1616
                            IntegerStamp result = new IntegerStamp(resultBits, newLowerBound, newUpperBound, newDownMask, newUpMask);
aec7bf35d6f5 8233273: Update Graal
dlong
parents: 58299
diff changeset
  1617
                            assert result.hasValues();
aec7bf35d6f5 8233273: Update Graal
dlong
parents: 58299
diff changeset
  1618
                            return result;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1619
                        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1620
                    },
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1621
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1622
                    new FloatConvertOp(I2F) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1623
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1624
                        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1625
                        public Constant foldConstant(Constant c) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1626
                            PrimitiveConstant value = (PrimitiveConstant) c;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1627
                            return JavaConstant.forFloat(value.asInt());
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1628
                        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1629
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1630
                        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1631
                        public Stamp foldStamp(Stamp input) {
49451
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
  1632
                            if (input.isEmpty()) {
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
  1633
                                return StampFactory.empty(JavaKind.Float);
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
  1634
                            }
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1635
                            IntegerStamp stamp = (IntegerStamp) input;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1636
                            assert stamp.getBits() == 32;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1637
                            float lowerBound = stamp.lowerBound();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1638
                            float upperBound = stamp.upperBound();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1639
                            return StampFactory.forFloat(JavaKind.Float, lowerBound, upperBound, true);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1640
                        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1641
                    },
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1642
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1643
                    new FloatConvertOp(L2F) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1644
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1645
                        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1646
                        public Constant foldConstant(Constant c) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1647
                            PrimitiveConstant value = (PrimitiveConstant) c;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1648
                            return JavaConstant.forFloat(value.asLong());
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1649
                        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1650
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1651
                        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1652
                        public Stamp foldStamp(Stamp input) {
49451
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
  1653
                            if (input.isEmpty()) {
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
  1654
                                return StampFactory.empty(JavaKind.Float);
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
  1655
                            }
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1656
                            IntegerStamp stamp = (IntegerStamp) input;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1657
                            assert stamp.getBits() == 64;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1658
                            float lowerBound = stamp.lowerBound();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1659
                            float upperBound = stamp.upperBound();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1660
                            return StampFactory.forFloat(JavaKind.Float, lowerBound, upperBound, true);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1661
                        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1662
                    },
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1663
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1664
                    new FloatConvertOp(I2D) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1665
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1666
                        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1667
                        public Constant foldConstant(Constant c) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1668
                            PrimitiveConstant value = (PrimitiveConstant) c;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1669
                            return JavaConstant.forDouble(value.asInt());
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1670
                        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1671
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1672
                        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1673
                        public Stamp foldStamp(Stamp input) {
49451
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
  1674
                            if (input.isEmpty()) {
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
  1675
                                return StampFactory.empty(JavaKind.Double);
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
  1676
                            }
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1677
                            IntegerStamp stamp = (IntegerStamp) input;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1678
                            assert stamp.getBits() == 32;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1679
                            double lowerBound = stamp.lowerBound();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1680
                            double upperBound = stamp.upperBound();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1681
                            return StampFactory.forFloat(JavaKind.Double, lowerBound, upperBound, true);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1682
                        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1683
                    },
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1684
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1685
                    new FloatConvertOp(L2D) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1686
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1687
                        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1688
                        public Constant foldConstant(Constant c) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1689
                            PrimitiveConstant value = (PrimitiveConstant) c;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1690
                            return JavaConstant.forDouble(value.asLong());
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1691
                        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1692
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1693
                        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1694
                        public Stamp foldStamp(Stamp input) {
49451
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
  1695
                            if (input.isEmpty()) {
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
  1696
                                return StampFactory.empty(JavaKind.Double);
e06f9607f370 8198969: Update Graal
iveresov
parents: 47798
diff changeset
  1697
                            }
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1698
                            IntegerStamp stamp = (IntegerStamp) input;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1699
                            assert stamp.getBits() == 64;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1700
                            double lowerBound = stamp.lowerBound();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1701
                            double upperBound = stamp.upperBound();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1702
                            return StampFactory.forFloat(JavaKind.Double, lowerBound, upperBound, true);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1703
                        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1704
                    });
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1705
}