hotspot/test/compiler/loopopts/TestMoveStoresOutOfLoops.java
author duke
Wed, 05 Jul 2017 22:24:41 +0200
changeset 41867 d62173b931bf
parent 41705 332239c052cc
permissions -rw-r--r--
Merge
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
32372
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
     1
/*
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
     2
 * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
     4
 *
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
     7
 * published by the Free Software Foundation.
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
     8
 *
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
     9
 * This code is distributed in the hope that it will be useful, but WITHOUT
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    10
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    11
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    12
 * version 2 for more details (a copy is included in the LICENSE file that
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    13
 * accompanied this code).
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    14
 *
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    15
 * You should have received a copy of the GNU General Public License version
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    16
 * 2 along with this work; if not, write to the Free Software Foundation,
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    17
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    18
 *
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    19
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    20
 * or visit www.oracle.com if you need additional information or have any
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    21
 * questions.
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    22
 */
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    23
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    24
/**
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    25
 * @test
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    26
 * @bug 8080289
33078
9452eb89c16d 8136926: phi == NULL assert in PhaseIdealLoop::try_move_store_after_loop
roland
parents: 32372
diff changeset
    27
 * @summary Move stores out of loops if possible
32372
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    28
 *
40059
c2304140ed64 8132919: Put compiler tests in packages
tpivovarova
parents: 33078
diff changeset
    29
 * @run main/othervm -XX:-UseOnStackReplacement -XX:-BackgroundCompilation
c2304140ed64 8132919: Put compiler tests in packages
tpivovarova
parents: 33078
diff changeset
    30
 *      -XX:CompileCommand=dontinline,compiler.loopopts.TestMoveStoresOutOfLoops::test*
c2304140ed64 8132919: Put compiler tests in packages
tpivovarova
parents: 33078
diff changeset
    31
 *      compiler.loopopts.TestMoveStoresOutOfLoops
32372
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    32
 */
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    33
40059
c2304140ed64 8132919: Put compiler tests in packages
tpivovarova
parents: 33078
diff changeset
    34
package compiler.loopopts;
c2304140ed64 8132919: Put compiler tests in packages
tpivovarova
parents: 33078
diff changeset
    35
c2304140ed64 8132919: Put compiler tests in packages
tpivovarova
parents: 33078
diff changeset
    36
import java.lang.reflect.Method;
c2304140ed64 8132919: Put compiler tests in packages
tpivovarova
parents: 33078
diff changeset
    37
import java.lang.reflect.Modifier;
c2304140ed64 8132919: Put compiler tests in packages
tpivovarova
parents: 33078
diff changeset
    38
import java.util.HashMap;
c2304140ed64 8132919: Put compiler tests in packages
tpivovarova
parents: 33078
diff changeset
    39
import java.util.function.Function;
32372
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    40
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    41
public class TestMoveStoresOutOfLoops {
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    42
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    43
    private static long[] array = new long[10];
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    44
    private static long[] array2 = new long[10];
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    45
    private static boolean[] array3 = new boolean[1000];
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    46
    private static byte[] byte_array = new byte[10];
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    47
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    48
    // Array store should be moved out of the loop, value stored
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    49
    // should be 999, the loop should be eliminated
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    50
    static void test_after_1(int idx) {
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    51
        for (int i = 0; i < 1000; i++) {
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    52
            array[idx] = i;
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    53
        }
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    54
    }
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    55
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    56
    // Array store can't be moved out of loop because of following
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    57
    // non loop invariant array access
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    58
    static void test_after_2(int idx) {
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    59
        for (int i = 0; i < 1000; i++) {
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    60
            array[idx] = i;
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    61
            array2[i%10] = i;
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    62
        }
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    63
    }
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    64
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    65
    // Array store can't be moved out of loop because of following
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    66
    // use
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    67
    static void test_after_3(int idx) {
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    68
        for (int i = 0; i < 1000; i++) {
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    69
            array[idx] = i;
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    70
            if (array[0] == -1) {
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    71
                break;
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    72
            }
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    73
        }
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    74
    }
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    75
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    76
    // Array store can't be moved out of loop because of preceding
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    77
    // use
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    78
    static void test_after_4(int idx) {
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    79
        for (int i = 0; i < 1000; i++) {
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    80
            if (array[0] == -2) {
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    81
                break;
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    82
            }
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    83
            array[idx] = i;
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    84
        }
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    85
    }
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    86
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    87
    // All array stores should be moved out of the loop, one after
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    88
    // the other
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    89
    static void test_after_5(int idx) {
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    90
        for (int i = 0; i < 1000; i++) {
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    91
            array[idx] = i;
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    92
            array[idx+1] = i;
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    93
            array[idx+2] = i;
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    94
            array[idx+3] = i;
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    95
            array[idx+4] = i;
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    96
            array[idx+5] = i;
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    97
        }
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    98
    }
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
    99
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   100
    // Array store can be moved after the loop but needs to be
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   101
    // cloned on both exit paths
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   102
    static void test_after_6(int idx) {
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   103
        for (int i = 0; i < 1000; i++) {
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   104
            array[idx] = i;
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   105
            if (array3[i]) {
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   106
                return;
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   107
            }
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   108
        }
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   109
    }
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   110
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   111
    // Optimize out redundant stores
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   112
    static void test_stores_1(int ignored) {
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   113
        array[0] = 0;
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   114
        array[1] = 1;
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   115
        array[2] = 2;
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   116
        array[0] = 0;
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   117
        array[1] = 1;
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   118
        array[2] = 2;
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   119
    }
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   120
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   121
    static void test_stores_2(int idx) {
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   122
        array[idx+0] = 0;
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   123
        array[idx+1] = 1;
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   124
        array[idx+2] = 2;
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   125
        array[idx+0] = 0;
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   126
        array[idx+1] = 1;
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   127
        array[idx+2] = 2;
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   128
    }
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   129
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   130
    static void test_stores_3(int idx) {
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   131
        byte_array[idx+0] = 0;
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   132
        byte_array[idx+1] = 1;
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   133
        byte_array[idx+2] = 2;
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   134
        byte_array[idx+0] = 0;
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   135
        byte_array[idx+1] = 1;
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   136
        byte_array[idx+2] = 2;
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   137
    }
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   138
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   139
    // Array store can be moved out of the loop before the loop header
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   140
    static void test_before_1(int idx) {
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   141
        for (int i = 0; i < 1000; i++) {
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   142
            array[idx] = 999;
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   143
        }
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   144
    }
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   145
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   146
    // Array store can't be moved out of the loop before the loop
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   147
    // header because there's more than one store on this slice
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   148
    static void test_before_2(int idx) {
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   149
        for (int i = 0; i < 1000; i++) {
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   150
            array[idx] = 999;
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   151
            array[i%2] = 0;
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   152
        }
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   153
    }
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   154
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   155
    // Array store can't be moved out of the loop before the loop
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   156
    // header because of use before store
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   157
    static int test_before_3(int idx) {
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   158
        int res = 0;
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   159
        for (int i = 0; i < 1000; i++) {
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   160
            res += array[i%10];
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   161
            array[idx] = 999;
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   162
        }
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   163
        return res;
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   164
    }
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   165
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   166
    // Array store can't be moved out of the loop before the loop
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   167
    // header because of possible early exit
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   168
    static void test_before_4(int idx) {
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   169
        for (int i = 0; i < 1000; i++) {
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   170
            if (idx / (i+1) > 0) {
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   171
                return;
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   172
            }
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   173
            array[idx] = 999;
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   174
        }
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   175
    }
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   176
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   177
    // Array store can't be moved out of the loop before the loop
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   178
    // header because it doesn't postdominate the loop head
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   179
    static void test_before_5(int idx) {
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   180
        for (int i = 0; i < 1000; i++) {
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   181
            if (i % 2 == 0) {
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   182
                array[idx] = 999;
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   183
            }
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   184
        }
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   185
    }
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   186
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   187
    // Array store can be moved out of the loop before the loop header
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   188
    static int test_before_6(int idx) {
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   189
        int res = 0;
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   190
        for (int i = 0; i < 1000; i++) {
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   191
            if (i%2 == 1) {
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   192
                res *= 2;
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   193
            } else {
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   194
                res++;
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   195
            }
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   196
            array[idx] = 999;
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   197
        }
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   198
        return res;
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   199
    }
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   200
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   201
    final HashMap<String,Method> tests = new HashMap<>();
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   202
    {
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   203
        for (Method m : this.getClass().getDeclaredMethods()) {
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   204
            if (m.getName().matches("test_(before|after|stores)_[0-9]+")) {
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   205
                assert(Modifier.isStatic(m.getModifiers())) : m;
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   206
                tests.put(m.getName(), m);
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   207
            }
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   208
        }
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   209
    }
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   210
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   211
    boolean success = true;
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   212
    void doTest(String name, Runnable init, Function<String, Boolean> check) throws Exception {
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   213
        Method m = tests.get(name);
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   214
        for (int i = 0; i < 20000; i++) {
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   215
            init.run();
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   216
            m.invoke(null, 0);
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   217
            success = success && check.apply(name);
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   218
            if (!success) {
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   219
                break;
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   220
            }
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   221
        }
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   222
    }
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   223
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   224
    static void array_init() {
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   225
        array[0] = -1;
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   226
    }
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   227
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   228
    static boolean array_check(String name) {
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   229
        boolean success = true;
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   230
        if (array[0] != 999) {
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   231
            success = false;
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   232
            System.out.println(name + " failed: array[0] = " + array[0]);
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   233
        }
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   234
        return success;
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   235
    }
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   236
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   237
    static void array_init2() {
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   238
        for (int i = 0; i < 6; i++) {
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   239
            array[i] = -1;
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   240
        }
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   241
    }
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   242
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   243
    static boolean array_check2(String name) {
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   244
        boolean success = true;
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   245
        for (int i = 0; i < 6; i++) {
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   246
            if (array[i] != 999) {
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   247
                success = false;
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   248
                System.out.println(name + " failed: array[" + i + "] = " + array[i]);
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   249
            }
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   250
        }
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   251
        return success;
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   252
    }
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   253
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   254
    static void array_init3() {
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   255
        for (int i = 0; i < 3; i++) {
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   256
            array[i] = -1;
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   257
        }
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   258
    }
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   259
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   260
    static boolean array_check3(String name) {
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   261
        boolean success = true;
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   262
        for (int i = 0; i < 3; i++) {
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   263
            if (array[i] != i) {
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   264
                success = false;
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   265
                System.out.println(name + " failed: array[" + i + "] = " + array[i]);
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   266
            }
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   267
        }
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   268
        return success;
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   269
    }
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   270
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   271
    static void array_init4() {
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   272
        for (int i = 0; i < 3; i++) {
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   273
            byte_array[i] = -1;
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   274
        }
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   275
    }
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   276
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   277
    static boolean array_check4(String name) {
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   278
        boolean success = true;
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   279
        for (int i = 0; i < 3; i++) {
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   280
            if (byte_array[i] != i) {
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   281
                success = false;
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   282
                System.out.println(name + " failed: byte_array[" + i + "] = " + byte_array[i]);
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   283
            }
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   284
        }
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   285
        return success;
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   286
    }
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   287
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   288
    static public void main(String[] args) throws Exception {
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   289
        TestMoveStoresOutOfLoops test = new TestMoveStoresOutOfLoops();
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   290
        test.doTest("test_after_1", TestMoveStoresOutOfLoops::array_init, TestMoveStoresOutOfLoops::array_check);
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   291
        test.doTest("test_after_2", TestMoveStoresOutOfLoops::array_init, TestMoveStoresOutOfLoops::array_check);
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   292
        test.doTest("test_after_3", TestMoveStoresOutOfLoops::array_init, TestMoveStoresOutOfLoops::array_check);
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   293
        test.doTest("test_after_4", TestMoveStoresOutOfLoops::array_init, TestMoveStoresOutOfLoops::array_check);
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   294
        test.doTest("test_after_5", TestMoveStoresOutOfLoops::array_init2, TestMoveStoresOutOfLoops::array_check2);
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   295
        test.doTest("test_after_6", TestMoveStoresOutOfLoops::array_init, TestMoveStoresOutOfLoops::array_check);
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   296
        array3[999] = true;
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   297
        test.doTest("test_after_6", TestMoveStoresOutOfLoops::array_init, TestMoveStoresOutOfLoops::array_check);
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   298
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   299
        test.doTest("test_stores_1", TestMoveStoresOutOfLoops::array_init3, TestMoveStoresOutOfLoops::array_check3);
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   300
        test.doTest("test_stores_2", TestMoveStoresOutOfLoops::array_init3, TestMoveStoresOutOfLoops::array_check3);
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   301
        test.doTest("test_stores_3", TestMoveStoresOutOfLoops::array_init4, TestMoveStoresOutOfLoops::array_check4);
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   302
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   303
        test.doTest("test_before_1", TestMoveStoresOutOfLoops::array_init, TestMoveStoresOutOfLoops::array_check);
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   304
        test.doTest("test_before_2", TestMoveStoresOutOfLoops::array_init, TestMoveStoresOutOfLoops::array_check);
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   305
        test.doTest("test_before_3", TestMoveStoresOutOfLoops::array_init, TestMoveStoresOutOfLoops::array_check);
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   306
        test.doTest("test_before_4", TestMoveStoresOutOfLoops::array_init, TestMoveStoresOutOfLoops::array_check);
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   307
        test.doTest("test_before_5", TestMoveStoresOutOfLoops::array_init, TestMoveStoresOutOfLoops::array_check);
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   308
        test.doTest("test_before_6", TestMoveStoresOutOfLoops::array_init, TestMoveStoresOutOfLoops::array_check);
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   309
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   310
        if (!test.success) {
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   311
            throw new RuntimeException("Some tests failed");
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   312
        }
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   313
    }
b82e88dcb26c 8080289: Intermediate writes in a loop not eliminated by optimizer
roland
parents:
diff changeset
   314
}