2009-05-06 07:27:52 +00:00
|
|
|
/*
|
2016-08-19 14:06:30 +00:00
|
|
|
* Copyright (c) 2009, 2016, Oracle and/or its affiliates. All rights reserved.
|
2009-05-06 07:27:52 +00:00
|
|
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
|
|
|
*
|
|
|
|
* This code is free software; you can redistribute it and/or modify it
|
|
|
|
* under the terms of the GNU General Public License version 2 only, as
|
|
|
|
* published by the Free Software Foundation.
|
|
|
|
*
|
|
|
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
|
|
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
|
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
|
|
|
* version 2 for more details (a copy is included in the LICENSE file that
|
|
|
|
* accompanied this code).
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License version
|
|
|
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
|
|
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
|
|
*
|
2010-05-28 02:08:38 +00:00
|
|
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
|
|
|
* or visit www.oracle.com if you need additional information or have any
|
|
|
|
* questions.
|
2009-05-06 07:27:52 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @test
|
|
|
|
* @bug 6823354
|
|
|
|
* @summary These methods can be instrinsified by using bit scan, bit test, and population count instructions.
|
2016-05-01 09:47:00 +00:00
|
|
|
* @modules java.base/jdk.internal.misc
|
2016-08-19 14:06:30 +00:00
|
|
|
* @library /test/lib
|
2016-07-12 15:24:48 +00:00
|
|
|
*
|
|
|
|
* @run main/othervm -Xcomp
|
|
|
|
* -XX:CompileCommand=compileonly,compiler.codegen.Test6823354::lzcomp
|
|
|
|
* -XX:CompileCommand=compileonly,compiler.codegen.Test6823354::tzcomp
|
|
|
|
* -XX:CompileCommand=compileonly,compiler.codegen.*::dolzcomp
|
|
|
|
* -XX:CompileCommand=compileonly,compiler.codegen.*::dotzcomp
|
|
|
|
* compiler.codegen.Test6823354
|
2009-05-06 07:27:52 +00:00
|
|
|
*/
|
|
|
|
|
2016-07-12 15:24:48 +00:00
|
|
|
package compiler.codegen;
|
|
|
|
|
2015-10-15 15:00:00 +00:00
|
|
|
import jdk.test.lib.Utils;
|
2009-05-06 07:27:52 +00:00
|
|
|
|
|
|
|
public class Test6823354 {
|
|
|
|
// Arrays of corner case values.
|
|
|
|
static final int[] ia = new int[] { 0, 1, -1, Integer.MIN_VALUE, Integer.MAX_VALUE };
|
|
|
|
static final long[] la = new long[] { 0L, 1L, -1L, Long.MIN_VALUE, Long.MAX_VALUE };
|
|
|
|
|
|
|
|
public static void main(String[] args) throws Exception {
|
|
|
|
// Load the classes and the methods.
|
|
|
|
Integer.numberOfLeadingZeros(0);
|
|
|
|
Integer.numberOfTrailingZeros(0);
|
|
|
|
Long.numberOfLeadingZeros(0);
|
|
|
|
Long.numberOfTrailingZeros(0);
|
|
|
|
|
|
|
|
lz();
|
|
|
|
tz();
|
|
|
|
}
|
|
|
|
|
|
|
|
static void lz() throws Exception {
|
|
|
|
// int
|
|
|
|
|
|
|
|
// Test corner cases.
|
|
|
|
for (int i = 0; i < ia.length; i++) {
|
|
|
|
int x = ia[i];
|
|
|
|
check(x, lzcomp(x), lzint(x));
|
|
|
|
}
|
|
|
|
|
|
|
|
// Test all possible return values.
|
|
|
|
for (int i = 0; i < Integer.SIZE; i++) {
|
|
|
|
int x = 1 << i;
|
|
|
|
check(x, lzcomp(x), lzint(x));
|
|
|
|
}
|
|
|
|
|
2016-07-12 15:24:48 +00:00
|
|
|
String classname = Test6823354.class.getName() + "$lzconI";
|
2009-05-06 07:27:52 +00:00
|
|
|
|
|
|
|
// Test Ideal optimizations (constant values).
|
|
|
|
for (int i = 0; i < ia.length; i++) {
|
|
|
|
testclass(classname, ia[i]);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Test Ideal optimizations (constant values).
|
|
|
|
for (int i = 0; i < Integer.SIZE; i++) {
|
|
|
|
int x = 1 << i;
|
|
|
|
testclass(classname, x);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// long
|
|
|
|
|
|
|
|
// Test corner cases.
|
|
|
|
for (int i = 0; i < ia.length; i++) {
|
|
|
|
long x = la[i];
|
|
|
|
check(x, lzcomp(x), lzint(x));
|
|
|
|
}
|
|
|
|
|
|
|
|
// Test all possible return values.
|
|
|
|
for (int i = 0; i < Long.SIZE; i++) {
|
|
|
|
long x = 1L << i;
|
|
|
|
check(x, lzcomp(x), lzint(x));
|
|
|
|
}
|
|
|
|
|
2016-07-12 15:24:48 +00:00
|
|
|
classname = Test6823354.class.getName() + "$lzconL";
|
2009-05-06 07:27:52 +00:00
|
|
|
|
|
|
|
// Test Ideal optimizations (constant values).
|
|
|
|
for (int i = 0; i < la.length; i++) {
|
|
|
|
testclass(classname, la[i]);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Test Ideal optimizations (constant values).
|
|
|
|
for (int i = 0; i < Long.SIZE; i++) {
|
|
|
|
long x = 1L << i;
|
|
|
|
testclass(classname, x);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
static void tz() throws Exception {
|
|
|
|
// int
|
|
|
|
|
|
|
|
// Test corner cases.
|
|
|
|
for (int i = 0; i < ia.length; i++) {
|
|
|
|
int x = ia[i];
|
|
|
|
check(x, tzcomp(x), tzint(x));
|
|
|
|
}
|
|
|
|
|
|
|
|
// Test all possible return values.
|
|
|
|
for (int i = 0; i < Integer.SIZE; i++) {
|
|
|
|
int x = 1 << i;
|
|
|
|
check(x, tzcomp(x), tzint(x));
|
|
|
|
}
|
|
|
|
|
2016-07-12 15:24:48 +00:00
|
|
|
String classname = Test6823354.class.getName() + "$tzconI";
|
2009-05-06 07:27:52 +00:00
|
|
|
|
|
|
|
// Test Ideal optimizations (constant values).
|
|
|
|
for (int i = 0; i < ia.length; i++) {
|
|
|
|
testclass(classname, ia[i]);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Test Ideal optimizations (constant values).
|
|
|
|
for (int i = 0; i < Integer.SIZE; i++) {
|
|
|
|
int x = 1 << i;
|
|
|
|
testclass(classname, x);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// long
|
|
|
|
|
|
|
|
// Test corner cases.
|
|
|
|
for (int i = 0; i < la.length; i++) {
|
|
|
|
long x = la[i];
|
|
|
|
check(x, tzcomp(x), tzint(x));
|
|
|
|
}
|
|
|
|
|
|
|
|
// Test all possible return values.
|
|
|
|
for (int i = 0; i < Long.SIZE; i++) {
|
|
|
|
long x = 1L << i;
|
|
|
|
check(x, tzcomp(x), tzint(x));
|
|
|
|
}
|
|
|
|
|
2016-07-12 15:24:48 +00:00
|
|
|
classname = Test6823354.class.getName() + "$tzconL";
|
2009-05-06 07:27:52 +00:00
|
|
|
|
|
|
|
// Test Ideal optimizations (constant values).
|
|
|
|
for (int i = 0; i < la.length; i++) {
|
|
|
|
testclass(classname, la[i]);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Test Ideal optimizations (constant values).
|
|
|
|
for (int i = 0; i < Long.SIZE; i++) {
|
|
|
|
long x = 1L << i;
|
|
|
|
testclass(classname, x);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
static void check(int value, int result, int expected) {
|
|
|
|
//System.out.println(value + ": " + result + ", " + expected);
|
|
|
|
if (result != expected)
|
|
|
|
throw new InternalError(value + " failed: " + result + " != " + expected);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void check(long value, long result, long expected) {
|
|
|
|
//System.out.println(value + ": " + result + ", " + expected);
|
|
|
|
if (result != expected)
|
|
|
|
throw new InternalError(value + " failed: " + result + " != " + expected);
|
|
|
|
}
|
|
|
|
|
|
|
|
static int lzint( int i) { return Integer.numberOfLeadingZeros(i); }
|
|
|
|
static int lzcomp(int i) { return Integer.numberOfLeadingZeros(i); }
|
|
|
|
|
|
|
|
static int lzint( long l) { return Long.numberOfLeadingZeros(l); }
|
|
|
|
static int lzcomp(long l) { return Long.numberOfLeadingZeros(l); }
|
|
|
|
|
|
|
|
static int tzint( int i) { return Integer.numberOfTrailingZeros(i); }
|
|
|
|
static int tzcomp(int i) { return Integer.numberOfTrailingZeros(i); }
|
|
|
|
|
|
|
|
static int tzint( long l) { return Long.numberOfTrailingZeros(l); }
|
|
|
|
static int tzcomp(long l) { return Long.numberOfTrailingZeros(l); }
|
|
|
|
|
|
|
|
static void testclass(String classname, int x) throws Exception {
|
|
|
|
System.setProperty("value", "" + x);
|
|
|
|
loadandrunclass(classname);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void testclass(String classname, long x) throws Exception {
|
|
|
|
System.setProperty("value", "" + x);
|
|
|
|
loadandrunclass(classname);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void loadandrunclass(String classname) throws Exception {
|
|
|
|
Class cl = Class.forName(classname);
|
2015-10-15 15:00:00 +00:00
|
|
|
ClassLoader apploader = cl.getClassLoader();
|
|
|
|
ClassLoader loader
|
|
|
|
= Utils.getTestClassPathURLClassLoader(apploader.getParent());
|
2009-05-06 07:27:52 +00:00
|
|
|
Class c = loader.loadClass(classname);
|
|
|
|
Runnable r = (Runnable) c.newInstance();
|
|
|
|
r.run();
|
|
|
|
}
|
|
|
|
|
|
|
|
public static class lzconI implements Runnable {
|
|
|
|
static final int VALUE;
|
|
|
|
|
|
|
|
static {
|
|
|
|
int value = 0;
|
|
|
|
try {
|
|
|
|
value = Integer.decode(System.getProperty("value"));
|
|
|
|
} catch (Throwable e) {}
|
|
|
|
VALUE = value;
|
|
|
|
}
|
|
|
|
|
|
|
|
public void run() { check(VALUE, lzint(VALUE), dolzcomp()); }
|
|
|
|
static int dolzcomp() { return lzcomp(VALUE); }
|
|
|
|
}
|
|
|
|
|
|
|
|
public static class lzconL implements Runnable {
|
|
|
|
static final long VALUE;
|
|
|
|
|
|
|
|
static {
|
|
|
|
long value = 0;
|
|
|
|
try {
|
|
|
|
value = Long.decode(System.getProperty("value"));
|
|
|
|
} catch (Throwable e) {}
|
|
|
|
VALUE = value;
|
|
|
|
}
|
|
|
|
|
|
|
|
public void run() { check(VALUE, lzint(VALUE), dolzcomp()); }
|
|
|
|
static int dolzcomp() { return lzcomp(VALUE); }
|
|
|
|
}
|
|
|
|
|
|
|
|
public static class tzconI implements Runnable {
|
|
|
|
static final int VALUE;
|
|
|
|
|
|
|
|
static {
|
|
|
|
int value = 0;
|
|
|
|
try {
|
|
|
|
value = Integer.decode(System.getProperty("value"));
|
|
|
|
} catch (Throwable e) {}
|
|
|
|
VALUE = value;
|
|
|
|
}
|
|
|
|
|
|
|
|
public void run() { check(VALUE, tzint(VALUE), dotzcomp()); }
|
|
|
|
static int dotzcomp() { return tzcomp(VALUE); }
|
|
|
|
}
|
|
|
|
|
|
|
|
public static class tzconL implements Runnable {
|
|
|
|
static final long VALUE;
|
|
|
|
|
|
|
|
static {
|
|
|
|
long value = 0;
|
|
|
|
try {
|
|
|
|
value = Long.decode(System.getProperty("value"));
|
|
|
|
} catch (Throwable e) {}
|
|
|
|
VALUE = value;
|
|
|
|
}
|
|
|
|
|
|
|
|
public void run() { check(VALUE, tzint(VALUE), dotzcomp()); }
|
|
|
|
static int dotzcomp() { return tzcomp(VALUE); }
|
|
|
|
}
|
|
|
|
}
|