aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBruce Momjian <bruce@momjian.us>1998-09-18 17:18:41 +0000
committerBruce Momjian <bruce@momjian.us>1998-09-18 17:18:41 +0000
commit4a9da7e5c4c1f8aeb281d3fe6d3527564574b2cb (patch)
tree86acb013552c0ef81e3ac9b8899551bf7c791fd6
parent1202ab259aec14b6d09c9b885b0c6e8ff068fb3d (diff)
downloadpostgresql-4a9da7e5c4c1f8aeb281d3fe6d3527564574b2cb.tar.gz
postgresql-4a9da7e5c4c1f8aeb281d3fe6d3527564574b2cb.zip
NS32K lock patch reversed.
-rw-r--r--src/backend/storage/buffer/s_lock.c13
-rw-r--r--src/include/storage/s_lock.h19
2 files changed, 18 insertions, 14 deletions
diff --git a/src/backend/storage/buffer/s_lock.c b/src/backend/storage/buffer/s_lock.c
index c50c9612bdb..a7b42bc4793 100644
--- a/src/backend/storage/buffer/s_lock.c
+++ b/src/backend/storage/buffer/s_lock.c
@@ -7,7 +7,7 @@
*
*
* IDENTIFICATION
- * $Header: /cvsroot/pgsql/src/backend/storage/buffer/Attic/s_lock.c,v 1.11 1998/09/18 05:36:23 momjian Exp $
+ * $Header: /cvsroot/pgsql/src/backend/storage/buffer/Attic/s_lock.c,v 1.12 1998/09/18 17:18:39 momjian Exp $
*
*-------------------------------------------------------------------------
*/
@@ -118,17 +118,6 @@ success: \n\
#endif /* PPC */
-#if defined(__ns32k__)
-int
-tas(volatile slock_t *lock)
-{
- int res;
- __asm__("sbitb 0, %0" : "=m"(*lock));
- __asm__("sprb us, %0" : "=r"(res));
- res = (res >> 5) & 1;
- return res;
-}
-#endif
#else /* defined(__GNUC__) */
/***************************************************************************
diff --git a/src/include/storage/s_lock.h b/src/include/storage/s_lock.h
index 967ec432cd1..7b531fda725 100644
--- a/src/include/storage/s_lock.h
+++ b/src/include/storage/s_lock.h
@@ -7,7 +7,7 @@
*
*
* IDENTIFICATION
- * $Header: /cvsroot/pgsql/src/include/storage/s_lock.h,v 1.48 1998/09/18 05:36:24 momjian Exp $
+ * $Header: /cvsroot/pgsql/src/include/storage/s_lock.h,v 1.49 1998/09/18 17:18:41 momjian Exp $
*
*-------------------------------------------------------------------------
*/
@@ -213,7 +213,22 @@ tas(slock_t *s_lock)
#endif /* NEED_I386_TAS_ASM */
-/* NS32K code is in s_lock.c */
+
+#if defined(NEED_NS32K_TAS_ASM)
+
+#define S_LOCK(lock) \
+{ \
+ slock_t res = 1; \
+ while (res) { \
+ __asm__("movqd 0, r0"); \
+ __asm__("sbitd r0, %0" : "=m"(*lock)); \
+ __asm__("sprb us, %0" : "=r" (res)); \
+ res = ((res >> 5) & 1); \
+ } \
+}
+
+#endif /* NEED_NS32K_TAS_ASM */
+
#endif /* defined(__GNUC__) */