aboutsummaryrefslogtreecommitdiff
path: root/libstdc++-v3
diff options
context:
space:
mode:
authorNathan Myers <ncm@cantrip.org>2001-12-08 00:59:11 +0000
committerLoren J. Rittle <ljrittle@gcc.gnu.org>2001-12-08 00:59:11 +0000
commit7814a308e422b29a671f65fefecd0adb466160c9 (patch)
tree77def8cc82fa7c31270a0eeafbd13767d0fc0f20 /libstdc++-v3
parent941a878b35217227b19bed82d16e285a9f845436 (diff)
downloadgcc-7814a308e422b29a671f65fefecd0adb466160c9.zip
gcc-7814a308e422b29a671f65fefecd0adb466160c9.tar.gz
gcc-7814a308e422b29a671f65fefecd0adb466160c9.tar.bz2
atomicity.h (struct __Atomicity_lock<__inst>): Add.
libstdc++/5037 * config/cpu/sparc/sparc32/bits/atomicity.h (struct __Atomicity_lock<__inst>): Add. (__Atomicity_lock<__inst>::_S_atomicity_lock): Add. (__exchange_and_add): Use __Atomicity_lock<0>::_S_atomicity_lock instead of lock local to static function. (__atomic_add): Likewise. Co-Authored-By: Loren J. Rittle <ljrittle@acm.org> From-SVN: r47782
Diffstat (limited to 'libstdc++-v3')
-rw-r--r--libstdc++-v3/ChangeLog11
-rw-r--r--libstdc++-v3/config/cpu/sparc/sparc32/bits/atomicity.h19
2 files changed, 24 insertions, 6 deletions
diff --git a/libstdc++-v3/ChangeLog b/libstdc++-v3/ChangeLog
index 0d14cf9..71848d1 100644
--- a/libstdc++-v3/ChangeLog
+++ b/libstdc++-v3/ChangeLog
@@ -1,3 +1,14 @@
+2001-12-07 Nathan Myers <ncm@cantrip.org>
+ Loren Rittle <ljrittle@acm.org>
+
+ libstdc++/5037
+ * config/cpu/sparc/sparc32/bits/atomicity.h
+ (struct __Atomicity_lock<__inst>): Add.
+ (__Atomicity_lock<__inst>::_S_atomicity_lock): Add.
+ (__exchange_and_add): Use __Atomicity_lock<0>::_S_atomicity_lock
+ instead of lock local to static function.
+ (__atomic_add): Likewise.
+
2001-12-07 Phil Edwards <pme@gcc.gnu.org>
* src/globals.cc: Remove __GTHREADS guard.
diff --git a/libstdc++-v3/config/cpu/sparc/sparc32/bits/atomicity.h b/libstdc++-v3/config/cpu/sparc/sparc32/bits/atomicity.h
index 6f9412c..5254913 100644
--- a/libstdc++-v3/config/cpu/sparc/sparc32/bits/atomicity.h
+++ b/libstdc++-v3/config/cpu/sparc/sparc32/bits/atomicity.h
@@ -32,11 +32,19 @@
typedef int _Atomic_word;
+template <int __inst>
+struct __Atomicity_lock
+{
+ static unsigned char _S_atomicity_lock;
+};
+
+template <int __inst>
+unsigned char __Atomicity_lock<__inst>::_S_atomicity_lock = 0;
+
static int
__attribute__ ((__unused__))
__exchange_and_add (volatile _Atomic_word* __mem, int __val)
{
- static unsigned char __lock;
_Atomic_word __result, __tmp;
__asm__ __volatile__("1: ldstub [%1], %0\n\t"
@@ -44,13 +52,13 @@ __exchange_and_add (volatile _Atomic_word* __mem, int __val)
" bne 1b\n\t"
" nop"
: "=&r" (__tmp)
- : "r" (&__lock)
+ : "r" (&__Atomicity_lock<0>::_S_atomicity_lock)
: "memory");
__result = *__mem;
*__mem += __val;
__asm__ __volatile__("stb %%g0, [%0]"
: /* no outputs */
- : "r" (&__lock)
+ : "r" (&__Atomicity_lock<0>::_S_atomicity_lock)
: "memory");
return __result;
}
@@ -59,7 +67,6 @@ static void
__attribute__ ((__unused__))
__atomic_add (volatile _Atomic_word* __mem, int __val)
{
- static unsigned char __lock;
_Atomic_word __tmp;
__asm__ __volatile__("1: ldstub [%1], %0\n\t"
@@ -67,12 +74,12 @@ __atomic_add (volatile _Atomic_word* __mem, int __val)
" bne 1b\n\t"
" nop"
: "=&r" (__tmp)
- : "r" (&__lock)
+ : "r" (&__Atomicity_lock<0>::_S_atomicity_lock)
: "memory");
*__mem += __val;
__asm__ __volatile__("stb %%g0, [%0]"
: /* no outputs */
- : "r" (&__lock)
+ : "r" (&__Atomicity_lock<0>::_S_atomicity_lock)
: "memory");
}