From: Bruce Momjian Date: Sun, 19 Jul 1998 01:19:54 +0000 (+0000) Subject: Somewhere between 6.1 and 6.3 someone removed the support for the X-Git-Tag: REL6_4_2~771 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=62cd6e7b7559ecd31531df0e5db89d336241e6a5;p=postgresql Somewhere between 6.1 and 6.3 someone removed the support for the NS32K machine I contributed. In any case, I now have postgresql-6.3 running again on NetBSD/pc532, a NS32532 machine. The following changes are needed relative to the src directory. (It looks like support was partially removed when the files were moved from the src/backend/storage/.... tree to the src/include tree.) If you need me to get a current development version of postgresql for this change let me know. Also, let me know if this code needs updating due to another code movement that deleted the old NS32K support. Thank you. Phil Nelson --- diff --git a/src/include/port/bsd.h b/src/include/port/bsd.h index 03c99acd87..4e754e77de 100644 --- a/src/include/port/bsd.h +++ b/src/include/port/bsd.h @@ -15,8 +15,8 @@ #define HAS_TEST_AND_SET #endif -#if defined(ns32k) -#define NEED_NS32k_TAS_ASM +#if defined(__ns32k__) +#define NEED_NS32K_TAS_ASM #define HAS_TEST_AND_SET #endif diff --git a/src/include/storage/s_lock.h b/src/include/storage/s_lock.h index 7cbf56385e..70a0f4226c 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.39 1998/07/18 14:58:58 momjian Exp $ + * $Header: /cvsroot/pgsql/src/include/storage/s_lock.h,v 1.40 1998/07/19 01:19:54 momjian Exp $ * *------------------------------------------------------------------------- */ @@ -209,6 +209,22 @@ tas(slock_t *s_lock) #endif /* NEED_I386_TAS_ASM */ + +#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__) */ @@ -308,6 +324,10 @@ int tas(volatile slock_t *lock); /* port/.../tas.s, or s_lock.c */ #define TAS(lock) tas((volatile slock_t *) lock) #endif /* TAS */ +#define S_UNLOCK(lock) (*(lock) = 0) + +#define S_INIT_LOCK(lock) S_UNLOCK(lock) + #endif /* HAS_TEST_AND_SET */ #endif /* S_LOCK_H */