src/jdk.internal.vm.compiler/share/classes/org.graalvm.compiler.core.test/src/org/graalvm/compiler/core/test/IntegerDivRemConstantTest.java
author jlaskey
Thu, 14 Nov 2019 12:50:08 -0400
branchJDK-8193209-branch
changeset 59088 da026c172c1e
parent 54084 84f10bbf993f
permissions -rw-r--r--
add missing files
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
54084
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
     1
/*
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
     2
 * Copyright (c) 2019, Oracle and/or its affiliates. All rights reserved.
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
     3
 * Copyright (c) 2019, Arm Limited and affiliates. All rights reserved.
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
     4
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
     5
 *
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
     6
 * This code is free software; you can redistribute it and/or modify it
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
     7
 * under the terms of the GNU General Public License version 2 only, as
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
     8
 * published by the Free Software Foundation.
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
     9
 *
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    10
 * This code is distributed in the hope that it will be useful, but WITHOUT
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    11
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    12
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    13
 * version 2 for more details (a copy is included in the LICENSE file that
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    14
 * accompanied this code).
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    15
 *
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    16
 * You should have received a copy of the GNU General Public License version
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    17
 * 2 along with this work; if not, write to the Free Software Foundation,
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    18
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    19
 *
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    20
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    21
 * or visit www.oracle.com if you need additional information or have any
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    22
 * questions.
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    23
 */
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    24
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    25
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    26
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    27
package org.graalvm.compiler.core.test;
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    28
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    29
import org.junit.Test;
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    30
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    31
public class IntegerDivRemConstantTest extends GraalCompilerTest {
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    32
    public static int intDivPositiveConstant(int val) {
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    33
        return val / 5;
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    34
    }
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    35
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    36
    @Test
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    37
    public void testIntDivPositiveConstant() {
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    38
        test("intDivPositiveConstant", -10);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    39
        test("intDivPositiveConstant", 0);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    40
        test("intDivPositiveConstant", 4256);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    41
        test("intDivPositiveConstant", Integer.MAX_VALUE);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    42
        test("intDivPositiveConstant", Integer.MIN_VALUE);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    43
    }
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    44
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    45
    public static int intDivIntegerMax(int val) {
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    46
        return val / Integer.MAX_VALUE;
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    47
    }
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    48
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    49
    @Test
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    50
    public void testIntDivIntegerMax() {
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    51
        test("intDivIntegerMax", -10);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    52
        test("intDivIntegerMax", 0);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    53
        test("intDivIntegerMax", 4256);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    54
        test("intDivIntegerMax", Integer.MAX_VALUE);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    55
        test("intDivIntegerMax", Integer.MIN_VALUE);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    56
    }
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    57
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    58
    public static int intDivNegativeConstant(int val) {
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    59
        return val / -1234;
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    60
    }
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    61
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    62
    @Test
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    63
    public void testIntDivNegativeConstant() {
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    64
        test("intDivNegativeConstant", -123);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    65
        test("intDivNegativeConstant", 0);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    66
        test("intDivNegativeConstant", 123);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    67
        test("intDivNegativeConstant", Integer.MAX_VALUE);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    68
        test("intDivNegativeConstant", Integer.MIN_VALUE);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    69
    }
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    70
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    71
    public static int intDivIntegerMinOdd(int val) {
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    72
        return val / (Integer.MIN_VALUE + 1);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    73
    }
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    74
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    75
    @Test
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    76
    public void testIntDivIntegerMinOdd() {
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    77
        test("intDivIntegerMinOdd", -123);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    78
        test("intDivIntegerMinOdd", 0);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    79
        test("intDivIntegerMinOdd", 123);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    80
        test("intDivIntegerMinOdd", Integer.MAX_VALUE);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    81
        test("intDivIntegerMinOdd", Integer.MIN_VALUE);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    82
    }
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    83
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    84
    public static long longDivPositiveConstant(long val) {
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    85
        return val / 35170432;
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    86
    }
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    87
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    88
    @Test
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    89
    public void testLongDivPositiveConstant() {
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    90
        test("longDivPositiveConstant", -1234L);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    91
        test("longDivPositiveConstant", 0L);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    92
        test("longDivPositiveConstant", 214423L);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    93
        test("longDivPositiveConstant", Long.MAX_VALUE);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    94
        test("longDivPositiveConstant", Long.MIN_VALUE);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    95
    }
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    96
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    97
    public static long longDivLongMax(long val) {
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    98
        return val / Long.MAX_VALUE;
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
    99
    }
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   100
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   101
    @Test
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   102
    public void testLongDivLongMax() {
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   103
        test("longDivLongMax", -1234L);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   104
        test("longDivLongMax", 0L);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   105
        test("longDivLongMax", 214423L);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   106
        test("longDivLongMax", Long.MAX_VALUE);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   107
        test("longDivLongMax", Long.MIN_VALUE);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   108
    }
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   109
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   110
    public static long longDivNegativeConstant(long val) {
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   111
        return val / -413;
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   112
    }
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   113
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   114
    @Test
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   115
    public void testLongDivNegativeConstant() {
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   116
        test("longDivNegativeConstant", -43L);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   117
        test("longDivNegativeConstant", 0L);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   118
        test("longDivNegativeConstant", 147065L);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   119
        test("longDivNegativeConstant", Long.MAX_VALUE);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   120
        test("longDivNegativeConstant", Long.MIN_VALUE);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   121
    }
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   122
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   123
    public static long longDivLongMinOdd(long val) {
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   124
        return val / (Long.MIN_VALUE + 1);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   125
    }
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   126
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   127
    @Test
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   128
    public void testLongDivLongMinOdd() {
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   129
        test("longDivLongMinOdd", -1234L);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   130
        test("longDivLongMinOdd", 0L);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   131
        test("longDivLongMinOdd", 214423L);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   132
        test("longDivLongMinOdd", Long.MAX_VALUE);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   133
        test("longDivLongMinOdd", Long.MIN_VALUE);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   134
    }
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   135
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   136
    public static int intRemPositiveConstant(int val) {
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   137
        return val % 139968;
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   138
    }
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   139
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   140
    @Test
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   141
    public void testIntRemPositiveConstant() {
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   142
        test("intRemPositiveConstant", -10);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   143
        test("intRemPositiveConstant", 0);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   144
        test("intRemPositiveConstant", 4256);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   145
        test("intRemPositiveConstant", Integer.MAX_VALUE);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   146
        test("intRemPositiveConstant", Integer.MIN_VALUE);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   147
    }
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   148
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   149
    public static int intRemNegativeConstant(int val) {
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   150
        return val % -139968;
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   151
    }
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   152
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   153
    @Test
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   154
    public void testIntRemNegativeConstant() {
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   155
        test("intRemNegativeConstant", -10);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   156
        test("intRemNegativeConstant", 0);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   157
        test("intRemNegativeConstant", 4256);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   158
        test("intRemNegativeConstant", Integer.MAX_VALUE);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   159
        test("intRemNegativeConstant", Integer.MIN_VALUE);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   160
    }
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   161
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   162
    @SuppressWarnings("divzero")
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   163
    public static int intRemZero(int val) {
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   164
        return val % 0;
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   165
    }
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   166
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   167
    @Test
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   168
    public void testIntRemZero() {
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   169
        test("intRemZero", -10);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   170
        test("intRemZero", 0);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   171
        test("intRemZero", 4256);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   172
        test("intRemZero", Integer.MAX_VALUE);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   173
        test("intRemZero", Integer.MIN_VALUE);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   174
    }
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   175
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   176
    public static int intRemMax(int val) {
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   177
        return val % Integer.MAX_VALUE;
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   178
    }
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   179
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   180
    @Test
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   181
    public void testIntRemMax() {
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   182
        test("intRemMax", -10);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   183
        test("intRemMax", 0);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   184
        test("intRemMax", 4256);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   185
        test("intRemMax", Integer.MAX_VALUE);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   186
        test("intRemMax", Integer.MIN_VALUE);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   187
    }
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   188
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   189
    public static int intRemMin(int val) {
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   190
        return val % Integer.MIN_VALUE;
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   191
    }
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   192
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   193
    @Test
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   194
    public void testIntRemMin() {
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   195
        test("intRemMin", -10);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   196
        test("intRemMin", 0);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   197
        test("intRemMin", 4256);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   198
        test("intRemMin", Integer.MAX_VALUE);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   199
        test("intRemMin", Integer.MIN_VALUE);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   200
    }
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   201
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   202
    public static long longRemPositiveConstant(long val) {
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   203
        return val % 35170432;
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   204
    }
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   205
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   206
    public static int intRemPowerOf2(int val) {
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   207
        return val % 4;
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   208
    }
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   209
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   210
    @Test
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   211
    public void testIntRemPowerOf2() {
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   212
        test("intRemPowerOf2", -10);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   213
        test("intRemPowerOf2", 0);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   214
        test("intRemPowerOf2", 4256);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   215
        test("intRemPowerOf2", Integer.MAX_VALUE);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   216
        test("intRemPowerOf2", Integer.MIN_VALUE);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   217
    }
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   218
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   219
    @Test
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   220
    public void testLongRemPositiveConstant() {
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   221
        test("longRemPositiveConstant", -1234L);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   222
        test("longRemPositiveConstant", 0L);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   223
        test("longRemPositiveConstant", 214423L);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   224
        test("longRemPositiveConstant", Long.MAX_VALUE);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   225
        test("longRemPositiveConstant", Long.MIN_VALUE);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   226
    }
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   227
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   228
    public static long longRemNegativeConstant(long val) {
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   229
        return val % -413;
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   230
    }
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   231
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   232
    @Test
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   233
    public void testLongRemNegativeConstant() {
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   234
        test("longRemNegativeConstant", -43L);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   235
        test("longRemNegativeConstant", 0L);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   236
        test("longRemNegativeConstant", 147065L);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   237
        test("longRemNegativeConstant", Long.MAX_VALUE);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   238
        test("longRemNegativeConstant", Long.MIN_VALUE);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   239
    }
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   240
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   241
    @SuppressWarnings("divzero")
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   242
    public static long longRemZero(long val) {
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   243
        return val % 0;
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   244
    }
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   245
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   246
    @Test
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   247
    public void testLongRemZero() {
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   248
        test("longRemZero", -43L);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   249
        test("longRemZero", 0L);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   250
        test("longRemZero", 147065L);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   251
        test("longRemZero", Long.MAX_VALUE);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   252
        test("longRemZero", Long.MIN_VALUE);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   253
    }
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   254
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   255
    public static long longRemMax(long val) {
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   256
        return val % Long.MAX_VALUE;
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   257
    }
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   258
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   259
    @Test
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   260
    public void testLongRemMax() {
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   261
        test("longRemMax", -43L);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   262
        test("longRemMax", 0L);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   263
        test("longRemMax", 147065L);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   264
        test("longRemMax", Long.MAX_VALUE);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   265
        test("longRemMax", Long.MIN_VALUE);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   266
    }
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   267
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   268
    public static long longRemMin(long val) {
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   269
        return val % Long.MIN_VALUE;
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   270
    }
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   271
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   272
    @Test
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   273
    public void testLongRemMin() {
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   274
        test("longRemMin", -43L);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   275
        test("longRemMin", 0L);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   276
        test("longRemMin", 147065L);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   277
        test("longRemMin", Long.MAX_VALUE);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   278
        test("longRemMin", Long.MIN_VALUE);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   279
    }
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   280
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   281
    public static long longRemPowerOf2(long val) {
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   282
        return val % 4L;
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   283
    }
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   284
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   285
    @Test
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   286
    public void testLongRemPowerOf2() {
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   287
        test("longRemPowerOf2", -43L);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   288
        test("longRemPowerOf2", 0L);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   289
        test("longRemPowerOf2", 147065L);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   290
        test("longRemPowerOf2", Long.MAX_VALUE);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   291
        test("longRemPowerOf2", Long.MIN_VALUE);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   292
    }
84f10bbf993f 8218074: Update Graal
jwilhelm
parents:
diff changeset
   293
}