From bc2a050d40976441cdb963ad829316c23e8df0aa Mon Sep 17 00:00:00 2001 From: Tom Lane <tgl@sss.pgh.pa.us> Date: Tue, 3 Jan 2012 16:00:06 -0500 Subject: [PATCH] Use a non-locking initial test in TAS_SPIN on PPC. Further testing convinces me that this is helpful at sufficiently high contention levels, though it's still worrisome that it loses slightly at lower contention levels. Per Manabu Ori. --- src/include/storage/s_lock.h | 3 +++ 1 file changed, 3 insertions(+) diff --git a/src/include/storage/s_lock.h b/src/include/storage/s_lock.h index ff7eb1418e6..9b02d1f5a40 100644 --- a/src/include/storage/s_lock.h +++ b/src/include/storage/s_lock.h @@ -358,6 +358,9 @@ typedef unsigned int slock_t; #define TAS(lock) tas(lock) +/* On PPC, it's a win to use a non-locking test before the lwarx */ +#define TAS_SPIN(lock) (*(lock) ? 1 : TAS(lock)) + /* * NOTE: per the Enhanced PowerPC Architecture manual, v1.0 dated 7-May-2002, * an isync is a sufficient synchronization barrier after a lwarx/stwcx loop. -- GitLab