| Index: include/core/SkSpinlock.h
|
| diff --git a/include/core/SkSpinlock.h b/include/core/SkSpinlock.h
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..68a6ff7b1246bcd216327a683a36d75148f2845b
|
| --- /dev/null
|
| +++ b/include/core/SkSpinlock.h
|
| @@ -0,0 +1,37 @@
|
| +/*
|
| + * Copyright 2015 Google Inc.
|
| + *
|
| + * Use of this source code is governed by a BSD-style license that can be
|
| + * found in the LICENSE file.
|
| + */
|
| +
|
| +// This file is not part of the public Skia API.
|
| +
|
| +#ifndef SkSpinlock_DEFINED
|
| +#define SkSpinlock_DEFINED
|
| +
|
| +#include "SkAtomics.h"
|
| +
|
| +#define SK_DECLARE_STATIC_SPINLOCK(name) namespace {} static SkPODSpinlock name
|
| +
|
| +// This class has no constructor and must be zero-initialized (the macro above does this).
|
| +struct SkPODSpinlock {
|
| + void acquire() {
|
| + // To act as a mutex, we need an acquire barrier.
|
| + while(sk_atomic_exchange(&fLocked, true, sk_memory_order_acquire)) { /*spin*/ }
|
| + }
|
| + void release() {
|
| + // To act as a mutex, we need a release barrier.
|
| + sk_atomic_store(&fLocked, false, sk_memory_order_release);
|
| + }
|
| +
|
| + bool fLocked;
|
| +};
|
| +
|
| +// For non-global-static use cases, this is normally what you want.
|
| +class SkSpinlock : public SkPODSpinlock {
|
| +public:
|
| + SkSpinlock() { this->release(); }
|
| +};
|
| +
|
| +#endif//SkSpinlock_DEFINED
|
|
|