]> granicus.if.org Git - postgresql/commitdiff
Another try at the inlined MIPS spinlock code. Can't test this myself,
authorTom Lane <tgl@sss.pgh.pa.us>
Fri, 26 Aug 2005 22:04:42 +0000 (22:04 +0000)
committerTom Lane <tgl@sss.pgh.pa.us>
Fri, 26 Aug 2005 22:04:42 +0000 (22:04 +0000)
but for sure it's not any more broken than the prior version.

src/include/storage/s_lock.h

index 0124b365a016425755ff0cdd14a0087ab2d1f9a1..3951aa7137b0b22afd2b7d2c068379f94111950d 100644 (file)
@@ -66,7 +66,7 @@
  * Portions Copyright (c) 1996-2005, PostgreSQL Global Development Group
  * Portions Copyright (c) 1994, Regents of the University of California
  *
- *       $PostgreSQL: pgsql/src/include/storage/s_lock.h,v 1.136 2005/08/26 14:47:35 tgl Exp $
+ *       $PostgreSQL: pgsql/src/include/storage/s_lock.h,v 1.137 2005/08/26 22:04:42 tgl Exp $
  *
  *-------------------------------------------------------------------------
  */
@@ -464,25 +464,25 @@ typedef unsigned int slock_t;
 static __inline__ int
 tas(volatile slock_t *lock)
 {
-       register volatile slock_t *__l = lock;
-       register int __r;
+       register volatile slock_t *_l = lock;
+       register int _res;
+       register int _tmp;
 
        __asm__ __volatile__(
                "       .set push           \n"
                "       .set mips2          \n"
                "       .set noreorder      \n"
                "       .set nomacro        \n"
-               "1:     ll      %0, %1      \n"
-               "       bne     %0, $0, 1f  \n"
-               "        xori   %0, 1       \n"
-               "       sc      %0, %1      \n"
-               "       beq     %0, $0, 1b  \n"
-               "        sync               \n"
+               "       ll      %0, %2      \n"
+               "       or      %1, %0, $1  \n"
+               "       sc      %1, %2      \n"
+               "       xori    %1, $1      \n"
+               "       or      %0, %0, %1  \n"
                "1:     .set pop              "
-:              "=&r" (__r), "+R" (*__l)
+:              "=&r" (_res), "=&r" (_tmp), "+R" (*_l)
 :
-:              "memory", "cc");
-       return __r;
+:              "memory");
+       return _res;
 }
 
 #endif /* __mips__ && !__sgi */