* lock to be empty of visitors.
*/
if (lk & PLOCK_LORW_WRQ_MASK)
+#if defined(PLOCK_LORW_INLINE_WAIT)
+ lk = __pl_wait_unlock_long(lock, PLOCK_LORW_WRQ_MASK);
+#else
lk = pl_wait_unlock_long(lock, PLOCK_LORW_WRQ_MASK);
+#endif
/* count us as visitor among others */
lk = pl_ldadd_acq(lock, PLOCK_LORW_SHR_BASE);
/* wait for end of exclusive access if any */
if (lk & PLOCK_LORW_EXC_MASK)
+#if defined(PLOCK_LORW_INLINE_WAIT)
+ lk = __pl_wait_unlock_long(lock, PLOCK_LORW_EXC_MASK);
+#else
lk = pl_wait_unlock_long(lock, PLOCK_LORW_EXC_MASK);
+#endif
}
*/
lk = pl_deref_long(lock);
if (__builtin_expect(lk & PLOCK_LORW_WRQ_MASK, 1))
+#if defined(PLOCK_LORW_INLINE_WAIT)
+ lk = __pl_wait_unlock_long(lock, PLOCK_LORW_WRQ_MASK);
+#else
lk = pl_wait_unlock_long(lock, PLOCK_LORW_WRQ_MASK);
+#endif
do {
/* let's check for the two sources of contention at once */
/* note below, an OR is significantly cheaper than BTS or XADD */
if (!(lk & PLOCK_LORW_WRQ_MASK))
pl_or_noret(lock, PLOCK_LORW_WRQ_BASE);
+#if defined(PLOCK_LORW_INLINE_WAIT)
+ lk = __pl_wait_unlock_long(lock, PLOCK_LORW_SHR_MASK);
+#else
lk = pl_wait_unlock_long(lock, PLOCK_LORW_SHR_MASK);
+#endif
}
/* And also wait for a previous writer to finish. */
if (lk & PLOCK_LORW_EXC_MASK)
+#if defined(PLOCK_LORW_INLINE_WAIT)
+ lk = __pl_wait_unlock_long(lock, PLOCK_LORW_EXC_MASK);
+#else
lk = pl_wait_unlock_long(lock, PLOCK_LORW_EXC_MASK);
+#endif
}
/* A fresh new reader may appear right now if there were none