*
*
* The interface to spinlocks is defined by the typedef "slock_t" and
- * these macros:
+ * these functions:
*
* void SpinLockInit(volatile slock_t *lock)
* Initialize a spinlock (to the unlocked state).
* void SpinLockRelease(volatile slock_t *lock)
* Unlock a previously acquired lock.
*
- * Callers must beware that the macro argument may be evaluated multiple
- * times!
- *
* Load and store operations in calling code are guaranteed not to be
* reordered with respect to these operations, because they include a
* compiler barrier. (Before PostgreSQL 9.5, callers needed to use a
* Keep in mind the coding rule that spinlocks must not be held for more
* than a few instructions. In particular, we assume it is not possible
* for a CHECK_FOR_INTERRUPTS() to occur while holding a spinlock, and so
- * it is not necessary to do HOLD/RESUME_INTERRUPTS() in these macros.
+ * it is not necessary to do HOLD/RESUME_INTERRUPTS() in these functions.
*
- * These macros are implemented in terms of hardware-dependent macros
+ * These functions are implemented in terms of hardware-dependent macros
* supplied by s_lock.h. There is not currently any extra functionality
* added by this header, but there has been in the past and may someday
* be again.
#include "storage/s_lock.h"
+static inline void
+SpinLockInit(volatile slock_t *lock)
+{
+ S_INIT_LOCK(lock);
+}
-#define SpinLockInit(lock) S_INIT_LOCK(lock)
-
-#define SpinLockAcquire(lock) S_LOCK(lock)
+static inline void
+SpinLockAcquire(volatile slock_t *lock)
+{
+ S_LOCK(lock);
+}
-#define SpinLockRelease(lock) S_UNLOCK(lock)
+static inline void
+SpinLockRelease(volatile slock_t *lock)
+{
+ S_UNLOCK(lock);
+}
#endif /* SPIN_H */