On 11/24/2011 12:50 PM, Andrew MacLeod wrote:
>       * optab.c (maybe_emit_atomic_exchange): New.  Try to emit an
>       atomic_exchange pattern.
>       (maybe_emit_sync_lock_test_and_set): New.  Try to emit an exchange
>       using __sync_lock_test_and_set.
>       (maybe_emit_compare_and_swap_exchange_loop): New. Try to emit an
>       exchange using a compare_and_swap loop.
>       (expand_sync_lock_test_and_set): New.  Expand sync_lock_test_and_set.
>       (expand_atomic_test_and_set): New.  Expand test_and_set operation.
>       (expand_atomic_exchange): Use new maybe_emit_* functions.
>       (expand_atomic_store): Use new maybe_emit_* functions.
>       * builtins.c (expand_builtin_sync_lock_test_and_set): Call
>       expand_sync_lock_test_and_set routine.
>       (expand_builtin_atomic_exchange): Remove parameter from call.
>       (expand_builtin_atomic_clear): Use atomic_clear pattern if present.
>       (expand_builtin_atomic_test_and_set): Add target and simply call
>       expand_atomic_test_and_set.
>       (expand_builtin): Add target to expand_builtin_atomic_test_and_set.
>       * expr.h (expand_atomic_exchange): Add parameter.
>       (expand_sync_lock_test_and_set): New prototype.
>       (expand_atomic_test_and_set, expand_atomic_clear): New prototypes.
> 

Ok.

r~

Reply via email to