Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/sys/arch/arm/include Use dmb/dsb



details:   https://anonhg.NetBSD.org/src/rev/eb853e1a6da0
branches:  trunk
changeset: 328169:eb853e1a6da0
user:      matt <matt%NetBSD.org@localhost>
date:      Fri Mar 28 21:40:53 2014 +0000

description:
Use dmb/dsb

diffstat:

 sys/arch/arm/include/mutex.h  |  18 +++++++++++++++++-
 sys/arch/arm/include/rwlock.h |  12 +++++++++++-
 2 files changed, 28 insertions(+), 2 deletions(-)

diffs (66 lines):

diff -r 2be76ffc1895 -r eb853e1a6da0 sys/arch/arm/include/mutex.h
--- a/sys/arch/arm/include/mutex.h      Fri Mar 28 21:39:09 2014 +0000
+++ b/sys/arch/arm/include/mutex.h      Fri Mar 28 21:40:53 2014 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: mutex.h,v 1.13 2012/09/25 05:24:00 matt Exp $  */
+/*     $NetBSD: mutex.h,v 1.14 2014/03/28 21:40:53 matt Exp $  */
 
 /*-
  * Copyright (c) 2002, 2007 The NetBSD Foundation, Inc.
@@ -88,12 +88,28 @@
  * MUTEX_RECEIVE: no memory barrier required; we're synchronizing against
  * interrupts, not multiple processors.
  */
+#ifdef MULTIPROCESSOR
+#if defined(_ARM_ARCH_7) && !defined(_ARM_ARCH_6)
+#define        MUTEX_RECEIVE(mtx)              __asm __volatile("dmb")
+#else
+#define        MUTEX_RECEIVE(mtx)              membar_consumer()
+#endif
+#else
 #define        MUTEX_RECEIVE(mtx)              /* nothing */
+#endif
 
 /*
  * MUTEX_GIVE: no memory barrier required; same reason.
  */
+#ifdef MULTIPROCESSOR
+#if defined(_ARM_ARCH_7) && !defined(_ARM_ARCH_6)
+#define        MUTEX_RECEIVE(mtx)              __asm __volatile("dsb")
+#else
+#define        MUTEX_GIVE(mtx)                 membar_producer()
+#endif
+#else
 #define        MUTEX_GIVE(mtx)                 /* nothing */
+#endif
 
 #define        MUTEX_CAS(p, o, n)              \
     (atomic_cas_ulong((volatile unsigned long *)(p), (o), (n)) == (o))
diff -r 2be76ffc1895 -r eb853e1a6da0 sys/arch/arm/include/rwlock.h
--- a/sys/arch/arm/include/rwlock.h     Fri Mar 28 21:39:09 2014 +0000
+++ b/sys/arch/arm/include/rwlock.h     Fri Mar 28 21:40:53 2014 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: rwlock.h,v 1.6 2014/01/29 00:17:21 matt Exp $  */
+/*     $NetBSD: rwlock.h,v 1.7 2014/03/28 21:40:53 matt Exp $  */
 
 /*-
  * Copyright (c) 2002, 2006 The NetBSD Foundation, Inc.
@@ -40,8 +40,18 @@
 
 #define        __HAVE_SIMPLE_RW_LOCKS          1
 
+#ifdef MULTIPROCESSOR
+#if defined(_ARM_ARCH_7) && !defined(_ARM_ARCH_6)
+#define        RW_RECEIVE(rw)                  __asm __volatile("dmb")
+#define        RW_GIVE(rw)                     __asm __volatile("dsb")
+#else
+#define        RW_RECEIVE(rw)                  membar_consumer()
+#define        RW_GIVE(rw)                     membar_producer()
+#endif
+#else
 #define        RW_RECEIVE(rw)                  /* nothing */
 #define        RW_GIVE(rw)                     /* nothing */
+#endif
 
 #define        RW_CAS(p, o, n)                 \
     (atomic_cas_ulong((volatile unsigned long *)(p), (o), (n)) == (o))



Home | Main Index | Thread Index | Old Index