diff options
| author | 2015-08-20 01:13:28 +0000 | |
|---|---|---|
| committer | 2015-08-20 01:13:28 +0000 | |
| commit | a6d2ff29c4920b440b16bc6ceaa90710361b9be9 (patch) | |
| tree | 37080c5e3ef6392ef2b5e1d2d3f330f3441d981f | |
| parent | 7a1ccf7c7d1dd0defa1a82d973a8b80f3370c52c (diff) | |
| parent | 110ddef1da19c03dd5e167680d00f48e1377da9d (diff) | |
am 110ddef1: Merge "binder: Change from C11 <stdatomic.h> to C++11 <atomic>."
* commit '110ddef1da19c03dd5e167680d00f48e1377da9d':
  binder: Change from C11 <stdatomic.h> to C++11 <atomic>.
| -rw-r--r-- | include/binder/Binder.h | 6 | ||||
| -rw-r--r-- | libs/binder/Binder.cpp | 41 | 
2 files changed, 16 insertions, 31 deletions
| diff --git a/include/binder/Binder.h b/include/binder/Binder.h index 86628a03d3..f849fd4327 100644 --- a/include/binder/Binder.h +++ b/include/binder/Binder.h @@ -17,7 +17,7 @@  #ifndef ANDROID_BINDER_H  #define ANDROID_BINDER_H -#include <stdatomic.h> +#include <atomic>  #include <stdint.h>  #include <binder/IBinder.h> @@ -71,7 +71,7 @@ private:      class Extras; -    atomic_uintptr_t    mExtras;  // should be atomic<Extras *> +    std::atomic<Extras*> mExtras;              void*       mReserved0;  }; @@ -95,7 +95,7 @@ private:      IBinder* const          mRemote;      RefBase::weakref_type*  mRefs; -    volatile int32_t        mState; +    std::atomic<int32_t>    mState;  };  }; // namespace android diff --git a/libs/binder/Binder.cpp b/libs/binder/Binder.cpp index 9d200fb219..e39093d52e 100644 --- a/libs/binder/Binder.cpp +++ b/libs/binder/Binder.cpp @@ -16,7 +16,7 @@  #include <binder/Binder.h> -#include <stdatomic.h> +#include <atomic>  #include <utils/misc.h>  #include <binder/BpBinder.h>  #include <binder/IInterface.h> @@ -70,9 +70,8 @@ public:  // --------------------------------------------------------------------------- -BBinder::BBinder() +BBinder::BBinder() : mExtras(nullptr)  { -  atomic_init(&mExtras, static_cast<uintptr_t>(0));  }  bool BBinder::isBinderAlive() const @@ -139,19 +138,16 @@ void BBinder::attachObject(      const void* objectID, void* object, void* cleanupCookie,      object_cleanup_func func)  { -    Extras* e = reinterpret_cast<Extras*>( -                    atomic_load_explicit(&mExtras, memory_order_acquire)); +    Extras* e = mExtras.load(std::memory_order_acquire);      if (!e) {          e = new Extras; -        uintptr_t expected = 0; -        if (!atomic_compare_exchange_strong_explicit( -                                        &mExtras, &expected, -                                        reinterpret_cast<uintptr_t>(e), -                                        memory_order_release, -                                        memory_order_acquire)) { +        Extras* expected = nullptr; +        if (!mExtras.compare_exchange_strong(expected, e, +                                             std::memory_order_release, +                                             std::memory_order_acquire)) {              delete e; -            e = reinterpret_cast<Extras*>(expected);  // Filled in by CAS +            e = expected;  // Filled in by CAS          }          if (e == 0) return; // out of memory      } @@ -160,18 +156,9 @@ void BBinder::attachObject(      e->mObjects.attach(objectID, object, cleanupCookie, func);  } -// The C11 standard doesn't allow atomic loads from const fields, -// though C++11 does.  Fudge it until standards get straightened out. -static inline uintptr_t load_const_atomic(const atomic_uintptr_t* p, -                                          memory_order mo) { -    atomic_uintptr_t* non_const_p = const_cast<atomic_uintptr_t*>(p); -    return atomic_load_explicit(non_const_p, mo); -} -  void* BBinder::findObject(const void* objectID) const  { -    Extras* e = reinterpret_cast<Extras*>( -                    load_const_atomic(&mExtras, memory_order_acquire)); +    Extras* e = mExtras.load(std::memory_order_acquire);      if (!e) return NULL;      AutoMutex _l(e->mLock); @@ -180,8 +167,7 @@ void* BBinder::findObject(const void* objectID) const  void BBinder::detachObject(const void* objectID)  { -    Extras* e = reinterpret_cast<Extras*>( -                    atomic_load_explicit(&mExtras, memory_order_acquire)); +    Extras* e = mExtras.load(std::memory_order_acquire);      if (!e) return;      AutoMutex _l(e->mLock); @@ -195,8 +181,7 @@ BBinder* BBinder::localBinder()  BBinder::~BBinder()  { -    Extras* e = reinterpret_cast<Extras*>( -                    atomic_load_explicit(&mExtras, memory_order_relaxed)); +    Extras* e = mExtras.load(std::memory_order_relaxed);      if (e) delete e;  } @@ -252,7 +237,7 @@ BpRefBase::BpRefBase(const sp<IBinder>& o)  BpRefBase::~BpRefBase()  {      if (mRemote) { -        if (!(mState&kRemoteAcquired)) { +        if (!(mState.load(std::memory_order_relaxed)&kRemoteAcquired)) {              mRemote->decStrong(this);          }          mRefs->decWeak(this); @@ -261,7 +246,7 @@ BpRefBase::~BpRefBase()  void BpRefBase::onFirstRef()  { -    android_atomic_or(kRemoteAcquired, &mState); +    mState.fetch_or(kRemoteAcquired, std::memory_order_relaxed);  }  void BpRefBase::onLastStrongRef(const void* /*id*/) |