Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/arch Nix mb_* on sparc and sparc64.
details: https://anonhg.NetBSD.org/src/rev/24c72a4f3b20
branches: trunk
changeset: 1005123:24c72a4f3b20
user: riastradh <riastradh%NetBSD.org@localhost>
date: Fri Nov 29 20:06:34 2019 +0000
description:
Nix mb_* on sparc and sparc64.
diffstat:
sys/arch/sparc/include/lock.h | 44 +---------------------------------------
sys/arch/sparc64/include/mutex.h | 8 +++++-
2 files changed, 7 insertions(+), 45 deletions(-)
diffs (78 lines):
diff -r 36b612487558 -r 24c72a4f3b20 sys/arch/sparc/include/lock.h
--- a/sys/arch/sparc/include/lock.h Fri Nov 29 20:06:08 2019 +0000
+++ b/sys/arch/sparc/include/lock.h Fri Nov 29 20:06:34 2019 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: lock.h,v 1.32 2017/09/17 00:01:08 christos Exp $ */
+/* $NetBSD: lock.h,v 1.33 2019/11/29 20:06:34 riastradh Exp $ */
/*-
* Copyright (c) 1998, 1999, 2006 The NetBSD Foundation, Inc.
@@ -140,46 +140,4 @@
*alp = __SIMPLELOCK_UNLOCKED;
}
-#if defined(__sparc_v9__)
-static __inline void
-mb_read(void)
-{
- __asm __volatile("membar #LoadLoad" : : : "memory");
-}
-
-static __inline void
-mb_write(void)
-{
- __asm __volatile("" : : : "memory");
-}
-
-static __inline void
-mb_memory(void)
-{
- __asm __volatile("membar #MemIssue" : : : "memory");
-}
-#else /* __sparc_v9__ */
-static __inline void
-mb_read(void)
-{
- static volatile int junk;
- __asm volatile("st %%g0,[%0]"
- :
- : "r" (&junk)
- : "memory");
-}
-
-static __inline void
-mb_write(void)
-{
- __insn_barrier();
-}
-
-static __inline void
-mb_memory(void)
-{
- mb_read();
-}
-#endif /* __sparc_v9__ */
-
#endif /* _MACHINE_LOCK_H */
diff -r 36b612487558 -r 24c72a4f3b20 sys/arch/sparc64/include/mutex.h
--- a/sys/arch/sparc64/include/mutex.h Fri Nov 29 20:06:08 2019 +0000
+++ b/sys/arch/sparc64/include/mutex.h Fri Nov 29 20:06:34 2019 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: mutex.h,v 1.4 2008/04/28 20:23:37 martin Exp $ */
+/* $NetBSD: mutex.h,v 1.5 2019/11/29 20:06:34 riastradh Exp $ */
/*-
* Copyright (c) 2002, 2007 The NetBSD Foundation, Inc.
@@ -55,7 +55,11 @@
#define __HAVE_MUTEX_STUBS 1
#define __HAVE_SIMPLE_MUTEXES 1
-#define MUTEX_RECEIVE(mtx) mb_read()
+/*
+ * XXX Should this be LoadLoad|LoadStore, or does the assumption of a
+ * preceding atomic r/m/w operation obviate the need for that?
+ */
+#define MUTEX_RECEIVE(mtx) __asm __volatile("membar #LoadLoad" : : : "memory")
/*
* MUTEX_GIVE: no memory barrier required, as _lock_cas() will take care of it.
Home |
Main Index |
Thread Index |
Old Index