Source-Changes-HG archive

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

[src/trunk]: src/sys/external/bsd/drm2/linux Implement atomic64_add_return an...



details:   https://anonhg.NetBSD.org/src/rev/a6fa204e4a3c
branches:  trunk
changeset: 993085:a6fa204e4a3c
user:      riastradh <riastradh%NetBSD.org@localhost>
date:      Mon Aug 27 15:11:17 2018 +0000

description:
Implement atomic64_add_return and atomic64_inc_return.

diffstat:

 sys/external/bsd/drm2/include/linux/atomic.h |  22 +++++++++++++++++++++-
 sys/external/bsd/drm2/linux/linux_atomic64.c |  16 ++++++++++++++--
 2 files changed, 35 insertions(+), 3 deletions(-)

diffs (92 lines):

diff -r 1642aefb3739 -r a6fa204e4a3c sys/external/bsd/drm2/include/linux/atomic.h
--- a/sys/external/bsd/drm2/include/linux/atomic.h      Mon Aug 27 15:11:04 2018 +0000
+++ b/sys/external/bsd/drm2/include/linux/atomic.h      Mon Aug 27 15:11:17 2018 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: atomic.h,v 1.18 2018/08/27 15:11:04 riastradh Exp $    */
+/*     $NetBSD: atomic.h,v 1.19 2018/08/27 15:11:17 riastradh Exp $    */
 
 /*-
  * Copyright (c) 2013 The NetBSD Foundation, Inc.
@@ -264,6 +264,18 @@
        atomic_add_64(&a->a_v, -d);
 }
 
+static inline int64_t
+atomic64_add_return(int64_t d, struct atomic64 *a)
+{
+       int64_t v;
+
+       smp_mb__before_atomic();
+       v = (int64_t)atomic_add_64_nv(&a->a_v, d);
+       smp_mb__after_atomic();
+
+       return v;
+}
+
 static inline uint64_t
 atomic64_xchg(struct atomic64 *a, uint64_t new)
 {
@@ -296,6 +308,7 @@
 #else  /* !defined(__HAVE_ATOMIC64_OPS) */
 
 #define        atomic64_add            linux_atomic64_add
+#define        atomic64_add_return     linux_atomic64_add_return
 #define        atomic64_cmpxchg        linux_atomic64_cmpxchg
 #define        atomic64_read           linux_atomic64_read
 #define        atomic64_set            linux_atomic64_set
@@ -306,11 +319,18 @@
 void           atomic64_set(struct atomic64 *, uint64_t);
 void           atomic64_add(int64_t, struct atomic64 *);
 void           atomic64_sub(int64_t, struct atomic64 *);
+int64_t                atomic64_add_return(int64_t, struct atomic64 *);
 uint64_t       atomic64_xchg(struct atomic64 *, uint64_t);
 uint64_t       atomic64_cmpxchg(struct atomic64 *, uint64_t, uint64_t);
 
 #endif
 
+static inline int64_t
+atomic64_inc_return(struct atomic64 *a)
+{
+       return atomic64_add_return(1, a);
+}
+
 struct atomic_long {
        volatile unsigned long  al_v;
 };
diff -r 1642aefb3739 -r a6fa204e4a3c sys/external/bsd/drm2/linux/linux_atomic64.c
--- a/sys/external/bsd/drm2/linux/linux_atomic64.c      Mon Aug 27 15:11:04 2018 +0000
+++ b/sys/external/bsd/drm2/linux/linux_atomic64.c      Mon Aug 27 15:11:17 2018 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: linux_atomic64.c,v 1.2 2018/08/27 15:10:53 riastradh Exp $     */
+/*     $NetBSD: linux_atomic64.c,v 1.3 2018/08/27 15:11:17 riastradh Exp $     */
 
 /*-
  * Copyright (c) 2018 The NetBSD Foundation, Inc.
@@ -30,7 +30,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: linux_atomic64.c,v 1.2 2018/08/27 15:10:53 riastradh Exp $");
+__KERNEL_RCSID(0, "$NetBSD: linux_atomic64.c,v 1.3 2018/08/27 15:11:17 riastradh Exp $");
 
 #include <sys/param.h>
 #include <sys/bitops.h>
@@ -164,6 +164,18 @@
        atomic64_unlock(a);
 }
 
+int64_t
+atomic64_add_return(int64_t delta, struct atomic64 *a)
+{
+       int64_t v;
+
+       atomic64_lock(a);
+       v = (int64_t)(a->a_v += delta);
+       atomic64_unlock(a);
+
+       return v;
+}
+
 uint64_t
 atomic64_xchg(struct atomic64 *a, uint64_t new)
 {



Home | Main Index | Thread Index | Old Index