From 9a93ac006df5199c4dc03710043d1d77396ff29e Mon Sep 17 00:00:00 2001 From: Ulrich Drepper Date: Mon, 30 Aug 1999 21:51:29 +0000 Subject: Update. * db2/db_int.h: Change tsl_t type to u_int32_t. * db2/mutex/mutex.c: Allow Alpha mutex definitions. * db2/mutex/alpha.h: New file. * db2/mutex/sparc.gcc: Fix store code for v9. Simplify clear code. * sysdeps/alpha/Makefile [db2]: Set CFLAGS of mutex.c to make spinlocks known. Patches by Richard Henderson. --- ChangeLog | 8 ++++++++ db2/db_int.h | 2 +- db2/mutex/alpha.h | 26 ++++++++++++++++++++++++++ db2/mutex/mutex.c | 4 ++++ db2/mutex/sparc.gcc | 14 ++++++-------- sysdeps/alpha/Makefile | 6 +++++- timezone/test-tz.c | 2 +- 7 files changed, 51 insertions(+), 11 deletions(-) create mode 100644 db2/mutex/alpha.h diff --git a/ChangeLog b/ChangeLog index e7cb403..992ec54 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,5 +1,13 @@ 1999-08-30 Ulrich Drepper + * db2/db_int.h: Change tsl_t type to u_int32_t. + * db2/mutex/mutex.c: Allow Alpha mutex definitions. + * db2/mutex/alpha.h: New file. + * db2/mutex/sparc.gcc: Fix store code for v9. Simplify clear code. + * sysdeps/alpha/Makefile [db2]: Set CFLAGS of mutex.c to make spinlocks + known. + Patches by Richard Henderson. + * stdlib/tst-environ.c: Add cast to avoid warning. * timezone/test-tz.c: Use setenv instead of putenv. diff --git a/db2/db_int.h b/db2/db_int.h index 4c2e794..228c7ab 100644 --- a/db2/db_int.h +++ b/db2/db_int.h @@ -138,7 +138,7 @@ typedef struct __fn { /******************************************************* * Mutex support. *******************************************************/ -typedef unsigned char tsl_t; +typedef u_int32_t tsl_t; /* * !!! diff --git a/db2/mutex/alpha.h b/db2/mutex/alpha.h new file mode 100644 index 0000000..ad3afc4 --- /dev/null +++ b/db2/mutex/alpha.h @@ -0,0 +1,26 @@ +/* For alpha, 0 is clear, 1 is set. */ + +#ifdef __GNUC__ +#define TSL_SET(tsl) ({ \ + register tsl_t *__l = (tsl); \ + int __r; \ + asm volatile( \ + "1: ldl_l %0,%1\n" \ + " blbs %0,2f\n" \ + " mov 1,%0\n" \ + " stl_c %0,%1\n" \ + " bne %0,1b\n" \ + " mb\n" \ + "2:" \ + : "=&r"(__r), "=m"(*__l) : "m"(*__l) : "memory"); \ + __r; \ +}) +#endif + +#ifdef __DECC +#include +#define TSL_SET(tsl) (__LOCK_LONG_RETRY((tsl), 1) != 0) +#endif + +#define TSL_UNSET(tsl) (*(tsl) = 0) +#define TSL_INIT(tsl) TSL_UNSET(tsl) diff --git a/db2/mutex/mutex.c b/db2/mutex/mutex.c index acc6aa0..2fac14c 100644 --- a/db2/mutex/mutex.c +++ b/db2/mutex/mutex.c @@ -110,6 +110,10 @@ static const char sccsid[] = "@(#)mutex.c 10.52 (Sleepycat) 11/8/98"; #include "x86.gcc" #endif +#ifdef HAVE_ASSEM_ALPHA +#include "alpha.h" +#endif + #ifdef WIN16 /* Win16 spinlocks are simple because we cannot possibly be preempted. */ #define TSL_INIT(tsl) diff --git a/db2/mutex/sparc.gcc b/db2/mutex/sparc.gcc index 8445a06..9e3239b 100644 --- a/db2/mutex/sparc.gcc +++ b/db2/mutex/sparc.gcc @@ -13,21 +13,19 @@ * For gcc/sparc, 0 is clear, 1 is set. */ -#if defined(__sparcv9__) -Does the following code need membar instructions for V9 processors? -#endif +/* The stbar is needed for v8, and is implemented as membar #sync on v9, + so is functional there as well. For v7, stbar may generate an illegal + instruction and we have no way to tell what we're running on. Some + operating systems notice and skip this instruction in the fault handler. */ #define TSL_SET(tsl) ({ \ register tsl_t *__l = (tsl); \ register tsl_t __r; \ __asm__ volatile \ - ("ldstub [%1],%0" \ + ("ldstub [%1],%0; stbar" \ : "=r"( __r) : "r" (__l)); \ !__r; \ }) -#define TSL_UNSET(tsl) ({ \ - register tsl_t *__l = (tsl); \ - __asm__ volatile ("stb %%g0,[%0]" : : "r" (__l)); \ -}) +#define TSL_UNSET(tsl) ((tsl) = 0) #define TSL_INIT(tsl) TSL_UNSET(tsl) diff --git a/sysdeps/alpha/Makefile b/sysdeps/alpha/Makefile index 250a317..63c7d4b 100644 --- a/sysdeps/alpha/Makefile +++ b/sysdeps/alpha/Makefile @@ -1,4 +1,4 @@ -# Copyright (C) 1993, 1994, 1995, 1996, 1997 Free Software Foundation, Inc. +# Copyright (C) 1993, 94, 95, 96, 97, 99 Free Software Foundation, Inc. # This file is part of the GNU C Library. # Contributed by Brendan Kehoe (brendan@zen.org). @@ -17,6 +17,10 @@ # write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330, # Boston, MA 02111-1307, USA. +ifeq ($(subdir),db2) +CPPFLAGS += -DHAVE_SPINLOCKS=1 -DHAVE_ASSEM_ALPHA=1 +endif + ifeq ($(subdir),gmon) sysdep_routines += _mcount endif diff --git a/timezone/test-tz.c b/timezone/test-tz.c index 28e1e37..af37d8a 100644 --- a/timezone/test-tz.c +++ b/timezone/test-tz.c @@ -34,7 +34,7 @@ main (int argc, char ** argv) for (i = 0; i < sizeof (tests) / sizeof (tests[0]); ++i) { - setenv ("TZ", tests[i].env); + setenv ("TZ", tests[i].env, 1); t = mktime (&tm); if (t != tests[i].expected) { -- cgit v1.1