From: Andrew Haley Date: Wed, 24 Jan 2007 17:11:04 +0000 (+0000) Subject: [multiple changes] X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=c863b570e4f51fd56a80bec9d9aaeb51f9847543;p=gcc.git [multiple changes] 2007-01-24 Andrew Haley * jcf-parse.c (HANDLE_SYNTHETIC_ATTRIBUTE): current_class is a type node, not a decl, so use TYPE_SYNTHETIC not CLASS_SYNTHETIC. 2007-01-22 Andrew Haley * builtins.c (VMSupportsCS8_builtin): New function. From-SVN: r121118 --- diff --git a/gcc/java/ChangeLog b/gcc/java/ChangeLog index 37029845d9e..4d24a208e1c 100644 --- a/gcc/java/ChangeLog +++ b/gcc/java/ChangeLog @@ -1,3 +1,12 @@ +2007-01-24 Andrew Haley + + * jcf-parse.c (HANDLE_SYNTHETIC_ATTRIBUTE): current_class is a + type node, not a decl, so use TYPE_SYNTHETIC not CLASS_SYNTHETIC. + +2007-01-22 Andrew Haley + + * builtins.c (VMSupportsCS8_builtin): New function. + 2007-01-23 Andrew Pinski PR java/30454 diff --git a/gcc/java/builtins.c b/gcc/java/builtins.c index 9b5353b2644..ef8854ae2e6 100644 --- a/gcc/java/builtins.c +++ b/gcc/java/builtins.c @@ -54,7 +54,7 @@ static tree compareAndSwapLong_builtin (tree, tree); static tree compareAndSwapObject_builtin (tree, tree); static tree putVolatile_builtin (tree, tree); static tree getVolatile_builtin (tree, tree); - +static tree VMSupportsCS8_builtin (tree, tree); /* Functions of this type are used to inline a given call. Such a @@ -121,6 +121,8 @@ static GTY(()) struct builtin_record java_builtins[] = { { "sun.misc.Unsafe" }, { "getIntVolatile" }, getVolatile_builtin, 0}, { { "sun.misc.Unsafe" }, { "getLongVolatile" }, getVolatile_builtin, 0}, { { "sun.misc.Unsafe" }, { "getLong" }, getVolatile_builtin, 0}, + { { "java.util.concurrent.atomic.AtomicLong" }, { "VMSupportsCS8" }, + VMSupportsCS8_builtin, 0}, { { NULL }, { NULL }, NULL, END_BUILTINS } }; @@ -432,7 +434,20 @@ getVolatile_builtin (tree method_return_type ATTRIBUTE_UNUSED, return stmt; } - + +static tree +VMSupportsCS8_builtin (tree method_return_type, + tree method_arguments ATTRIBUTE_UNUSED) +{ + enum machine_mode mode = TYPE_MODE (long_type_node); + gcc_assert (method_return_type == boolean_type_node); + if (sync_compare_and_swap_cc[mode] != CODE_FOR_nothing + || sync_compare_and_swap[mode] != CODE_FOR_nothing) + return boolean_true_node; + else + return boolean_false_node; +} + #define BUILTIN_NOTHROW 1 diff --git a/gcc/java/jcf-parse.c b/gcc/java/jcf-parse.c index 10e13aea792..8a6d6fc2499 100644 --- a/gcc/java/jcf-parse.c +++ b/gcc/java/jcf-parse.c @@ -975,7 +975,7 @@ handle_signature_attribute (int member_index, JCF *jcf, else if (current_field) \ FIELD_SYNTHETIC (current_field) = 1; \ else \ - CLASS_SYNTHETIC (current_class) = 1; \ + TYPE_SYNTHETIC (current_class) = 1; \ } #define HANDLE_GCJCOMPILED_ATTRIBUTE() \