提交 3daa602c 编写于 作者: N never

Merge

...@@ -279,7 +279,11 @@ void os::init_system_properties_values() { ...@@ -279,7 +279,11 @@ void os::init_system_properties_values() {
* ... * ...
* 7: The default directories, normally /lib and /usr/lib. * 7: The default directories, normally /lib and /usr/lib.
*/ */
#if defined(AMD64) || defined(_LP64) && (defined(SPARC) || defined(PPC) || defined(S390))
#define DEFAULT_LIBPATH "/usr/lib64:/lib64:/lib:/usr/lib"
#else
#define DEFAULT_LIBPATH "/lib:/usr/lib" #define DEFAULT_LIBPATH "/lib:/usr/lib"
#endif
#define EXTENSIONS_DIR "/lib/ext" #define EXTENSIONS_DIR "/lib/ext"
#define ENDORSED_DIR "/lib/endorsed" #define ENDORSED_DIR "/lib/endorsed"
......
...@@ -192,64 +192,46 @@ JRT_END ...@@ -192,64 +192,46 @@ JRT_END
JRT_LEAF(jint, SharedRuntime::f2i(jfloat x)) JRT_LEAF(jint, SharedRuntime::f2i(jfloat x))
if (g_isnan(x)) {return 0;} if (g_isnan(x))
jlong lltmp = (jlong)x; return 0;
jint ltmp = (jint)lltmp; if (x >= (jfloat) max_jint)
if (ltmp == lltmp) { return max_jint;
return ltmp; if (x <= (jfloat) min_jint)
} else { return min_jint;
if (x < 0) { return (jint) x;
return min_jint;
} else {
return max_jint;
}
}
JRT_END JRT_END
JRT_LEAF(jlong, SharedRuntime::f2l(jfloat x)) JRT_LEAF(jlong, SharedRuntime::f2l(jfloat x))
if (g_isnan(x)) {return 0;} if (g_isnan(x))
jlong lltmp = (jlong)x; return 0;
if (lltmp != min_jlong) { if (x >= (jfloat) max_jlong)
return lltmp; return max_jlong;
} else { if (x <= (jfloat) min_jlong)
if (x < 0) { return min_jlong;
return min_jlong; return (jlong) x;
} else {
return max_jlong;
}
}
JRT_END JRT_END
JRT_LEAF(jint, SharedRuntime::d2i(jdouble x)) JRT_LEAF(jint, SharedRuntime::d2i(jdouble x))
if (g_isnan(x)) {return 0;} if (g_isnan(x))
jlong lltmp = (jlong)x; return 0;
jint ltmp = (jint)lltmp; if (x >= (jdouble) max_jint)
if (ltmp == lltmp) { return max_jint;
return ltmp; if (x <= (jdouble) min_jint)
} else { return min_jint;
if (x < 0) { return (jint) x;
return min_jint;
} else {
return max_jint;
}
}
JRT_END JRT_END
JRT_LEAF(jlong, SharedRuntime::d2l(jdouble x)) JRT_LEAF(jlong, SharedRuntime::d2l(jdouble x))
if (g_isnan(x)) {return 0;} if (g_isnan(x))
jlong lltmp = (jlong)x; return 0;
if (lltmp != min_jlong) { if (x >= (jdouble) max_jlong)
return lltmp; return max_jlong;
} else { if (x <= (jdouble) min_jlong)
if (x < 0) { return min_jlong;
return min_jlong; return (jlong) x;
} else {
return max_jlong;
}
}
JRT_END JRT_END
......
/*
* Copyright 2008 Sun Microsystems, Inc. All Rights Reserved.
* 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.
*
* Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
* CA 95054 USA or visit www.sun.com if you need additional information or
* have any questions.
*
*/
/*
* @test
* @bug 6778657
* @summary Casts in SharedRuntime::f2i, f2l, d2i and d2l rely on undefined C++ behaviour
*/
public class Test {
public static void check_f2i(int expect) {
float check = expect;
check *= 2;
int actual = (int) check;
if (actual != expect)
throw new RuntimeException("expecting " + expect + ", got " + actual);
}
public static void check_f2l(long expect) {
float check = expect;
check *= 2;
long actual = (long) check;
if (actual != expect)
throw new RuntimeException("expecting " + expect + ", got " + actual);
}
public static void check_d2i(int expect) {
double check = expect;
check *= 2;
int actual = (int) check;
if (actual != expect)
throw new RuntimeException("expecting " + expect + ", got " + actual);
}
public static void check_d2l(long expect) {
double check = expect;
check *= 2;
long actual = (long) check;
if (actual != expect)
throw new RuntimeException("expecting " + expect + ", got " + actual);
}
public static void main(String[] args) {
check_f2i(Integer.MAX_VALUE);
check_f2i(Integer.MIN_VALUE);
check_f2l(Long.MAX_VALUE);
check_f2l(Long.MIN_VALUE);
check_d2i(Integer.MAX_VALUE);
check_d2i(Integer.MIN_VALUE);
check_d2l(Long.MAX_VALUE);
check_d2l(Long.MIN_VALUE);
}
}
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册