aboutsummaryrefslogtreecommitdiff
path: root/gcc/java
diff options
context:
space:
mode:
authorRoger Sayle <roger@nextmovesoftware.com>2016-05-31 11:30:56 +0000
committerRoger Sayle <sayle@gcc.gnu.org>2016-05-31 11:30:56 +0000
commita1293f402a25801d03a58312b06b65c33702c726 (patch)
treee4795973441e52b0a0b748fb08728e4962eb277f /gcc/java
parent051154a1f6be0f597b7da235d6fe13463e7629be (diff)
downloadgcc-a1293f402a25801d03a58312b06b65c33702c726.zip
gcc-a1293f402a25801d03a58312b06b65c33702c726.tar.gz
gcc-a1293f402a25801d03a58312b06b65c33702c726.tar.bz2
builtins.c (java_builtins): Use popcount* and bswap* builtins to implement bitCount() and reverseBytes()...
2016-05-31 Roger Sayle <roger@nextmovesoftware.com> gcc/java: * builtins.c (java_builtins): Use popcount* and bswap* builtins to implement bitCount() and reverseBytes() methods in java.lang.Integer and friends. (initialize_builtins): Annotate math builtins with ECF_LEAF. Call define_builtin for the new popcount* and bswap* builtins. libjava: * testsuite/libjava.lang/BuiltinBitCount.java: New test case. * testsuite/libjava.lang/BuiltinReverseBytes.java: Likewise. From-SVN: r236919
Diffstat (limited to 'gcc/java')
-rw-r--r--gcc/java/ChangeLog8
-rw-r--r--gcc/java/builtins.c65
2 files changed, 57 insertions, 16 deletions
diff --git a/gcc/java/ChangeLog b/gcc/java/ChangeLog
index 8aa55ab..58e40a6 100644
--- a/gcc/java/ChangeLog
+++ b/gcc/java/ChangeLog
@@ -1,3 +1,11 @@
+2016-05-31 Roger Sayle <roger@nextmovesoftware.com>
+
+ * builtins.c (java_builtins): Use popcount* and bswap* builtins to
+ implement bitCount() and reverseBytes() methods in java.lang.Integer
+ and friends.
+ (initialize_builtins): Annotate math builtins with ECF_LEAF. Call
+ define_builtin for the new popcount* and bswap* builtins.
+
2016-04-28 Rainer Orth <ro@CeBiTec.Uni-Bielefeld.DE>
PR java/70839
diff --git a/gcc/java/builtins.c b/gcc/java/builtins.c
index 033e086..f27831d 100644
--- a/gcc/java/builtins.c
+++ b/gcc/java/builtins.c
@@ -98,6 +98,11 @@ static GTY(()) struct builtin_record java_builtins[] =
{ { "java.lang.Math" }, { "sin" }, NULL, BUILT_IN_SIN },
{ { "java.lang.Math" }, { "sqrt" }, NULL, BUILT_IN_SQRT },
{ { "java.lang.Math" }, { "tan" }, NULL, BUILT_IN_TAN },
+ { { "java.lang.Integer" }, { "bitCount" }, NULL, BUILT_IN_POPCOUNT },
+ { { "java.lang.Integer" }, { "reverseBytes" }, NULL, BUILT_IN_BSWAP32 },
+ { { "java.lang.Long" }, { "bitCount" }, NULL, BUILT_IN_POPCOUNTL },
+ { { "java.lang.Long" }, { "reverseBytes" }, NULL, BUILT_IN_BSWAP64 },
+ { { "java.lang.Short" }, { "reverseBytes" }, NULL, BUILT_IN_BSWAP16 },
{ { "java.lang.Float" }, { "intBitsToFloat" }, convert_real,
(enum built_in_function) 0 },
{ { "java.lang.Double" }, { "longBitsToDouble" }, convert_real,
@@ -483,6 +488,7 @@ initialize_builtins (void)
tree double_ftype_double, double_ftype_double_double;
tree float_ftype_float_float;
tree boolean_ftype_boolean_boolean;
+ tree int_ftype_int;
int i;
for (i = 0; java_builtins[i].builtin_code != END_BUILTINS; ++i)
@@ -507,50 +513,77 @@ initialize_builtins (void)
double_type_node, double_type_node, NULL_TREE);
define_builtin (BUILT_IN_FMOD, "__builtin_fmod",
- double_ftype_double_double, "fmod", ECF_CONST);
+ double_ftype_double_double, "fmod", ECF_CONST | ECF_LEAF);
define_builtin (BUILT_IN_FMODF, "__builtin_fmodf",
- float_ftype_float_float, "fmodf", ECF_CONST);
+ float_ftype_float_float, "fmodf", ECF_CONST | ECF_LEAF);
define_builtin (BUILT_IN_ACOS, "__builtin_acos",
double_ftype_double, "_ZN4java4lang4Math4acosEJdd",
- ECF_CONST);
+ ECF_CONST | ECF_LEAF);
define_builtin (BUILT_IN_ASIN, "__builtin_asin",
double_ftype_double, "_ZN4java4lang4Math4asinEJdd",
- ECF_CONST);
+ ECF_CONST | ECF_LEAF);
define_builtin (BUILT_IN_ATAN, "__builtin_atan",
double_ftype_double, "_ZN4java4lang4Math4atanEJdd",
- ECF_CONST);
+ ECF_CONST | ECF_LEAF);
define_builtin (BUILT_IN_ATAN2, "__builtin_atan2",
double_ftype_double_double, "_ZN4java4lang4Math5atan2EJddd",
- ECF_CONST);
+ ECF_CONST | ECF_LEAF);
define_builtin (BUILT_IN_CEIL, "__builtin_ceil",
double_ftype_double, "_ZN4java4lang4Math4ceilEJdd",
- ECF_CONST);
+ ECF_CONST | ECF_LEAF);
define_builtin (BUILT_IN_COS, "__builtin_cos",
double_ftype_double, "_ZN4java4lang4Math3cosEJdd",
- ECF_CONST);
+ ECF_CONST | ECF_LEAF);
define_builtin (BUILT_IN_EXP, "__builtin_exp",
double_ftype_double, "_ZN4java4lang4Math3expEJdd",
- ECF_CONST);
+ ECF_CONST | ECF_LEAF);
define_builtin (BUILT_IN_FLOOR, "__builtin_floor",
double_ftype_double, "_ZN4java4lang4Math5floorEJdd",
- ECF_CONST);
+ ECF_CONST | ECF_LEAF);
define_builtin (BUILT_IN_LOG, "__builtin_log",
double_ftype_double, "_ZN4java4lang4Math3logEJdd",
- ECF_CONST);
+ ECF_CONST | ECF_LEAF);
define_builtin (BUILT_IN_POW, "__builtin_pow",
double_ftype_double_double, "_ZN4java4lang4Math3powEJddd",
- ECF_CONST);
+ ECF_CONST | ECF_LEAF);
define_builtin (BUILT_IN_SIN, "__builtin_sin",
double_ftype_double, "_ZN4java4lang4Math3sinEJdd",
- ECF_CONST);
+ ECF_CONST | ECF_LEAF);
define_builtin (BUILT_IN_SQRT, "__builtin_sqrt",
double_ftype_double, "_ZN4java4lang4Math4sqrtEJdd",
- ECF_CONST);
+ ECF_CONST | ECF_LEAF);
define_builtin (BUILT_IN_TAN, "__builtin_tan",
double_ftype_double, "_ZN4java4lang4Math3tanEJdd",
- ECF_CONST);
-
+ ECF_CONST | ECF_LEAF);
+
+ int_ftype_int = build_function_type_list (int_type_node,
+ int_type_node, NULL_TREE);
+
+ define_builtin (BUILT_IN_POPCOUNT, "__builtin_popcount", int_ftype_int,
+ "_ZN4java4lang7Integer8bitCountEJii",
+ ECF_CONST | ECF_LEAF | ECF_NOTHROW);
+ define_builtin (BUILT_IN_BSWAP32, "__builtin_bswap32", int_ftype_int,
+ "_ZN4java4lang7Integer12reverseBytesEJii",
+ ECF_CONST | ECF_LEAF | ECF_NOTHROW);
+
+ define_builtin (BUILT_IN_POPCOUNTL, "__builtin_popcountl",
+ build_function_type_list (int_type_node,
+ long_type_node, NULL_TREE),
+ "_ZN4java4lang4Long8bitCountEJix",
+ ECF_CONST | ECF_LEAF | ECF_NOTHROW);
+ define_builtin (BUILT_IN_BSWAP64, "__builtin_bswap64",
+ build_function_type_list (long_type_node,
+ long_type_node, NULL_TREE),
+ "_ZN4java4lang4Long12reverseBytesEJxx",
+ ECF_CONST | ECF_LEAF | ECF_NOTHROW);
+
+ define_builtin (BUILT_IN_BSWAP16, "__builtin_bswap16",
+ build_function_type_list (short_type_node,
+ short_type_node, NULL_TREE),
+ "_ZN4java4lang5Short12reverseBytesEJss",
+ ECF_CONST | ECF_LEAF | ECF_NOTHROW);
+
boolean_ftype_boolean_boolean
= build_function_type_list (boolean_type_node,
boolean_type_node, boolean_type_node,