From: Tom Lane Date: Mon, 20 Nov 2017 22:57:46 +0000 (-0500) Subject: Add support for Motorola 88K to s_lock.h. X-Git-Tag: REL_10_2~130 X-Git-Url: http://git.postgresql.org/gitweb/?a=commitdiff_plain;h=1ecf7eeb8719e2fab008c37c17590cf3840cfc5b;p=postgresql.git Add support for Motorola 88K to s_lock.h. Apparently there are still people out there who care about this old architecture. They probably care about dusty versions of Postgres too, so back-patch to all supported branches. David Carlier (from a patch being carried by OpenBSD packagers) Discussion: https://postgr.es/m/CA+XhMqzwFSGVU7MEnfhCecc8YdP98tigXzzpd0AAdwaGwaVXEA@mail.gmail.com --- diff --git a/src/include/storage/s_lock.h b/src/include/storage/s_lock.h index bbf505e246f..d0d162e654e 100644 --- a/src/include/storage/s_lock.h +++ b/src/include/storage/s_lock.h @@ -543,6 +543,30 @@ tas(volatile slock_t *lock) #endif /* (__mc68000__ || __m68k__) && __linux__ */ +/* Motorola 88k */ +#if defined(__m88k__) +#define HAS_TEST_AND_SET + +typedef unsigned int slock_t; + +#define TAS(lock) tas(lock) + +static __inline__ int +tas(volatile slock_t *lock) +{ + register slock_t _res = 1; + + __asm__ __volatile__( + " xmem %0, %2, %%r0 \n" +: "+r"(_res), "+m"(*lock) +: "r"(lock) +: "memory"); + return (int) _res; +} + +#endif /* __m88k__ */ + + /* * VAXen -- even multiprocessor ones * (thanks to Tom Ivar Helbekkmo)