src/jdk.internal.vm.compiler/share/classes/org.graalvm.compiler.core.test/src/org/graalvm/compiler/core/test/IntegerDivPowerOf2Test.java
author jlaskey
Thu, 14 Nov 2019 12:50:08 -0400
branchJDK-8193209-branch
changeset 59088 da026c172c1e
parent 55509 d58442b8abc1
permissions -rw-r--r--
add missing files
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
55509
d58442b8abc1 8225497: Update Graal
jwilhelm
parents:
diff changeset
     1
/*
d58442b8abc1 8225497: Update Graal
jwilhelm
parents:
diff changeset
     2
 * Copyright (c) 2019, Oracle and/or its affiliates. All rights reserved.
d58442b8abc1 8225497: Update Graal
jwilhelm
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
d58442b8abc1 8225497: Update Graal
jwilhelm
parents:
diff changeset
     4
 *
d58442b8abc1 8225497: Update Graal
jwilhelm
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
d58442b8abc1 8225497: Update Graal
jwilhelm
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
d58442b8abc1 8225497: Update Graal
jwilhelm
parents:
diff changeset
     7
 * published by the Free Software Foundation.
d58442b8abc1 8225497: Update Graal
jwilhelm
parents:
diff changeset
     8
 *
d58442b8abc1 8225497: Update Graal
jwilhelm
parents:
diff changeset
     9
 * This code is distributed in the hope that it will be useful, but WITHOUT
d58442b8abc1 8225497: Update Graal
jwilhelm
parents:
diff changeset
    10
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
d58442b8abc1 8225497: Update Graal
jwilhelm
parents:
diff changeset
    11
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
d58442b8abc1 8225497: Update Graal
jwilhelm
parents:
diff changeset
    12
 * version 2 for more details (a copy is included in the LICENSE file that
d58442b8abc1 8225497: Update Graal
jwilhelm
parents:
diff changeset
    13
 * accompanied this code).
d58442b8abc1 8225497: Update Graal
jwilhelm
parents:
diff changeset
    14
 *
d58442b8abc1 8225497: Update Graal
jwilhelm
parents:
diff changeset
    15
 * You should have received a copy of the GNU General Public License version
d58442b8abc1 8225497: Update Graal
jwilhelm
parents:
diff changeset
    16
 * 2 along with this work; if not, write to the Free Software Foundation,
d58442b8abc1 8225497: Update Graal
jwilhelm
parents:
diff changeset
    17
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
d58442b8abc1 8225497: Update Graal
jwilhelm
parents:
diff changeset
    18
 *
d58442b8abc1 8225497: Update Graal
jwilhelm
parents:
diff changeset
    19
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
d58442b8abc1 8225497: Update Graal
jwilhelm
parents:
diff changeset
    20
 * or visit www.oracle.com if you need additional information or have any
d58442b8abc1 8225497: Update Graal
jwilhelm
parents:
diff changeset
    21
 * questions.
d58442b8abc1 8225497: Update Graal
jwilhelm
parents:
diff changeset
    22
 */
d58442b8abc1 8225497: Update Graal
jwilhelm
parents:
diff changeset
    23
d58442b8abc1 8225497: Update Graal
jwilhelm
parents:
diff changeset
    24
d58442b8abc1 8225497: Update Graal
jwilhelm
parents:
diff changeset
    25
package org.graalvm.compiler.core.test;
d58442b8abc1 8225497: Update Graal
jwilhelm
parents:
diff changeset
    26
d58442b8abc1 8225497: Update Graal
jwilhelm
parents:
diff changeset
    27
import org.graalvm.compiler.api.directives.GraalDirectives;
d58442b8abc1 8225497: Update Graal
jwilhelm
parents:
diff changeset
    28
import org.graalvm.compiler.nodes.StructuredGraph;
d58442b8abc1 8225497: Update Graal
jwilhelm
parents:
diff changeset
    29
import org.graalvm.compiler.nodes.calc.RightShiftNode;
d58442b8abc1 8225497: Update Graal
jwilhelm
parents:
diff changeset
    30
import org.graalvm.compiler.nodes.calc.UnsignedRightShiftNode;
d58442b8abc1 8225497: Update Graal
jwilhelm
parents:
diff changeset
    31
import org.junit.Test;
d58442b8abc1 8225497: Update Graal
jwilhelm
parents:
diff changeset
    32
d58442b8abc1 8225497: Update Graal
jwilhelm
parents:
diff changeset
    33
public class IntegerDivPowerOf2Test extends GraalCompilerTest {
d58442b8abc1 8225497: Update Graal
jwilhelm
parents:
diff changeset
    34
d58442b8abc1 8225497: Update Graal
jwilhelm
parents:
diff changeset
    35
    public static int positiveDivByPowerOf2(boolean flag) {
d58442b8abc1 8225497: Update Graal
jwilhelm
parents:
diff changeset
    36
        int val = flag ? 1 : 10;
d58442b8abc1 8225497: Update Graal
jwilhelm
parents:
diff changeset
    37
        GraalDirectives.blackhole(val);
d58442b8abc1 8225497: Update Graal
jwilhelm
parents:
diff changeset
    38
        return val / 8;
d58442b8abc1 8225497: Update Graal
jwilhelm
parents:
diff changeset
    39
    }
d58442b8abc1 8225497: Update Graal
jwilhelm
parents:
diff changeset
    40
d58442b8abc1 8225497: Update Graal
jwilhelm
parents:
diff changeset
    41
    @Test
d58442b8abc1 8225497: Update Graal
jwilhelm
parents:
diff changeset
    42
    public void testPositiveDivByPowerOf2() {
d58442b8abc1 8225497: Update Graal
jwilhelm
parents:
diff changeset
    43
        StructuredGraph graph = parseForCompile(getResolvedJavaMethod("positiveDivByPowerOf2"));
d58442b8abc1 8225497: Update Graal
jwilhelm
parents:
diff changeset
    44
        // We expect no rounding is needed
d58442b8abc1 8225497: Update Graal
jwilhelm
parents:
diff changeset
    45
        assertTrue(countShiftNode(graph) == 1);
d58442b8abc1 8225497: Update Graal
jwilhelm
parents:
diff changeset
    46
    }
d58442b8abc1 8225497: Update Graal
jwilhelm
parents:
diff changeset
    47
d58442b8abc1 8225497: Update Graal
jwilhelm
parents:
diff changeset
    48
    private static int countShiftNode(StructuredGraph graph) {
d58442b8abc1 8225497: Update Graal
jwilhelm
parents:
diff changeset
    49
        return graph.getNodes().filter(node -> node instanceof RightShiftNode || node instanceof UnsignedRightShiftNode).count();
d58442b8abc1 8225497: Update Graal
jwilhelm
parents:
diff changeset
    50
    }
d58442b8abc1 8225497: Update Graal
jwilhelm
parents:
diff changeset
    51
d58442b8abc1 8225497: Update Graal
jwilhelm
parents:
diff changeset
    52
    public static int unknownDivByPowerOf2(boolean flag) {
d58442b8abc1 8225497: Update Graal
jwilhelm
parents:
diff changeset
    53
        int val = flag ? 0x800000F0 : 0x20;
d58442b8abc1 8225497: Update Graal
jwilhelm
parents:
diff changeset
    54
        GraalDirectives.blackhole(val);
d58442b8abc1 8225497: Update Graal
jwilhelm
parents:
diff changeset
    55
        return val / 8;
d58442b8abc1 8225497: Update Graal
jwilhelm
parents:
diff changeset
    56
    }
d58442b8abc1 8225497: Update Graal
jwilhelm
parents:
diff changeset
    57
d58442b8abc1 8225497: Update Graal
jwilhelm
parents:
diff changeset
    58
    @Test
d58442b8abc1 8225497: Update Graal
jwilhelm
parents:
diff changeset
    59
    public void testUnknownDivByPowerOf2() {
d58442b8abc1 8225497: Update Graal
jwilhelm
parents:
diff changeset
    60
        StructuredGraph graph = parseForCompile(getResolvedJavaMethod("unknownDivByPowerOf2"));
d58442b8abc1 8225497: Update Graal
jwilhelm
parents:
diff changeset
    61
        // We expect no rounding is needed
d58442b8abc1 8225497: Update Graal
jwilhelm
parents:
diff changeset
    62
        assertTrue(graph.getNodes().filter(RightShiftNode.class).count() <= 1);
d58442b8abc1 8225497: Update Graal
jwilhelm
parents:
diff changeset
    63
    }
d58442b8abc1 8225497: Update Graal
jwilhelm
parents:
diff changeset
    64
d58442b8abc1 8225497: Update Graal
jwilhelm
parents:
diff changeset
    65
}