diff -r b4441f6cfe79 -r c2304140ed64 hotspot/test/compiler/codegen/IntRotateWithImmediate.java --- a/hotspot/test/compiler/codegen/IntRotateWithImmediate.java Tue Jul 12 08:42:46 2016 +0000 +++ b/hotspot/test/compiler/codegen/IntRotateWithImmediate.java Tue Jul 12 18:24:48 2016 +0300 @@ -28,51 +28,54 @@ * @bug 8154537 * @key regression * @summary Test that the rotate distance used in the rotate instruction is properly masked with 0x1f - * @run main/othervm -Xbatch -XX:-UseOnStackReplacement IntRotateWithImmediate + * + * @run main/othervm -Xbatch -XX:-UseOnStackReplacement compiler.codegen.IntRotateWithImmediate * @author volker.simonis@gmail.com */ +package compiler.codegen; + public class IntRotateWithImmediate { - // This is currently the same as Integer.rotateRight() - static int rotateRight1(int i, int distance) { - // On some architectures (i.e. x86_64 and ppc64) the following computation is - // matched in the .ad file into a single MachNode which emmits a single rotate - // machine instruction. It is important that the shift amount is masked to match - // corresponding immediate width in the native instruction. On x86_64 the rotate - // left instruction ('rol') encodes an 8-bit immediate while the corresponding - // 'rotlwi' instruction on Power only encodes a 5-bit immediate. - return ((i >>> distance) | (i << -distance)); - } + // This is currently the same as Integer.rotateRight() + static int rotateRight1(int i, int distance) { + // On some architectures (i.e. x86_64 and ppc64) the following computation is + // matched in the .ad file into a single MachNode which emmits a single rotate + // machine instruction. It is important that the shift amount is masked to match + // corresponding immediate width in the native instruction. On x86_64 the rotate + // left instruction ('rol') encodes an 8-bit immediate while the corresponding + // 'rotlwi' instruction on Power only encodes a 5-bit immediate. + return ((i >>> distance) | (i << -distance)); + } - static int rotateRight2(int i, int distance) { - return ((i >>> distance) | (i << (32-distance))); - } + static int rotateRight2(int i, int distance) { + return ((i >>> distance) | (i << (32 - distance))); + } - static int compute1(int x) { - return rotateRight1(x, 3); - } + static int compute1(int x) { + return rotateRight1(x, 3); + } - static int compute2(int x) { - return rotateRight2(x, 3); - } + static int compute2(int x) { + return rotateRight2(x, 3); + } - public static void main(String args[]) { - int val = 4096; + public static void main(String args[]) { + int val = 4096; - int firstResult = compute1(val); + int firstResult = compute1(val); - for (int i = 0; i < 100000; i++) { - int newResult = compute1(val); - if (firstResult != newResult) { - throw new InternalError(firstResult + " != " + newResult); - } - newResult = compute2(val); - if (firstResult != newResult) { - throw new InternalError(firstResult + " != " + newResult); - } + for (int i = 0; i < 100000; i++) { + int newResult = compute1(val); + if (firstResult != newResult) { + throw new InternalError(firstResult + " != " + newResult); + } + newResult = compute2(val); + if (firstResult != newResult) { + throw new InternalError(firstResult + " != " + newResult); + } + } + System.out.println("OK"); } - System.out.println("OK"); - } }